Skip to content

fetus-hina/stat.ink

Repository files navigation

stat.ink

status

Yii2 MIT License Actions Status

Source codes for https://stat.ink/

SquidTracks, splatnet2statink, IkaLog, s3s 等の対応ソフトウェア、または自作のソフトウェアと連携することで Splatoon 1, 2, 3 の戦績を保存し、統計を取ります。

This software will save your Splatoon 1, 2, 3 battle results and get statistics by integrating with "supported software" such as SquidTracks, splatnet2statink, IkaLog, s3s, etc., or your own app.

バグレポート BUG REPORT

バグレポートは日本語で大丈夫です。開発者は日本語しかまともに使えない日本人です。

I'll accept your bug report in English or Japanese.
The administrator is not goot at English. Please use easy English and do not use idioms or slangs.

問題がセキュリティにかかわるものであれば、非公開の方法を利用してください。
Use a private channel if it is a security issue.

REQUIREMENTS

  • PHP 8.2
    • PHP 8.1以下では動作しません。(8.2で追加された構文等を利用しています)
      Doesn't work with 8.1 or lower. (Uses statements and constants added in v8.2)
    • Argon2が有効化されたPHPが必要です。RemirepoのPHPを利用している場合、php-sodiumをインストールしてください。(詳細
      You should build/install with Argon2. Install php-sodium if you use remirepo's PHP.
    • 現在のところ、PHP 8.3+での動作は確認していません。
      At this time, we have not tested it with PHP 8.3+.
  • PostgreSQL 9.5+ (Recommended: 11+)
    • PgSQL 9.4以下では動作しません(9.5で追加された機能を利用しています)
      Doesn't work with 9.4 or lower. (Uses features added in v9.5)
  • ImageMagick (convert)
  • Node.js (npm)
    • Recommended: latest release or latest LTS
  • jpegoptim
  • MaxMind's account

https://stat.ink/ works with:

  • CentOS 7 (x86-64)
  • EPEL
  • JP3CKI Repository
  • Remi's RPM repository
    • remi-safe repository, it uses SCL mechanism
      • PHP 8.2
        • php82-php-cli
        • php82-php-fpm
        • php82-php-gd
        • php82-php-intl
        • php82-php-mbstring
        • php82-php-mcrypt
        • php82-php-pdo
        • php82-php-pecl-msgpack
        • php82-php-pgsql
        • php82-php-sodium

Notes:

  • CentOS 7のデフォルトのPHPバージョンは5.4.16です。このバージョンでは動作しません。PHP 8.2までで追加された機能を利用しています。
    Default version of PHP on CentOS 7 is 5.4.16. This application doesn't work on it. We are using features and statements that were added up to PHP 8.2.

  • CentOS 7のデフォルトのPostgreSQLバージョンは9.2.14です。このバージョンでは動作しません。PgSQL 9.5で追加された機能を利用しています(jsonb, UPSERT)。実際のシステムではPgSQL 11を利用していますが、9.5でも充分動作します。
    Default version of PostgreSQL on CentOS 7 is 9.2.14. This application doesn't work with it. We are using features added in PostgreSQL 9.5 (e.g., jsonb, UPSERT). We use PostgreSQL 11 in our actual system, but 9.5 will work just fine.

MaxMind's Account

stat.inkは利用者のタイムゾーンの検出等にGeoIPデータベースを利用します。 データベースをダウンロードするには、MaxMindへの会員登録が必要です。(無料)

Stat.ink uses the GeoIP database for purposes such as detecting the user's time zone. You need to register an account on MaxMind to download the database (No additional cost required).

  1. MaxMindに会員登録します(またはログインします)
    Sign up for MaxMind account (or just log in)

  2. 「My License Key」ページにアクセスし、「Generate new license key」をクリックします。
    Access to "My License Key" page and click "Generate new license key."

  3. 「License key description」を埋め、ライセンスキーを発行します。
    Fill in "License key description" and issue a license key.

  4. ライセンスキーを記録します。ライセンスキーはこれを最後に表示されないので注意してください。
    Note the license key. The license key won't be displayed again.

ライセンスキーを発行したら、環境変数 GEOIP_LICENSE_KEY に設定します。
bashを利用しているなら、~/.bashrc に追加するなどの方法があります。

After issuing the license key, set the license key to the environment variable "GEOIP_LICENSE_KEY".
If you are using bash, you may want to add the following to your ~/.bashrc:

export GEOIP_LICENSE_KEY=ABCDEFGHIJKLMNOP

.bashrc を編集したら、シェルを再起動するか、source ~/.bashrc してください。

After editing .bashrc, reopen the shell or remember source ~/.bashrc.

Branches

2つの主たるブランチがあります。 masterdev です。

We have 2 main branches. The one is master and the other is dev.

master branch

このブランチがサーバにデプロイされます。 dev ブランチから不定期に変更が取り込まれます。

This branch is deployed to the server. Changes are merged from the dev branch at irregular intervals.

コントリビュートいただく場合、このブランチへプルリクエストは行わないでください。

When you contribute to us, you should not request changes to this branch.

master はただの識別子です。政治的・差別的意図はありません。

The word master is just an identifier. There are no political or discriminatory intentions.

dev branch

アプリの開発はこのブランチで行います。

The development of the app takes place on this branch.

プルリクエストを作成する場合、このブランチから/へ行ってください。

If you think you're going to make a pull request, make the change from this branch.

使い方 HOW TO USE (DEVELOPER)

SETUP

Recommend: Setup with Vagrant

Another way: How to setup a development environment

Note: Docker way is abandoned.

UPDATE

git fetch --all && \
  git merge --ff-only origin/master && \
  ./composer.phar install --prefer-dist && \
  make && \
  ./yii asset/up-revision

API

stat.ink にデータを投稿する、または取得する API は次のページを参照してください。 See the pages below for APIs to post and retrieve data from stat.ink.

コーディング規約 CODING STANDARDS

Language Coding Standards
PHP PSR-12-based, See phpcs.xml
PHP (views) Indent with 2 spaces
JavaScript semistandard
SCSS / CSS Sass Guidelines-based, See .stylelintrc

ライセンス LICENSE

The MIT License (MIT)

Copyright (c) 2015-2024 AIZAWA Hina <hina@fetus.jp>

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

ライセンス(アプリケーションテンプレート) LICENSE (App Template)

The Yii framework is free software. It is released under the terms of
the following BSD License.

Copyright © 2008 by Yii Software LLC (http://www.yiisoft.com)
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:

 * Redistributions of source code must retain the above copyright
   notice, this list of conditions and the following disclaimer.
 * Redistributions in binary form must reproduce the above copyright
   notice, this list of conditions and the following disclaimer in
   the documentation and/or other materials provided with the
   distribution.
 * Neither the name of Yii Software LLC nor the names of its
   contributors may be used to endorse or promote products derived
   from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.

ライセンス(ドキュメント類) LICENSE (DOCUMENTS)

CC-BY 4.0

ドキュメント類のライセンスはCreative Commons - 表示 4.0 国際の下にライセンスされています。

Documents of stat.ink project are licensed under a Creative Commons Attribution 4.0 International License.