Aller directement au contenu

Démarrage

  1. Installez le package

    Fenêtre de terminal
    bun add @capgo/capacitor-passkey
  2. Synchronisez les projets natifs

    Fenêtre de terminal
    bunx cap sync
  3. Ajoutez la configuration du plugin

    import type { CapacitorConfig } from '@capacitor/cli';
    const config: CapacitorConfig = {
    appId: 'app.capgo.passkey.example',
    appName: 'My App',
    webDir: 'dist',
    plugins: {
    CapacitorPasskey: {
    origin: 'https://signin.example.com',
    autoShim: true,
    domains: ['signin.example.com'],
    },
    },
    };
    export default config;
  4. Installez le shim lors du démarrage

    import { CapacitorPasskey } from '@capgo/capacitor-passkey';
    await CapacitorPasskey.autoShimWebAuthn();
  5. Conservez votre flux WebAuthn normal

    const registration = await navigator.credentials.create({
    publicKey: registrationOptions,
    });
    const authentication = await navigator.credentials.get({
    publicKey: requestOptions,
    });

La configuration est lue de plugins.CapacitorPasskey dans capacitor.config.*.

  • origin: origine HTTPS primaire de partenaire de confiance utilisée par le shim et direct API
  • domains: hôtes de partenaire de confiance supplémentaires à intégrer dans la configuration native pendant la synchronisation
  • autoShim: par défaut true et contrôle l'hook de configuration native automatique cap sync Quels patchs de synchronisation vous sont proposés

Section intitulée « Quels patchs de synchronisation vous sont proposés »

Lorsque vous exécutez

Lorsque vous exécutez bunx cap sync, le plugin met à jour le projet de hôte natif généré :

  • iOS : les autorisations de domaine associées et la mise en relation des autorisations Xcode lorsque nécessaire
  • Android : asset_statements les métadonnées et les ressources générées utilisées par le manifeste

L'hook ne publie pas les fichiers de confiance de votre site pour vous. Vous devez toujours les héberger :

  • https://your-domain/.well-known/apple-app-site-association
  • https://your-domain/.well-known/assetlinks.json