3
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

TauriAdvent Calendar 2024

Day 18

Tauri のアップデーター機能の利用

Last updated at Posted at 2024-12-17

はじめに

Electron にも標準でアップデーターの機能がある が、Tauri にもその機能がある
このアップデーターを使用する方法を調べてまとめてみた。

環境

  • Windows 11 Pro 23H2
  • Tauri v1.4

主な手順

次項で詳しく内容をまとめるが、若干ややこしいので、この手順でやったらいいだろうというのを先に手順だけまとめておく。

  1. 認証情報の発行
  2. tauri.config.json への tauri.updater の項目追加
  3. tauri.config.json への認証情報の追記
  4. tauri.config.json へのエンドポイント endpoints の設定
  5. Updater 付インストーラー作成環境の設定 (環境変数の設定)
  6. Updater 付インストーラーのビルド
  7. Updater 付インストーラーの配置

アップデーターの設定

認証情報の発行

まずは認証情報を発行する。
以下のコマンドは pnpm、npm、yarn、bun などでも可。

cargo tauri signer generate -w ~/.tauri/myapp.key

Windows の場合は、以下の方を使用する。

cargo tauri signer generate -w $HOME/.tauri/myapp.key

コマンドを実行すると、パスワードの入力を求められるので、パスワードを入力する。

Please enter a password to protect the secret key.
Password: 
Password (one more time): 
Deriving a key from the password in order to encrypt the secret key... done

すると、指定したディレクトリに以下の二つのファイルが作成される。

Your keypair was generated successfully
Private: C:\Users\aurat\.tauri\myapp.key (Keep it secret!)
Public: C:\Users\aurat\.tauri\myapp.key.pub
  • myapp.key
    • 暗号キー
    • 秘密情報をとして扱う
  • myapp.key.pub
    • 公開キー
    • tauri.config.json に記載する

Tauri コンフィグを設定する

アップデーターを有効にするには、以下の条件が必要になる。

  • tauri.updater.activetrue にすること
  • tauri.updater.endpoints に記載すること
  • tauri.updater.pubkey に記載すること
    • ハッシュ文字列
    • 先に作成した myapp.key.pub の中身を記載する

以下の様に Tauri コンフィグを設定する。
エンドポイント (endpoints) の設定方法は後の方で説明する。

{
  "tauri": {
    "updater": {
      "active": true,
      "endpoints": [
        "https://releases.myapp.com/{{target}}/{{arch}}/{{current_version}}"
      ],
      "dialog": true,
      "pubkey": "<myapp.key.pub の中身 (ハッシュ値) をこちらに記載する。>"
    }
  }
}

どのアップデート認識を使用するかを選択する

Tauri アップデーターには、二通りのアップデート認証方式が存在する。
この違いによって、先のエンドポイントの設定やインストーラーの配置の仕方が変わってくるので注意する。

  • 静的 JSON ファイルを使用する
  • ダイナミックアップデートサーバーを使用する

環境変数の設定

認証情報を有効にしてビルドするために、環境変数に以下の情報を設定する。

  • TAURI_PRIVATE_KEY
    • myapp.key ファイルのファイルパス
  • TAURI_KEY_PASSWORD
    • myapp.key を作成した際に設定したパスワード

VSCode の tasks.json で設定する

もし、ソースコードをプライベートに管理出来て、プロジェクトルートに .tauri/update.key みたいに管理できるのであれば、VS Code の場合、以下の様にして勝手にフルパスが代入されるようにしてミスを減らすのも手。

.vscode/tasks.json
{
	"version": "2.0.0",
	"tasks": [
		{
			"label": "ui:build",
			"type": "shell",
			"command": "cargo",
			"args": ["tauri", "build"],
			"group": "build",
			"options": {
				"env": {
					"TAURI_PRIVATE_KEY": "${workspaceFolder}\\.tauri\\update.key",
					"TAURI_KEY_PASSWORD": "123456"
				}
			}
		}
	]
}

ビルドする

上記まで設定ができれば、後は通常通りにビルド (tauri build) するだけ。

cargo tauri build

こうしてビルドすると、Windows で NSIS タイプのインストーラーの場合、以下のアーティファクトが作成される。

  • *.exe 拡張子のインストーラー
  • *.nsis.zip という名前+拡張子のアップデーター用ファイル
  • *.nsis.zip.sig という名前+拡張子の署名ファイル

このした二つをアップデーターとして利用する。

エンドポイントの設定の仕方

エンドポイント URL の記載には以下の変数が利用できる。

変数 説明
{{target}} linuxwindowsdarwin が利用可能。
{{arch}} x86_64i686aarch64armv7 のいずれかを利用可能。
{{current_version}} バージョンを指定してアップデートを促したい場合はこちらを使用して入力する。

しかしながら、最新を提供したい場合であれば、単一のファイルでも良い。
以下の様に latest.json のみを作成し、所定の場所に配置する運用もある。

https://example.org/app/myapp/latest.json

エンドポイントは複数設定可能なので、例えば target + arch ごとに分けるという運用は多く発生しそう。
しかしながら、アプリ内にこのエンドポイントは埋め込むことになるので、 veersion 等のハードコードはあまり望ましくないと思われる。

静的 JSON ファイル

例えば、GitHub の Releases を参照する場合は次の様に JSON ファイルを設定する。

{
  "version": "v1.0.0",
  "notes": "Test version",
  "pub_date": "2020-06-22T19:25:57Z",
  "platforms": {
    "darwin-x86_64": {
      "signature": "Content of app.tar.gz.sig",
      "url": "https://github.com/username/reponame/releases/download/v1.0.0/app-x86_64.app.tar.gz"
    },
    "darwin-aarch64": {
      "signature": "Content of app.tar.gz.sig",
      "url": "https://github.com/username/reponame/releases/download/v1.0.0/app-aarch64.app.tar.gz"
    },
    "linux-x86_64": {
      "signature": "Content of app.AppImage.tar.gz.sig",
      "url": "https://github.com/username/reponame/releases/download/v1.0.0/app-amd64.AppImage.tar.gz"
    },
    "windows-x86_64": {
      "signature": "Content of app-setup.nsis.sig or app.msi.sig, depending on the chosen format",
      "url": "https://github.com/username/reponame/releases/download/v1.0.0/app-x64-setup.nsis.zip"
    }
  }
}

静的 JSON ファイルの運用イメージ
先にも記載のとおり、より具体的なファイル名として、 latest.json といった感じで、「最新は何か?」というものだけを扱うように設定していくのがこのアップデートコンフィグの設定用途。
必ず最新だけを確認できるようにする」という認識でいると理解しやすい。

仕様

キー 説明
version バージョン名。セマンティックバージョン表記のみに対応 Ex: 1.0.0v1.0.0
platforms プラットフォームの記載 OS-ARCH という感じに、ハイフンでつないで記載する。例: windows-x86_64
url アップデーターバンドル (生成された .zip ファイルなど) への URL。
signature ビルド時に生成された署名。同じバージョンであってもビルド毎に変動するので注意する。
notes パブリッシュノート。日本語などのマルチバイト文字も入力可。
pub_date 公開日を [RFC 3339(https://datatracker.ietf.org/doc/html/rfc3339#section-5.8) 形式で記載する。 Ex: 2024-05-19T20:04:01Z

このアップデーター用静的 JSON ファイルを用意する際には必須項目がある。
上記を用いて、

  • version
  • platforms.[target].url
  • platforms.[target].signature

は必須項目となるので埋めておく。

シンプルな具体例

これについてシンプルな具体例を作成してみる。
例えば、以下のファイルを S3 など、アプリの実行者から読める場所に配置する。

{
	"version": "1.3.3",
	"notes": "新規機能の実装",
	"pub_date": "2024-05-19T20:04:01Z",
	"platforms": {
		"windows-x86_64": {
			"signature": "<ビルド時に発行された署名>",
			"url": ".../Gaia_0.27.0_x64-setup.nsis.zip"
		}
	}
}

ダイナミックアップデートサーバーを使用する

ダイナミックアップデートサーバーを利用するメリット
ダイナミックアップデーターを使用する場合、例えば、v1.0.5 をリリースした場合、そのバージョンに致命的なエラーがあったとする。その場合に v1.0.4 などのバージョンへのロールバックを促したい場合などに対応できる

こちらはまた機会があったら別途まとめる。
サーバー設定とかもろもろ書いてるとかなりの規模になりそうなので。

アップデーターの利用

アップデーターの利用タイミング

アップデーターが走る・走らせるタイミングとしては以下のようなケースがある。

  • 起動時
  • アップデート確認ボタンを押したとき

この中で「起動時」に関しては、デフォルトのアップデートダイアログを表示する設定だと必ず走るようになる。

tauri.config.json
{
  "tauri": {
    "updater": {
      "dialog": true
    }
  }
}

アップデーターダイアログのカスタマイズ

アプリのデザインに合わせてアップデートダイアログをカスタムしたい場合は、デフォルトのダイアログを切って実装することもできる。

そのためにはまずはコンフィグでダイアログの表示をオフにする。

tauri.config.json
{
  "tauri": {
    "updater": {
      "dialog": false
    }
  }
}

起動時のアップデート確認

例えば Svelte の場合、トップレベルの +layout.svelte ファイルに次のようなスクリプトを埋め込む。

+layout.svelte
<script lang="ts">
    import {
        checkUpdate,
    } from '@tauri-apps/api/updater'

    onMount(() => {
		checkUpdate()
	});
<script>

アップデート確認ボタン

+layout.svelte
<script lang="ts">
    import {
        checkUpdate,
    } from '@tauri-apps/api/updater'

    onMount(() => {
		checkUpdate()
	});
<script>

<button>

Tuari v2 への対応

v2 では、Tauri コマンドでのアップデーター追加が行えるようになっている。

ベースとなる部分は基本的に v1 と変わらないが、v2 と v1 への継続サポートということで少しだけオプションが追加されている。

その一つが、updater コンフィグあとリビューとの中に createUpdaterArtifacts アトリビュートを加えるというもの。

v2 のみの場合は以下の様に書くが、

v2
{
  "bundle": {
    "createUpdaterArtifacts": true
  }
}

v1 の Updater と互換性を保つ場合は以下の様に指定する。

v1Compatible
{
  "bundle": {
    "createUpdaterArtifacts": "v1Compatible"
  }
}

トラブルシュート

どんだけ慎重に進めていてもトラブルはつきもの。
次の項目は良く遭遇すると思われるので、一応まとめる。

Error Invalid byte 46, offset 6.

他にも Error Encoded text cannot have a 6-bit remainder. といったエラーも発生する。

原因

以下の原因の可能性がある。

  • プライベートキーのパスを間違えている
    • これの可能性が高い
    • 特に Windows の場合、パスの扱いをミスりやすいので凝りうる
  • パブリックキーとプライベートキーのペアが一致しない
    • 間違えてはいけないのが、 tauri.config.json に記載するのは、パブリックキーのファイルの中の文字列 (ハッシュ値)。プライベートキーはパスで指定するので、間違えてパブリックキーもパスで指定してしまうと行った事が起こると同様のエラーが発生する

解決方法

  • プライベートキーへのパスを正しく入力する
    • Windows の場合、ミスりやすいので気を付けよう
    • 先の通り、VSCode などで管理し、必ず指定のパスでビルド時に環境変数が設定されるようにする方がミスらなくていい
  • パブリックキーとプライベートキーのペアが一致しない
    • こちらの問題は、正しく入力しかない
3
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?