Mac App Storeガイド
このページでは、WailsアプリをMac App Storeで公開する方法について、概要を説明します。
前提条件
- Apple Developerアカウントを所持しておく必要があります。 詳しくは、Apple Developer Programのサイトを確認してください。
- 開発者ポータルで、証明書、ID、アプリを作成しておく必要があります。 詳しくは以下の手順に従ってください。
- Xcodeコマンドラインツールを、あなたのローカルマシンにインストールしておく必要があります。
証明書とIDの作成
- Apple Developerアカウントへアクセスします。
Certificates, Identifiers & Profiles
内にあるIdentifiers
をクリックし、新しいApp IDを登録します。 (com.example.app) のような形式にしてください。- 同じページで
Certificates
をクリックし、Mac App Storeディストリビューション用の新しい証明書を生成します。 それらの証明書をダウンロードし、ローカルマシンのKeychainにインポートしてください。
アプリ提出物の作成
- App Store Connectサイトへアクセスします。
- 新しいアプリケーションを登録し、前のステップで作成済みのバンドルIDをリンクします。
- Appleの要求する正規のスクリーンショットや説明文などを、アプリに追加します。
- アプリの新しいバージョンを作成します。
Mac App Storeへの公開手順
AppleのApp Sandboxの有効化
Mac App Storeへ提出されるアプリは、AppleのApp Sandbox内で動作する必要があります。 そのためには、entitlements.plist
ファイルを作成しておく必要があります。 ファイルは、{PROJECT_DIR}/build/darwin/entitlements.plist
配下に作成することを推奨します。
entitlementsファイルの例
ここでは、RiftShareというアプリのentitlementsファイルを例として示します。 参考として、アプリが必要とする権限を入力してください。 詳しくは、こちらのサイトをご覧ください。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>com.apple.security.app-sandbox</key>
<true/>
<key>com.apple.security.network.client</key>
<true/>
<key>com.apple.security.network.server</key>
<true/>
<key>com.apple.security.files.user-selected.read-write</key>
<true/>
<key>com.apple.security.files.downloads.read-write</key>
<true/>
</dict>
</plist>
アプリパッケージのビルドと署名
以下は、Mac App Storeへの提出用に、アプリをビルドおよび署名するスクリプトの例です。 プロジェクトのルートディレクトリからスクリプトを実行することを前提としています。
アプリへ署名するための証明書と、インストーラへ署名するための証明書は異なりますので、ご注意ください。 両方の証明書がKeychainにインポートされていることを確認してください。 Keychainで文字列を探し、下記スクリプトに挿入してください。 具体的には、証明書名およびアプリ名を入力します。 以下のスクリプトを実行すると、アプリケーションのルートディレクトリに、署名済みのapp.pkg
ファイルが生成されます。
#!/bin/bash
APP_CERTIFICATE="3rd Party Mac Developer Application: YOUR NAME (CODE)"
PKG_CERTIFICATE="3rd Party Mac Developer Installer: YOUR NAME (CODE)"
APP_NAME="YourApp"
wails build -platform darwin/universal -clean
codesign --timestamp --options=runtime -s "$APP_CERTIFICATE" -v --entitlements ./build/darwin/entitlements.plist ./build/bin/$APP_NAME.app
productbuild --sign "$PKG_CERTIFICATE" --component ./build/bin/$APP_NAME.app /Applications ./$APP_NAME.pkg
アプリバンドルのアップロード
審査向けに提出が可能となる前に、生成されたパッケージファイルをアップロードし、アプリケーションに関連付ける必要があります。
- Mac App StoreからTransporter Appをダウンロードします。
- アプリを起動し、Apple IDでサインインします。
- +マークをクリックし、前のステップで生成済みの
APP_NAME.pkg
ファイルを選択します。 そしてアップロードします。 - App Store Connectサイトへ戻り、アプリ提出物ページへ戻ります。 App Storeで公開する準備できているバージョンを選択します。
Build
内で、Transporter経由でアップロードしたパッケージを選択します。
以上で終了です! サイトで、アプリを審査のために提出できるようになりました。 数営業日後、審査結果に問題が無ければ、アプリがMac App Storeに公開されます。