Migration zu Apple Sign-In zu @capgo/social-login
Einen Einrichtungsprompt mit den Installationsanweisungen und der vollständigen Markdown-Guide für diesen Plugin kopieren.
Übersicht
Abschnitt mit dem Titel “Übersicht”Diese Anleitung beschreibt die Übergang vom alten Plugin zum modernen @capacitor-community/apple-sign-in Paket. Das neue Plugin bietet eine einheitliche Schnittstelle für mehrere soziale Authentifizierungsanbieter mit verbessertem TypeScript-Unterstützung und aktiver Wartung. @capgo/capacitor-social-login Installation
Abschnitt mit dem Titel “Installation”
Entfernen Sie das alte Paket:-
Terminalfenster
Zur Zwischenablage kopieren npm uninstall @capacitor-community/apple-sign-in -
Install das neue Paket:
Terminalfenster npm install @capgo/capacitor-social-loginnpx cap sync
Code Änderungen
Abschnitt mit dem Titel “Code Änderungen”Änderungen importieren
Abschnitt mit dem Titel “Änderungen importieren”import { SignInWithApple } from '@capacitor-community/apple-sign-in';import { SocialLogin } from '@capgo/capacitor-social-login';Initialisierung
Abschnitt mit dem Titel “Initialisierung”Schlüsseländerung: Die neue Plugin erfordert einen Initialisierungsschritt, der vorher nicht benötigt wurde.
// No initialization needed in old package// For iOS: Basic configurationawait SocialLogin.initialize({ apple: {} // Basic iOS configuration});
// For Android: Additional configuration requiredawait SocialLogin.initialize({ apple: { clientId: 'YOUR_SERVICE_ID', // Service ID from Apple Developer Portal redirectUrl: 'https://your-backend.com/callback' // Your backend callback URL }});Wichtiger Hinweis: Für iOS bereitstellen Sie grundlegende Konfigurationen, während Android zusätzliche Details erfordert, einschließlich einer Service-ID und einem Backend-Callback-URL für webbasierte OAuth-Authentifizierung.
Der Anmeldevorgang vereinfacht sich von mehreren Parametern zu einem sauberen API:
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' }});Der neue Plugin verwendet login() mit provider: 'apple' und optionalen Berechtigungen anstatt einzelne Konfigurationswerte wie clientId und redirectURI.
Änderungen des Antworttyps
Abschnitt mit dem Titel „Änderungen der Antworttypen“Die Ergebnisse umfassen nun ein accessToken Objekt mit Abgabedetails und einer strukturierten profile Abschnitt, der die flache Antwortformat des Originalpaketes ersetzt:
// Old response typeinterface AppleSignInResponse { response: { user: string; email: string | null; givenName: string | null; familyName: string | null; identityToken: string | null; authorizationCode: string | null; };}
// New response typeinterface 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; }; };}Neue Funktionen
Abschnitt mit dem Titel „Neue Funktionen“Das aktualisierte Plugin bietet Funktionen, die im Vorgänger nicht verfügbar waren:
Anmeldung überprüfen
// Not available in old packageconst status = await SocialLogin.isLoggedIn({ provider: 'apple'});Abmeldefunktion
// Not available in old packageawait SocialLogin.logout({ provider: 'apple'});Diese Methoden bieten isLoggedIn() um die Authentifizierungsstatus und logout() Funktionalität an.
Plattformspezifische Änderungen
Abschnitt mit dem Titel “Plattformspezifische Änderungen”iOS-Einrichtung
Abschnitt mit dem Titel “iOS-Einrichtung”iOS pflegt bekannte Einrichtungsverfahren durch Xcode-Funktionen:
- Die iOS-Einrichtung bleibt größtenteils gleich. Sie müssen immer noch:
- Die Funktion „Anmeldung mit Apple“ in Xcode aktivieren
- Ihre App in der Apple-Entwickler-Portal konfigurieren
- No additional code Änderungen erforderlich für iOS
Android-Einrichtung
Sektion mit dem Titel “Android-Einrichtung”Android erhält nun native Unterstützung über webbasierte OAuth-Authentifizierung:
Das neue Plugin bietet Android-Unterstützung direkt vor der Verpackung, erfordert jedoch zusätzliche Einrichtungen:
- Erstellen Sie einen Services-ID im Apple-Entwicklerportal
- Konfigurieren Sie einen Web-Authentifizierungs-Endpunkt
- Konfigurieren Sie Ihre Android-App zum Handling des OAuth-Flusses
- Eine Konfiguration des Backend-Dienstes ist erforderlich
Für detaillierte Anweisungen zur Android-Einrichtung, zitieren Sie bitte die Anleitung zur Android-Einrichtung.
Der modernisierte Paket bietet:
- Einheitliche APIs über mehrere soziale Anbieter (Google, Facebook, Apple)
- Verbesserte TypeScript-Typisierung mit besseren Typdefinitionen
- Aktive Wartung durch die Community im Vergleich zur veralteten Version
- Integrierte Android-Unterstützung durch webbasierte Authentifizierung
- Verwaltung des persistierenden Login-Zustands
- Bessere Fehlerbehandlung mit konsistenten Fehlerarten
Änderungen in der Versionsgeschichte
Abschnitt mit dem Titel “Änderungen in der Versionsgeschichte”- Eine explizite Initialisierung ist jetzt erforderlich - keine Standardkonfiguration
- Die Struktur der Antwortobjekte hat sich geändert - Format für die Ergebnisse in der NESTED-Struktur
- Für die Android-Implementierung ist ein Backend-Service erforderlich für OAuth
- Die Token-Refresh-Verwaltung ist anders - Verbesserte Token-Verwaltung
- Fehlerbehandlung und Fehlerarten haben sich geändert - detailliertere Fehler
Für detailliertere Anweisungen zur Einrichtung, wenden Sie sich bitte an die offizielle Dokumentation.
Fortsetzen Sie von der Migration zum Apple-Sign-In bis @capgo/social-login
Abschnitt mit dem Titel “Fortsetzen Sie von der Migration zum Apple-Sign-In bis @capgo/social-login”Wenn Sie Apple-Sign-In-Migration bis @capgo/social-login zur Planung der Authentifizierung und der Kontoflows verwenden, verbinden Sie es mit Mithilfe von @capgo/capacitor-social-login zur nativen Fähigkeit in Mithilfe von @capgo/capacitor-social-login, @capgo/capacitor-social-login für die Implementierungsdetails in @capgo/capacitor-social-login @capgo/capacitor-passkey für die Implementierungsdetails in @capgo/capacitor-passkey @capgo/capacitor-native-biometric für die Implementierungsdetails in @capgo/capacitor-native-biometric und Zweifaktor-Authentifizierung für die Implementierungsdetails in Zweifaktor-Authentifizierung.