Saltar a contenido

Configuración de iOS & Verificación de Backend

__CAPGO_KEEP_0__ nativo del sistema iOS utilizado

Sección titulada “__CAPGO_KEEP_0__ nativo del sistema iOS utilizado”

En iOS, este plugin utiliza Apple App Attest desde el DeviceCheck framework.

  • iOS 14+
  • Se recomienda un dispositivo físico para flujos de validación real
  • Objetivo de Xcode con la capacidad de App Attest habilitada
  1. Abra su objetivo de aplicación iOS en Xcode.
  2. Vaya a Firma y capacidades.
  3. Haga clic + Capacidad y agregue Attest de la aplicación.

No se requieren permisos de iOS personalizados en Info.plist para el Attest de la aplicación en sí.

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',
});

Enviar attestation.token y assertion.token no validéellos en la aplicación.

  1. El backend crea una challenge.
  2. La aplicación llama createAttestation({ keyId, challenge }).
  3. El backend verifica la atestación de la aplicación App Attest:
    • la cadena de certificados es válida y está anclada a Apple App Attest
    • La identidad de la aplicación coincide con su aplicación (bundleId, equipo)
    • clientDataHash Coincide SHA256(challenge)
  4. Almacena el estado de la clave del dispositivo (keyId, clave pública y metadatos de verificador).
  1. El backend crea una solicitud temporal payload (o el hash de solicitud canónico de entrada).
  2. La aplicación llama createAssertion({ keyId, payload }).
  3. El backend verifica la firma de la afirmación con el material de clave almacenado previamente.
  4. Aplica la protección contra retransmisiones y comprobaciones de TTL de nonce.
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

Registro:

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

Assertión:

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

Sigue adelante desde la configuración de iOS y la verificación del backend

Sección titulada “Sigue adelante desde la configuración de iOS y la verificación del backend”

Si estás utilizando Configuración de iOS y Verificación de Backend para planificar la seguridad y la conformidad, conecte con Usando @capgo/capacitor-app-attest para la capacidad nativa en Usando @capgo/capacitor-app-attest, Cifrado para el detalle de implementación en Cifrado, Conformidad para el detalle de implementación en Conformidad, Capgo Escáner de Seguridad para el flujo de trabajo del producto en Capgo Escáner de Seguridad, y Capgo Seguridad para el flujo de trabajo del producto en Capgo Seguridad.