Configuration & vérification backend de iOS
Copier un prompt de configuration avec les étapes d'installation et le guide markdown complet pour ce plugin.
Système natif iOS utilisé
Section intitulée « Système natif iOS utilisé »Sur iOS, ce plugin utilise Apple App Attest à partir du DeviceCheck framework.
Exigences
Section intitulée « Exigences »- iOS 14+
- Un appareil physique est recommandé pour les flux de validation réels
- Cible Xcode avec la capacité App Attest activée
Configuration Xcode
Section intitulée « Configuration Xcode »- Ouvrez votre cible d'application iOS dans Xcode.
- Allez à Signature et capacités.
- Cliquez et ajoutez App Attest Aucune permission iOS personnalisée n'est requise pour App Attest elle-même..
__CAPGO_KEEP_0__ Info.plist __CAPGO_KEEP_0__
Flux client
Section intitulée « Flux client »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',});Envoyer attestation.token et assertion.token à votre backend. N'effectuez pas de validation dans l'application.
Flux de travail backend (iOS)
Section intitulée « Flux de travail backend (iOS) »Inscription (createAttestation)
Section intitulée « Inscription (createAttestation) »- Le backend crée un code d'accès unique
challenge. - L'application appelle
createAttestation({ keyId, challenge }). - La plateforme backend vérifie l'attestation App Attest :
- la chaîne de certificats est valide et ancrée à Apple App Attest
- l'identité de l'application correspond à votre application (
bundleId, équipe) clientDataHashcorrespondSHA256(challenge)
- Sauvegarde l'état de la clé de magasin (
keyId, clé publique et métadonnées de vérificateur).
Demande de protection (createAssertion)
Sous-section intitulée “Demande de protection (createAssertion)”- La plateforme backend crée une demande unique
payload(ou hash de requête canonique en entrée). - L'application appele
createAssertion({ keyId, payload }). - Le backend vérifie l'empreinte de signature de l'assertion avec le matériel de clé stocké précédemment.
- Exigez la protection contre la reprise et les vérifications de TTL de nonce.
Schéma iOS
Section intitulée “Schéma 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 policyContrat de charge de données backend minimal
Section intitulée “Contrat de charge de données backend minimal”Inscription :
{ "platform": "ios", "format": "apple-app-attest", "keyId": "string", "challenge": "string", "token": "string"}Assertion :
{ "platform": "ios", "format": "apple-app-attest", "keyId": "string", "payload": "string", "token": "string"}Continuez de la configuration iOS et de la vérification du backend
Section intitulée « Continuez de la configuration iOS & de la vérification du backend »Si vous utilisez la configuration iOS & de la vérification du backend pour planifier la sécurité et la conformité, connectez-le avec En utilisant @capgo/capacitor-app-attest pour la capacité native dans En utilisant @capgo/capacitor-app-attest, Chiffrement pour le détail d'implémentation dans Chiffrement, Conformité pour le détail d'implémentation dans Conformité, Capgo Scanner de sécurité pour le flux de travail du produit dans Capgo Scanner de sécurité, et Capgo Sécurité pour le flux de travail du produit dans Capgo Sécurité.