メインコンテンツにスキップ
バージョン: v2.6.0

Mac App Storeガイド

このページでは、WailsアプリをMac App Storeで公開する方法について、概要を説明します。

前提条件

  • Apple Developerアカウントを所持しておく必要があります。 詳しくは、Apple Developer Programのサイトを確認してください。
  • 開発者ポータルで、証明書、ID、アプリを作成しておく必要があります。 詳しくは以下の手順に従ってください。
  • Xcodeコマンドラインツールを、あなたのローカルマシンにインストールしておく必要があります。

証明書とIDの作成

  1. Apple Developerアカウントへアクセスします。
  2. Certificates, Identifiers & Profiles内にあるIdentifiersをクリックし、新しいApp IDを登録します。 (com.example.app) のような形式にしてください。
  3. 同じページでCertificatesをクリックし、Mac App Storeディストリビューション用の新しい証明書を生成します。 それらの証明書をダウンロードし、ローカルマシンのKeychainにインポートしてください。

アプリ提出物の作成

  1. App Store Connectサイトへアクセスします。
  2. 新しいアプリケーションを登録し、前のステップで作成済みのバンドルIDをリンクします。
  3. Appleの要求する正規のスクリーンショットや説明文などを、アプリに追加します。
  4. アプリの新しいバージョンを作成します。

プロビジョニングプロファイルの作成

  1. Apple Developerプロフィールページへアクセスします。
  2. Mac App Storeへの配布用に、新しいプロビジョニングプロファイルを追加します。
  3. プロファイルタイプをMacに設定し、先ほど作成したアプリケーションのApp IDを選択します。
  4. Mac App Distribution証明書を選択します。
  5. 埋め込みプロビジョニングプロファイルに名前をつけ、作成されたプロファイルをダウンロードします。

Mac App Storeへの公開手順

AppleのApp Sandboxの有効化

Mac App Storeへ提出されるアプリは、AppleのApp Sandbox内で動作する必要があります。 そのためには、entitlements.plistファイルを作成しておく必要があります。 ファイルは、{PROJECT_DIR}/build/darwin/entitlements.plist配下に作成することを推奨します。

entitlementsファイルの例

ここでは、RiftShareというアプリのentitlementsファイルを例として示します。 参考として、アプリが必要とする権限を入力してください。 詳しくは、こちらのサイトをご覧ください。 チーム ID とアプリケーション名を上記で登録したものに置き換える必要があります。

entitlements.plist
<?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/>
<key>com.apple.application-identifier</key>
<string>TEAM_ID.APP_NAME</string>
<key>com.apple.developer.team-identifier</key>
<string>TEAM_ID</string>
</dict>
</plist>

組み込みプロビジョニング プロファイルの追加 上記で作成したプロビジョニング プロファイルは、アプリケーションのルートに追加する必要があります。 embedded.provisionprofile という名前にする必要があります。

アプリパッケージのビルドと署名

以下は、Mac App Storeへの提出用に、アプリをビルドおよび署名するスクリプトの例です。 プロジェクトのルートディレクトリからスクリプトを実行することを前提としています。

アプリへ署名するための証明書と、インストーラへ署名するための証明書は異なりますので、ご注意ください。 両方の証明書がKeychainにインポートされていることを確認してください。 Keychainで文字列を探し、下記スクリプトに挿入してください。 具体的には、証明書名およびアプリ名を入力します。 以下のスクリプトを実行すると、アプリケーションのルートディレクトリに、署名済みのapp.pkgファイルが生成されます。

macappstore-build.sh
#!/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

cp ./embedded.provisionprofile "./build/bin/$APP_NAME.app/Contents"

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

アプリバンドルのアップロード

審査向けに提出が可能となる前に、生成されたパッケージファイルをアップロードし、アプリケーションに関連付ける必要があります。

  1. Mac App StoreからTransporter Appをダウンロードします。
  2. アプリを起動し、Apple IDでサインインします。
  3. +マークをクリックし、前のステップで生成済みのAPP_NAME.pkgファイルを選択します。 そしてアップロードします。
  4. App Store Connectサイトへ戻り、アプリ提出物ページへ戻ります。 App Storeで公開する準備できているバージョンを選択します。 Build内で、Transporter経由でアップロードしたパッケージを選択します。

以上で終了です! サイトで、アプリを審査のために提出できるようになりました。 数営業日後、審査結果に問題が無ければ、アプリがMac App Storeに公開されます。