Allez directement à la navigation

Importation de l'authentification Apple à @capgo/social-login

GitHub

Cette guide décrit la transition de l'ancien @capacitor-community/apple-sign-in plugin vers le plugin moderne. @capgo/capacitor-social-login Le nouveau plugin fournit une interface unifiée pour plusieurs fournisseurs d'authentification sociale avec un support amélioré de TypeScript et une maintenance active.

  1. Supprimez l'ancien package :

    Fenêtre de terminal
    npm uninstall @capacitor-community/apple-sign-in
  2. Installez le nouveau package :

    Fenêtre de terminal
    npm install @capgo/capacitor-social-login
    npx cap sync
import { SignInWithApple } from '@capacitor-community/apple-sign-in';
import { SocialLogin } from '@capgo/capacitor-social-login';

Modification clé: La nouvelle extension nécessite une étape d'initialisation qui n'était pas nécessaire avant.

// No initialization needed in old package
// For iOS: Basic configuration
await SocialLogin.initialize({
apple: {} // Basic iOS configuration
});
// For Android: Additional configuration required
await SocialLogin.initialize({
apple: {
clientId: 'YOUR_SERVICE_ID', // Service ID from Apple Developer Portal
redirectUrl: 'https://your-backend.com/callback' // Your backend callback URL
}
});

Note importante: Pour iOS, vous fournissez une configuration de base, tandis que l'Android nécessite des détails supplémentaires, notamment un ID de Service et une URL de rappel backend pour l'authentification OAuth basée sur le web.

Le processus de connexion se simplifie de plusieurs paramètres à un API: plus propre

const result = await SignInWithApple.authorize({
clientId: 'com.your.app',
redirectURI: 'https://your-app.com/callback',
scopes: 'email name',
state: '12345',
nonce: 'nonce'
});
const result = await SocialLogin.login({
provider: 'apple',
options: {
// Optional: Add scopes if needed
scopes: ['email', 'name'],
nonce: 'nonce'
}
});

Le nouveau plugin utilise login() avec provider: 'apple' et des champs d'échelle optionnels au lieu de passer des valeurs de configuration individuelles comme clientId et redirectURI.

Les résultats incluent désormais un accessToken objet contenant des informations d'expiration et une section structurée profile remplaçant le format de réponse plus plat de l'ancien package :

// Old response type
interface AppleSignInResponse {
response: {
user: string;
email: string | null;
givenName: string | null;
familyName: string | null;
identityToken: string | null;
authorizationCode: string | null;
};
}
// New response type
interface SocialLoginResponse {
provider: 'apple';
result: {
accessToken: {
token: string;
expiresIn?: number;
refreshToken?: string;
} | null;
idToken: string | null;
profile: {
user: string;
email: string | null;
givenName: string | null;
familyName: string | null;
};
};
}

Le plugin mis à jour introduit une fonctionnalité qui n'était pas disponible dans le prédécesseur :

Vérification de l'état de connexion

// Not available in old package
const status = await SocialLogin.isLoggedIn({
provider: 'apple'
});

Fonctionnalité de déconnexion

// Not available in old package
await SocialLogin.logout({
provider: 'apple'
});

Ces méthodes fournissent isLoggedIn() pour vérifier l'état d'authentification et logout() la fonctionnalité.

iOS permet de maintenir des procédures de configuration familières grâce aux capacités Xcode :

  1. La configuration iOS reste principalement la même. Vous devez toujours :
    • Activer la « Connexion avec Apple » dans Xcode
    • Configurer votre application dans le Portail des développeurs Apple
    • No modifications supplémentaires code sont nécessaires pour iOS

Android maintenant reçoit un support natif via l'authentification OAuth basée sur le web :

Le nouveau plugin fournit un support Android par défaut, mais nécessite une configuration supplémentaire :

  1. Créez un ID de service dans le Portail du développeur Apple
  2. Configurez un point de terminaison d'authentification web
  3. Configurez votre application Android pour gérer le flux OAuth
  4. Une configuration du service backend est requise

Pour des instructions de configuration Android détaillées, veuillez vous référer au Guide de configuration Android.

Le package modernisé fournit :

  1. API unifiées sur plusieurs fournisseurs sociaux (Google, Facebook, Apple)
  2. Mise à jour de la typification TypeScript avec de meilleures définitions de type
  3. Maintenance de la communauté active par rapport à la version dépréciée
  4. Support Android intégré à l'aide d'une authentication basée sur le web
  5. Gestion de l'état de connexion persistant
  6. Meilleure gestion des erreurs Avec des types d'erreurs cohérents
  1. L'initialisation explicite est désormais requise - pas de configuration par défaut
  2. La structure de l'objet réponse a changé - format de résultat imbriqué
  3. La mise en œuvre Android nécessite un service backend pour OAuth
  4. La gestion des jetons est différente - gestion améliorée des jetons
  5. Gestion des erreurs et types d'erreurs ont changé - des erreurs plus détaillées

Pour plus d'informations sur les instructions de configuration détaillées, veuillez vous référer à la documentation officielle.

Continuez de la migration vers l'authentification Apple Sign-In à @capgo/social-login

Section intitulée “Continuez de la migration vers l'authentification Apple Sign-In à @capgo/social-login”

Si vous utilisez la migration vers l'authentification Apple Sign-In à @capgo/social-login pour planifier l'authentification et les flux de compte, connectez-le avec Utilisation de @capgo/capacitor-social-login pour la capacité native dans l'utilisation de @capgo/capacitor-social-login, @capgo/capacitor-social-login pour les détails d'implémentation dans @capgo/capacitor-login-social @capgo/capacitor-passkey pour les détails d'implémentation dans @capgo/capacitor-passkey @capgo/capacitor-biométrique-natif pour les détails d'implémentation dans @capgo/capacitor-biométrique-natif, et L'authentification à deux facteurs pour les détails d'implémentation dans L'authentification à deux facteurs.