メインコンテンツにジャンプ

iOS セットアップ & バックエンド検証

GitHub

iOSネイティブシステム使用

iOSネイティブシステム使用セクション

iOSでは、このプラグインは Apple App Attest から DeviceCheck フレームワーク.

  • iOS 14+
  • 実際の検証フローで物理デバイスが推奨されます
  • App Attest機能を有効にしたXcodeのターゲット
  1. iOSアプリのターゲットを開きます。
  2. Signing & Capabilities Click.
  3. + Capability +機能 と追加 App Attest.

iOS用のカスタムパーミッションは必要ありません。 Info.plist App Attest自体の場合です。

import { AppAttest } from '@capgo/capacitor-app-attest';
const { keyId } = await AppAttest.prepare();
const attestation = await AppAttest.createAttestation({
keyId,
challenge: 'backend-registration-challenge',
});
const assertion = await AppAttest.createAssertion({
keyId,
payload: 'backend-request-payload',
});

送信 attestation.tokenassertion.token アプリ内で検証しないでください。

バックエンドワークフロー(iOS)

セクションのタイトル “Backend workflow (iOS)”
  1. バックエンドは一時 challenge.
  2. アプリが呼び出し createAttestation({ keyId, challenge }).
  3. バックエンドはアプリのAttestの証明書を検証:
    • 証明書チェーンはApple App Attestにアンカーされ、
    • アプリのIDはアプリの( bundleId, チーム)と一致
    • clientDataHash 一致 SHA256(challenge)
  4. ストアデバイスキーの状態 (keyId, 公開鍵、検証者メタデータ).

保護要求 (createAssertion)

保護要求 (createAssertion)
  1. バックエンドは一時的な payload (またはcanonical request hash入力).
  2. アプリが呼び出す createAssertion({ keyId, payload }).
  3. バックエンドは以前のストレージされたキー材料で署名を検証します。
  4. 再生保護とnonce TTL チェックを強制します。
sequenceDiagram
participant App as iOS App
participant Plugin as AppAttest plugin
participant Apple as Apple App Attest
participant BE as Backend
BE->>App: one-time challenge
App->>Plugin: prepare()
Plugin->>Apple: generateKey()
Apple-->>Plugin: keyId
App->>Plugin: createAttestation(keyId, challenge)
Plugin->>Apple: attestKey(keyId, SHA256(challenge))
Apple-->>Plugin: attestation token
Plugin-->>App: token + platform + format + keyId
App->>BE: token + challenge + keyId
BE->>BE: verify Apple attestation rules
BE->>App: one-time payload
App->>Plugin: createAssertion(keyId, payload)
Plugin->>Apple: generateAssertion(keyId, SHA256(payload))
Apple-->>Plugin: assertion token
Plugin-->>App: token + platform + format + keyId
App->>BE: token + payload + keyId
BE->>BE: verify signature + replay policy

バックエンドの最小契約

保護要求 (createAssertion)

登録:

{
"platform": "ios",
"format": "apple-app-attest",
"keyId": "string",
"challenge": "string",
"token": "string"
}

__CAPGO_KEEP_0__: __CAPGO_KEEP_1__

{
"platform": "ios",
"format": "apple-app-attest",
"keyId": "string",
"payload": "string",
"token": "string"
}

iOS セットアップとバックエンド検証から続ける

「iOS セットアップとバックエンド検証から続ける」のセクション

Capacitor を使用している場合 iOS セットアップとバックエンド検証 セキュリティとコンプライアンスの計画に使用し、Capacitor を Capacitor の @capgo/capacitor-app-attest を使用 Capacitor の @capgo/capacitor-app-attest のネイティブ機能 Capacitor の @__CAPGO_KEEP_0__/__CAPGO_KEEP_1__-app-attest の実装詳細 暗号化 Compliance for the implementation detail in Compliance, Capgo for the product workflow in Capgo Security Scanner, and Capgo for the product workflow in Capgo Security.