# インストール方法

## サーバーに直接インストールする

1. サーバーに git, Nodejs, npm, PostgreSQL, PGroonga, Redis, Rust をインストールします。Arch Linux にインストールする場合には[私のブログ](https://blog.naskya.net/post/6kic0tebueju/)が参考になるかもしれません。

    Ubuntu や Debian にインストールする場合には、例えば以下のようになります。

    ```bash
    # Rust のインストール
    curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

    # Nodejs v21 のインストールの準備
    NODE_MAJOR=21
    sudo apt install --no-install-recommends curl ca-certificates gnupg
    sudo mkdir -p /etc/apt/keyrings
    curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key \
      | sudo gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
    echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] "https://deb.nodesource.com/node_${NODE_MAJOR}.x" nodistro main" \
      | sudo tee /etc/apt/sources.list.d/nodesource.list

    # PostgreSQL のインストールの準備
    echo "deb https://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" | sudo tee /etc/apt/sources.list.d/pgdg.list
    curl -s https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -

    # PGroonga のインストールの準備
    sudo apt install --no-install-recommends software-properties-common wget
    sudo add-apt-repository -y universe
    sudo add-apt-repository -y ppa:groonga/ppa
    wget https://packages.groonga.org/ubuntu/groonga-apt-source-latest-$(lsb_release --codename --short).deb
    sudo apt install --no-install-recommends ./groonga-apt-source-latest-$(lsb_release --codename --short).deb
    echo "deb http://apt.postgresql.org/pub/repos/apt/ $(lsb_release --codename --short)-pgdg main" | sudo tee /etc/apt/sources.list.d/pgdg.list
    wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -

    # Redis のインストールの準備
    curl -fsSL https://packages.redis.io/gpg | sudo gpg --dearmor -o /usr/share/keyrings/redis-archive-keyring.gpg

    # 各ソフトウェアのインストール
    sudo apt update
    sudo apt install --no-install-recommends git nodejs postgresql-16 postgresql-16-pgdg-pgroonga redis-server

    # pnpm を有効化
    sudo corepack enable

    # PostgreSQL, Redis を起動
    systemctl enable --now postgresql redis-server
    ```

2. このリポジトリを複製し、リポジトリのディレクトリに移る

    ```bash
    git clone --branch=main https://code.naskya.net/naskya/firefish
    cd firefish
    ```

3. 設定ファイルのテンプレートを複製する

    ```bash
    cp .config/example.yml .config/default.yml
    ```

4. PostgreSQL のユーザー名・データベース名・パスワードを決める(決めるだけでこの工程にコマンドの操作は無い)

5. `./config/default.yml` を編集する

    ```bash
    vim .config/default.yml
    ```

    `url` という項目を `example.com` から使いたいドメイン名に変更する

    ```yaml
    # Final accessible URL seen by a user.
    url: https://example.com/
    ```

    データベースの設定を変える(データベース名・ユーザー名・パスワードはそれぞれさっき自分で決めたもの)

    ```yaml
    db:
      host: localhost  # 変えない
      port: 5432       # 変えない

      db: firefish_db  # ここをデータベース名に変える

      user: firefish   # ここをデータベースのユーザー名に変える
      pass: very_strong_password  # ここをデータベースのパスワードに変える
    ```

6. PostgreSQL のユーザーとデータベースを作る

    ```bash
    POSTGRES_DB='データベース名'
    POSTGRES_USER='ユーザー名'
    POSTGRES_PASSWORD='パスワード'

    sudo -u postgres psql --command="CREATE ROLE ${POSTGRES_USER} LOGIN PASSWORD '${POSTGRES_PASSWORD}';"
    sudo -u postgres psql --command="CREATE DATABASE ${POSTGRES_DB} OWNER ${POSTGRES_USER} encoding = 'UTF8';"
    ```

7. データベースに変更を加える

    ```bash
    sudo -u postgres psql --dbname="${POSTGRES_DB}" --file=neko/install.sql
    ```

8. Firefish をビルドする

    ```bash
    ./update.sh --install --native
    ```

9. Firefish を起動するための systemd サービスを作る

    `/etc/systemd/system/firefish.service` というテキストファイルを作り、Firefish をインストールしたディレクトリで `pnpm run start` を実行させるようにします。[私のブログ](https://blog.naskya.net/post/6kic0tebueju/#firefish-%E3%82%92%E8%B5%B7%E5%8B%95)や [systemd サービスに関する記事](https://wiki.archlinux.jp/index.php/Systemd#.E3.83.A6.E3.83.8B.E3.83.83.E3.83.88.E3.83.95.E3.82.A1.E3.82.A4.E3.83.AB)などを参考にしてください。

    以下の設定を行えば大丈夫なはずです。
    - 実行するユーザーをグループを指定する
    - `which pnpm` で `pnpm` コマンドの場所(例えば `/usr/bin/pnpm`)を探し、`ExecStart` で `pnpm run start` を実行させる
      - 例えば `ExecStart=/usr/bin/pnpm run start`
    - リポジトリのディレクトリを `WorkingDirectory` に設定する
    - `Environment="NODE_ENV=production"`

    ```bash
    sudo vim /etc/systemd/system/firefish.service
    ```

10. Firefish のサービスを有効化・起動する

    ```bash
    sudo systemctl enable --now firefish
    ```

これで `http://localhost:3000` で Web クライアントが動くので、リバースプロキシやファイヤーウォールを設定して外部からアクセス可能にすればよいです。その設定には[私のブログ](https://blog.naskya.net/post/6kic0tebueju/)や[本家 Firefish の README](https://git.joinfirefish.org/firefish/firefish#-getting-started)が参考になるかもしれません。

正常にインストールできなかった場合には自力で解決しようとせず、[私にコマンドの実行ログを送ってください](https://code.naskya.net/naskya/firefish/source-by/main/docs/trouble_shooting.md#私にコマンドの実行ログを送る)。

## コンテナイメージを用いる

実行環境として [Podman](https://podman.io/) と [Docker](https://www.docker.com/) をサポートしています。Docker を使う場合には以下の `podman`, `podman-compose`, `--podman` をそれぞれ `docker`, `docker-compose`, `--docker` に読み替えてください。

x86_64 アーキテクチャの Linux のマシン上では、[`registry.code.naskya.net/naskya/firefish`](https://view.registry.code.naskya.net/naskya/firefish) に上げられている [OCI コンテナイメージ](https://opencontainers.org/)を利用できます。それ以外の環境で使うには、自分でコンテナイメージをビルドする必要があります。

1. このリポジトリを複製し、リポジトリのディレクトリに移る

    ```bash
    git clone --branch=main https://code.naskya.net/naskya/firefish
    cd firefish
    ```

2. 設定ファイルのテンプレートを複製する

    ```bash
    cp docker-compose.example.yml docker-compose.yml
    cp .config/docker.example.env .config/docker.env
    cp .config/example.yml .config/default.yml
    ```

3. PostgreSQL のユーザー名・データベース名・パスワードを決めて `./config/docker.env` に書く

    ```bash
    vim .config/docker.env
    ```

4. `.config/default.yml` を編集する

    ```bash
    vim .config/default.yml
    ```

    `url` という項目を `example.com` から使いたいドメイン名に変更する

    ```yaml
    # Final accessible URL seen by a user.
    url: https://example.com/
    ```

    データベースの設定を変える(データベース名・ユーザー名・パスワードはそれぞれさっき `.config/docker.env` に書いた `POSTGRES_DB`, `POSTGRES_USER`, `POSTGRES_PASSWORD`)

    ```yaml
    db:
      host: localhost  # ここを firefish_db に変える
      port: 5432       # 変えない

      db: firefish_db  # ここをデータベース名に変える

      user: firefish   # ここをデータベースのユーザー名に変える
      pass: very_strong_password  # ここをデータベースのパスワードに変える
    ```

    Redis の設定を変える

    ```yaml
    redis:
      host: localhost  # ここを firefish_redis に変える
    ```

5. コンテナイメージをダウンロードまたはビルドする

    ```bash
    ./update.sh --install --podman
    ```

6. Firefish を起動する

    ```bash
    podman-compose up --detach
    ```

これで `http://localhost:3000` で Web クライアントが動くので、リバースプロキシやファイヤーウォールを設定して外部からアクセス可能にすればよいです。その設定には[私のブログ](https://blog.naskya.net/post/6kic0tebueju/)や[本家 Firefish の README](https://git.joinfirefish.org/firefish/firefish#-getting-started)が参考になるかもしれません。

正常にインストールできなかった場合には自力で解決しようとせず、[私にコマンドの実行ログを送ってください](https://code.naskya.net/naskya/firefish/source-by/main/docs/trouble_shooting.md#私にコマンドの実行ログを送る)。