ローカルにiOSおよびAndroidビルドの資格情報を保存および管理 - ストアの面倒ごとなくせずに、リアルタイムで__CAPGO_KEEP_0__アプリの更新を管理することができます。5分でインストール

資格情報の管理

iOS と Android のビルド資格情報をローカルに管理して、便利なクラウド ビルドを実行できます。

Capgo CLI では、ビルドの資格情報を保存します。 コンピューター上に保存されます — Capgo のサーバーには保存されません。デフォルトでは、すべてのプロジェクトで共有される 1 つのグローバルファイルに保存されます。 プロジェクトごとに保存する場合は、代わりにパスを渡してください。 ビルドの資格情報は、保存された資格情報が自動的に使用され、安全に __CAPGO_KEEP_0__ に送信され、ビルドが完了したら削除されます。 ~/.capgo-credentials/credentials.json__CAPGO_KEEP_0__ --local __CAPGO_KEEP_1__ __CAPGO_KEEP_0__ __CAPGO_KEEP_0__ .capgo-credentials.json instead. When you run a build, the saved credentials are used automatically and sent securely to Capgo, then deleted after the build completes.

クレデンシャルをインタラクティブに管理

「クレデンシャルをインタラクティブに管理」セクション

保存済みのクレデンシャルと効果的に作業する最速の方法は、インタラクティブ マネージャです。TUI (同じもの)を開き、保存されているものを参照できます。アプリとプラットフォームごとに設定されているものを確認し、CI/CD用のファイルをエクスポートしたり、プラットフォームのクレデンシャルを削除したりできます。 build init ターミナル画面 .env コピー

オプション
bunx @capgo/cli@latest build credentials manage
The quickest way to work with your saved credentials is the interactive manager. It opens a TUI (the same one uses) where you can browse what’s stored, see what’s configured per app and platform, export a CI/CD-ready file, or delete a platform’s credentials:Terminal window
--appId <appId>App を管理する (省略した場合は選択肢を提示します)
--platform <ios|android>プラットフォームを管理する (省略した場合は選択肢を提示します)
--localプロジェクトごとに使用するのではなく、グローバルファイルを使用します。 .capgo-credentials.json グローバルファイルの代わりにプロジェクトごとにファイルを使用します。

一括実行可能なコマンドを使用するのではなく、個別のコマンドを使用しますか? 以下の個別のコマンドを使用してください。

クレデンシャルを保存

クレデンシャルを保存

自動的に使用するためにローカルにビルドクレデンシャルを保存します:

ターミナル画面
bunx @capgo/cli@latest build credentials save --platform <ios|android> [options]

クレデンシャルを更新

クレデンシャルを更新

既存の資格情報を部分的に更新するには、すべて再入力する必要はありません:

ターミナル画面
bunx @capgo/cli@latest build credentials update --platform <ios|android> [options]

この update コマンドは 追加的なマージ プロビジョニングプロファイルの場合 — 新しいプロファイルは既存のプロファイルとマージされます。全体のプロビジョニングマップを置き換える場合は、 --overwrite-ios-provisioning-map.

例 — 既存の資格情報に拡張プロファイルを追加します:

ターミナル画面
bunx @capgo/cli@latest build credentials update \
--platform ios \
--ios-provisioning-profile "com.example.app.widget=./widget_profile.mobileprovision"

更新コマンドは save のオプションを受け付けますが、すべてはオプションです — 提供されたフィールドのみが更新されます。

現在保存されている資格情報を表示 (パスワードはマスクされています):

ターミナル画面
bunx @capgo/cli@latest build credentials list
# List credentials for a specific app
bunx @capgo/cli@latest build credentials list --appId com.example.app

ローカルマシンから保存された資格情報を削除:

ターミナル画面
# Clear all credentials
bunx @capgo/cli@latest build credentials clear
# Clear credentials for a specific app + platform
bunx @capgo/cli@latest build credentials clear --appId com.example.app --platform ios

__CAPGO_KEEP_0__を新しいマルチターゲット形式に変換します:

__CAPGO_KEEP_0__ウィンドウ
bunx @capgo/cli@latest build credentials migrate --platform ios

__CAPGO_KEEP_0__コマンドは、古い BUILD_PROVISION_PROFILE_BASE64 __CAPGO_KEEP_0__、これらを変換し、レガシーキーを削除します。詳細は CAPGO_IOS_PROVISIONING_MAP__CAPGO_KEEP_0__からシングルプロファイルをマイグレーション __CAPGO_KEEP_0__のiOS資格情報を保存 __CAPGO_KEEP_1__

__CAPGO_KEEP_1__

__CAPGO_KEEP_2__
ターミナル画面
bunx @capgo/cli@latest build credentials save \
--platform ios \
--certificate ./cert.p12 \
--p12-password "YourP12Password" \
--ios-provisioning-profile "com.example.app=./profile.mobileprovision" \
--apple-key ./AuthKey_ABC1234567.p8 \
--apple-key-id "ABC1234567" \
--apple-issuer-id "00000000-0000-0000-0000-000000000000" \
--apple-team-id "TEAM123456"
オプション説明必要
--certificate <path>__CAPGO_KEEP_0__ の .p12 証明書ファイルのパスはい (リリース)
--p12-password <password>__CAPGO_KEEP_0__ の .p12 証明書のパスワードはい (リリース)
--ios-provisioning-profile <mapping>__CAPGO_KEEP_0__ のプロビジョニング プロファイルのマッピング (、). 複数のターゲット アプリの場合に繰り返し可能です。 1 つのプロファイルと bundleId のプレフィックスがなければ、__CAPGO_KEEP_0__ はプロファイルから自動で推測します。bundleId=path). Repeatable for multi-target apps. If only one profile and no bundleId prefix, CLI auto-infers from the profile.App Store Connect __CAPGO_KEEP_0__ の .p8 キーのパス
--apple-key <path>Path to App Store Connect API .p8 keyApp Store Connect __CAPGO_KEEP_0__ のキーアイデンティティ
--apple-key-id <id>App Store Connect API Key ID__CAPGO_KEEP_0__
--apple-issuer-id <id>App Store Connect API 発行者 ID (UUID)注釈¹ を参照してください
--apple-team-id <id>App Store Connect チーム IDはい
--ios-distribution <mode>配布モード: app_store (デフォルト) または ad_hocいいえ
--output-uploadCapgo ダウンロードリンクの有効期間を設定しますいいえ (デフォルト: false)
--output-retention <seconds>ビルド出力の有効期間 (例えば 3600s)いいえ (デフォルト: 3600s)
--skip-build-number-bump自動ビルド番号のインクリメントをスキップNo

iOS 認証情報を保存するときに、CLI:

  1. 証明書とプロビジョニング プロファイル ファイルを読み取ります。
  2. base64 エンコードに変換します。
  3. 保存先 ~/.capgo-credentials/credentials.json (または .capgo-credentials.json パスワードと ID を平文 (ローカル ファイルのみ) で保存します。 --local)
  4. — no App Store submission takes place. See

保存されたファイル構造:

{
"ios": {
"BUILD_CERTIFICATE_BASE64": "...",
"CAPGO_IOS_PROVISIONING_MAP": "{\"com.example.app\":{\"profile\":\"...\",\"name\":\"match AppStore com.example.app\"}}",
"APPLE_KEY_CONTENT": "...",
"P12_PASSWORD": "...",
"APPLE_KEY_ID": "ABC1234567",
"APPLE_ISSUER_ID": "...",
"APP_STORE_CONNECT_TEAM_ID": "TEAM123456",
"CAPGO_IOS_DISTRIBUTION": "app_store"
}
}
ターミナルウィンドウ
bunx @capgo/cli@latest build credentials save \
--platform android \
--keystore ./release.keystore \
--keystore-alias "my-key-alias" \
--keystore-key-password "KeyPassword123" \
--keystore-store-password "StorePassword123" \
--play-config ./play-store-service-account.json
オプション説明必須
--keystore <path>.keystore または .jks ファイルへのパスはい (リリース)
--keystore-alias <alias>キーストア内のキーアリセスはい (リリース)
--keystore-key-password <password>キーアリセスのパスワードはい (リリース)
--keystore-store-password <password>__CAPGO_KEEP_0__:のキーストア用パスワードはい (リリース)
--play-config <path>Play Store サービス アカウント JSON のパスはい (提出)

CLI:を保存するときにAndroidの資格情報が保存される

  1. キーストアとサービス アカウント JSON ファイルを読み取ります
  2. base64 エンコードに変換します
  3. 保存先 ~/.capgo-credentials/credentials.json (または .capgo-credentials.json with --local)
  4. __CAPGO_KEEP_0__

The stored file structure:

{
"android": {
"ANDROID_KEYSTORE_FILE": "...",
"PLAY_CONFIG_JSON": "...",
"KEYSTORE_KEY_ALIAS": "my-key-alias",
"KEYSTORE_KEY_PASSWORD": "...",
"KEYSTORE_STORE_PASSWORD": "..."
}
}

Saved Credentialsを保存すると、自動的にビルド時に使用されます:

ターミナル画面
# Credentials automatically loaded from ~/.capgo-credentials/credentials.json
bunx @capgo/cli@latest build request com.example.app --platform ios

Saved Credentialsをオーバーライドするには、環境変数を使用することもできます:

ターミナル画面
# Environment variables take precedence over saved credentials
BUILD_CERTIFICATE_BASE64="..." \
P12_PASSWORD="different-password" \
bunx @capgo/cli@latest build request com.example.app --platform ios

優先順位の順序:

  1. 環境変数(最高優先順位)
  2. 保存されたクレデンシャル(~/.capgo-credentials/credentials.json、またはローカル .capgo-credentials.json)
  3. クレデンシャルなし(最低優先順位)

保存されたクレデンシャルを表示

セクション「保存されたクレデンシャルを表示」

保存されたクレデンシャルの一覧を表示:

ターミナル画面
bunx @capgo/cli@latest build credentials list

例:

📋 Saved Build Credentials:
iOS Credentials:
✓ Certificate (base64)
✓ Provisioning Map (JSON)
✓ Apple Key Content (base64)
✓ P12 Password: ********
✓ Apple Key ID: ABC1234567
✓ Apple Issuer ID: 00000000-0000-0000-0000-000000000000
✓ Team ID: TEAM123456
Android Credentials:
✓ Keystore (base64)
✓ Play Store Config (base64)
✓ Keystore Alias: my-key-alias
✓ Key Password: ********
✓ Store Password: ********
Location: ~/.capgo-credentials/credentials.json
🔒 These credentials are stored locally on your machine only.
When building, they are sent to Capgo but NEVER stored there.
They are auto-deleted after build completion.

セキュリティのベスト プラクティス

セキュリティのベスト プラクティス

ローカル ストレージのセキュリティ

ローカル ストレージのセキュリティ
  1. ファイルのパーミッション

    ターミナル
    # Global credentials directory + file
    chmod 700 ~/.capgo-credentials
    chmod 600 ~/.capgo-credentials/credentials.json
    # Local (per-project) credentials, if you use --local
    chmod 600 .capgo-credentials.json
  2. クレデンシャルをコミットしない

    ターミナル
    # Ignore the per-project credentials file (used with --local)
    echo ".capgo-credentials.json" >> .gitignore

    グローバル ファイルは、ホーム ディレクトリの外側のリポジトリ内にあります。

  3. クレデンシャルを分離する

    • ローカル開発とCI/CDで異なるクレデンシャルを使用する
    • クレデンシャルを定期的にローテートする
    • チームメンバー間でクレデンシャルを共有しない

CI/CDの使用

CI/CDの使用

CI/CD環境の場合 環境変数を 保存されたクレデンシャルよりも

エクスポートする準備ができた.env (推奨)

手作業で各クレデンシャルファイルをbase64エンコードするのではなく 下記) では build credentials manage ファイルを生成してください:

ターミナル画面
bunx @capgo/cli@latest build credentials manage
# pick your app → choose "Export to .env"

ファイル (権限 .env.capgo.<appId>.<platform> ) には、保存されたすべてのクレデンシャルを環境変数として記述します — 各行は CI/CD プロバイダーに追加するシークレットです。両方のプラットフォームはデフォルトで組み込まれています。 1 つにスコープを設定するには 0600注意 --platform ios 注意 --platform android ファイルの生成

環境変数の完全なリファレンス

セクション「環境変数の完全なリファレンス」

The CLI reads the following environment variables for credentials:

iOSの資格情報:

変数説明フォーマット必要
BUILD_CERTIFICATE_BASE64P12/PKCS12証明書 for code の署名Base64Yes (release)
CAPGO_IOS_PROVISIONING_MAPバンドルIDとプロビジョニングプロファイルデータのJSONマップJSON文字列Yes (release)
P12_PASSWORDP12証明書のパスワード平文任意
APPLE_KEY_IDApp Store Connect API キーID文字列(例:「ABC1234567」)注釈¹を参照
APPLE_ISSUER_IDApp Store Connect API 発行者IDUUID文字列注記¹を参照
APPLE_KEY_CONTENTApp Store Connect API キー (.p8 ファイル内容)Base64注記¹を参照
APP_STORE_CONNECT_TEAM_IDApple Developer Team ID文字列 (例:「XXXXXXXXXX」)はい
CAPGO_IOS_DISTRIBUTION配布モード: app_store (標準) または ad_hoc文字列いいえ

Android 認証情報:

変数説明フォーマット必須
ANDROID_KEYSTORE_FILEAPK/AABの署名用キーストアファイルBase64はい (リリース)
KEYSTORE_KEY_ALIASキーストア内キーアリース文字列はい (リリース)
KEYSTORE_KEY_PASSWORDキーアリースのパスワード__CAPGO_KEEP_0__Yes*
KEYSTORE_STORE_PASSWORD鍵ストアファイルのパスワード平文Yes*
PLAY_CONFIG_JSONGoogle PlayサービスアカウントJSONBase64Yes (提出)

*1つのパスワードのみが提供された場合、両方に使用される KEYSTORE_KEY_PASSWORDKEYSTORE_STORE_PASSWORD.

GitHub アクションの例

GitHub アクションの例
github/workflows/build.yml
name: Cloud Build
on:
push:
branches: [main]
jobs:
build-ios:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- uses: oven-sh/setup-bun@v2
- run: bun install
- run: bunx @capgo/cli@latest build request com.example.app --platform ios
env:
CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }}
BUILD_CERTIFICATE_BASE64: ${{ secrets.BUILD_CERTIFICATE_BASE64 }}
CAPGO_IOS_PROVISIONING_MAP: ${{ secrets.CAPGO_IOS_PROVISIONING_MAP }}
P12_PASSWORD: ${{ secrets.P12_PASSWORD }}
APPLE_KEY_ID: ${{ secrets.APPLE_KEY_ID }}
APPLE_ISSUER_ID: ${{ secrets.APPLE_ISSUER_ID }}
APPLE_KEY_CONTENT: ${{ secrets.APPLE_KEY_CONTENT }}
APP_STORE_CONNECT_TEAM_ID: ${{ secrets.APP_STORE_CONNECT_TEAM_ID }}
build-android:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- uses: oven-sh/setup-bun@v2
- run: bun install
- run: bunx @capgo/cli@latest build request com.example.app --platform android
env:
CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }}
ANDROID_KEYSTORE_FILE: ${{ secrets.ANDROID_KEYSTORE_FILE }}
KEYSTORE_KEY_ALIAS: ${{ secrets.KEYSTORE_KEY_ALIAS }}
KEYSTORE_KEY_PASSWORD: ${{ secrets.KEYSTORE_KEY_PASSWORD }}
KEYSTORE_STORE_PASSWORD: ${{ secrets.KEYSTORE_STORE_PASSWORD }}
PLAY_CONFIG_JSON: ${{ secrets.PLAY_CONFIG_JSON }}

CI/CDシークレットとしてbase64に変換するために、資格情報ファイルを次のように変換します:

ターミナル画面
# iOS Certificate (.p12)
base64 -i certificate.p12 | tr -d '\n' > certificate_base64.txt
# iOS Provisioning Profiles — use the CLI to generate CAPGO_IOS_PROVISIONING_MAP:
bunx @capgo/cli@latest build credentials save --platform ios \
--ios-provisioning-profile "com.example.app=./profile.mobileprovision" \
# ... other options
# Then copy CAPGO_IOS_PROVISIONING_MAP from ~/.capgo-credentials/credentials.json to your CI secrets
# iOS App Store Connect Key (.p8)
base64 -i AuthKey_XXXXXX.p8 | tr -d '\n' > apple_key_base64.txt
# Android Keystore (.keystore or .jks)
base64 -i release.keystore | tr -d '\n' > keystore_base64.txt
# Google Play Service Account JSON
base64 -i play-store-service-account.json | tr -d '\n' > play_config_base64.txt

このアプローチは、以下の理由により、より安全です。

  • シークレットは、CI/CD プラットフォームによって管理されます。
  • ランナーの上でシークレットファイルが存在しません。
  • シークレットのローテーションとアクセス制御が容易です。
  • シークレットの使用に関する監査トレイルが作成されます。

定期的にクレデンシャルをローテーションしてください:

  1. iOS: 年に一度新しい証明書と API キーを生成してください。
  2. Android: 年に一度キーストアのパスワードを変更してください。
  3. チームの変更後: チームメンバーが退社したときに回転

保存済みの資格情報を更新:

ターミナル画面
# Re-run save command with new credentials
bunx @capgo/cli@latest build credentials save --platform ios --certificate ./new-cert.p12 ...

”No credentials found”

資格情報が見つかりません

「資格情報が見つかりません」のセクション

  1. ビルドが資格情報が見つからないと表示される場合::

    資格情報が保存されているか確認する
    bunx @capgo/cli@latest build credentials list
  2. クレデンシャルが欠落している場合にクレデンシャルを保存:

    ターミナル画面
    bunx @capgo/cli@latest build credentials save --platform ios ...
  3. クレデンシャルファイルが存在することを確認:

    ターミナル画面
    ls -la ~/.capgo-credentials/credentials.json # global
    ls -la .capgo-credentials.json # local (--local)

ファイルを読み込むときに「許可されていません」というエラー

「ファイルを読み込むときに「許可されていません」というエラー」のセクション

ファイルのパーミッションを修正

ターミナル画面
chmod 600 ~/.capgo-credentials/credentials.json # global
chmod 600 .capgo-credentials.json # local

資格情報が使用されていない

資格情報が使用されていない

正しいプラットフォームが指定されているか確認してください:

ターミナル画面
# Make sure --platform matches saved credentials
bunx @capgo/cli@latest build request com.example.app --platform ios # Uses ios credentials
bunx @capgo/cli@latest build request com.example.app --platform android # Uses android credentials

資格情報をクリアして再保存

資格情報をクリアして再保存

資格情報が不正なようだら

ターミナル画面
# Clear all credentials
bunx @capgo/cli@latest build credentials clear
# Save again
bunx @capgo/cli@latest build credentials save --platform ios ...

環境変数から移行

環境変数から移行

環境変数を使用している場合、保存済みの資格情報に移行できます:

  1. 現在の環境変数を抽出

    ターミナル画面
    echo $BUILD_CERTIFICATE_BASE64 # Verify they exist
  2. base64ファイルを元のファイルに復元 (必要に応じて)

    ターミナル画面
    echo "$BUILD_CERTIFICATE_BASE64" | base64 -d > cert.p12
    echo "$BUILD_PROVISION_PROFILE_BASE64" | base64 -d > profile.mobileprovision
  3. CLIで保存

    ターミナル画面
    bunx @capgo/cli@latest build credentials save \
    --platform ios \
    --certificate ./cert.p12 \
    --ios-provisioning-profile ./profile.mobileprovision \
    --p12-password "$P12_PASSWORD" \
    --apple-key-id "$APPLE_KEY_ID" \
    --apple-issuer-id "$APPLE_ISSUER_ID" \
    --apple-team-id "$APP_STORE_CONNECT_TEAM_ID"

    既存の資格情報が古い形式(単一)で保存されている場合 BUILD_PROVISION_PROFILE_BASE64)、実行する

    ターミナル画面
    bunx @capgo/cli@latest build credentials migrate --platform ios

    このレガシーのシングルプロファイルを変換し CAPGO_IOS_PROVISIONING_MAP 古い BUILD_PROVISION_PROFILE_BASE64APPLE_PROFILE_NAME キーを削除します。

  4. ビルドをテストする

    ターミナル画面
    bunx @capgo/cli@latest build request com.example.app --platform ios
  5. 環境変数を削除する (省略可能)

    ターミナルウィンドウ
    unset BUILD_CERTIFICATE_BASE64 BUILD_PROVISION_PROFILE_BASE64

クレデンシャルは、単一のJSONファイルに保存されています:

  • グローバル (デフォルト): ~/.capgo-credentials/credentials.json すべてのプロジェクトで共有されます
  • ローカル (プロジェクトルートに --local): .capgo-credentials.json プロジェクトごとにグローバルファイルを上書きします

ファイルは、最初にクレデンシャルを保存したときに自動的に作成されます。追加 .capgo-credentials.json あなたの .gitignore プロジェクトごとに認証情報はコミットされません。

ヘルプが必要ですか?

ヘルプが必要ですか?

クレデンシャルを管理するから続けて

クレデンシャルを管理するから続けて

CI/CD オートメーションを計画する場合は CI/CD オートメーションを計画する場合は CI/CD Capgo CI/CD 製品ワークフローにおけるCapgo CI/CDの Capgoネイティブビルド 製品ワークフローにおけるCapgoネイティブビルドの Capgo統合 製品ワークフローにおけるCapgo統合の CI/CD統合 CI/CD統合の実装詳細については GitHubアクション統合 for the implementation detail in GitHub Actions Integration.