__CAPGO_KEEP_0__ - __CAPGO_KEEP_1__ アプリのリアルタイム更新

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

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

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

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

要件

要件
  • iOS 14+
  • 実際の検証フローで物理デバイスが推奨されます
  • App Attest機能が有効になっているXcodeターゲット

Xcodeの設定

Xcode設定
  1. XcodeでiOSアプリのターゲットを開きます。
  2. Go to Signing & Capabilities.
  3. Click + Capability と追加 App Attest.

App Attest自体には Info.plist Client flow

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.token そして assertion.token あなたのバックエンドに送信します。アプリ内で検証しないでください。

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

バックエンドワークフロー (iOS) セクション
  1. バックエンドは一時 challenge.
  2. アプリが呼び出し createAttestation({ keyId, challenge }).
  3. バックエンドはアプリの証明書の検証
    • 証明書チェーンは有効であり、Apple App Attestにアンカーされています。
    • アプリのIDはあなたのアプリと一致します (bundleId, チーム)
    • clientDataHash マッチ SHA256(challenge)
  4. デバイスキー状態を保存 (keyId, 公開鍵、および検証者メタデータ)
  1. バックエンドは、 payload (またはcanonical request hash入力).
  2. アプリが createAssertion({ keyId, payload }).
  3. バックエンドは、以前保存されたキー材料でアサーション署名を検証します。
  4. 再生保護とnonce TTL チェックを強制します。

iOS スキーマ

iOS スキーマ
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

最小バックエンドペイロード契約

最小バックエンドペイロード契約

登録:

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

アサーション:

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

iOS セットアップ & バックエンド検証から続けて あなたが使用している場合 セキュリティとコンプライアンスの計画に役立つため、接続する @capgo/capacitor-app-attestを使用する @capgo/capacitor-app-attestのネイティブ機能の使用 暗号化 暗号化の実装詳細 コンプライアンス コンプライアンスの実装詳細 Capgo セキュリティ スキャナー Capgo セキュリティ スキャナーの製品ワークフロー Capgo セキュリティ Capgo セキュリティの製品ワークフロー