跳过内容

Google Auth 迁移至 @capgo/social-login

本指南提供了从 @codetrix-studio/capacitor-google-auth@capgo/capacitor-social-login,以确保smooth的过渡和改进的身份验证体验的全面步骤。新插件将多个社交身份验证提供商统一到一个单一、一致的API。

安装

安装
  1. 移除旧包:

    终端窗口
    npm uninstall @codetrix-studio/capacitor-google-auth
  2. 安装新包:

    终端窗口
    npm install @capgo/capacitor-social-login
    npx cap sync

Google Auth 配置的重要变化

重要变化在 Google Auth 配置

Web 客户端 ID 的要求

Web 客户端 ID 的要求

关键更新: 必须在所有平台上使用更新的插件的 Web 客户端 ID。

您需要:

  1. 如果您没有,请在 Google Cloud 控制台中创建 Web 客户端 ID (获取凭据的方法)
  2. 在所有平台的 webClientId 字段中使用此 Web 客户端 ID
  3. 对于 Android,仍然需要使用 SHA1 创建 Android 客户端 ID,但这仅用于验证目的 - 令牌将不会被使用 (Android 配置指南)
import { GoogleAuth } from '@codetrix-studio/capacitor-google-auth';
import { SocialLogin } from '@capgo/capacitor-social-login';

从简单的调用变成了更结构化的 GoogleAuth.initialize() 嵌套的Google配置: SocialLogin.initialize() 复制到剪贴板

GoogleAuth.initialize({
clientId: 'CLIENT_ID.apps.googleusercontent.com',
scopes: ['profile', 'email'],
grantOfflineAccess: true,
});
await SocialLogin.initialize({
google: {
webClientId: 'WEB_CLIENT_ID.apps.googleusercontent.com', // Use Web Client ID for all platforms
iOSClientId: 'IOS_CLIENT_ID', // for iOS
mode: 'offline' // replaces grantOfflineAccess
}
});

Section titled “Sign In”

GoogleAuth.signIn() The setup transforms from a simple call to a more structured with nested Google configuration: SocialLogin.login() 使用明确的提供者指定:

const user = await GoogleAuth.signIn();
const res = await SocialLogin.login({
provider: 'google',
options: {
scopes: ['email', 'profile'],
forceRefreshToken: true // if you need refresh token
}
});

平台特定更改

标题:平台特定更改
  1. 更新您的 MainActivity.java (全Android设置指南):
import ee.forgr.capacitor.social.login.GoogleProvider;
import ee.forgr.capacitor.social.login.SocialLoginPlugin;
import ee.forgr.capacitor.social.login.ModifiedMainActivityForSocialLoginPlugin;
import com.getcapacitor.PluginHandle;
import com.getcapacitor.Plugin;
import android.content.Intent;
import android.util.Log;
public class MainActivity extends BridgeActivity {
public class MainActivity extends BridgeActivity implements ModifiedMainActivityForSocialLoginPlugin {
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode >= GoogleProvider.REQUEST_AUTHORIZE_GOOGLE_MIN && requestCode < GoogleProvider.REQUEST_AUTHORIZE_GOOGLE_MAX) {
PluginHandle pluginHandle = getBridge().getPlugin("SocialLogin");
if (pluginHandle == null) {
Log.i("Google Activity Result", "SocialLogin login handle is null");
return;
}
Plugin plugin = pluginHandle.getInstance();
if (!(plugin instanceof SocialLoginPlugin)) {
Log.i("Google Activity Result", "SocialLogin plugin instance is not SocialLoginPlugin");
return;
}
((SocialLoginPlugin) plugin).handleGoogleLoginIntent(requestCode, data);
}
}
public void IHaveModifiedTheMainActivityForTheUseWithSocialLoginPlugin() {}
}
  1. AppDelegate.swift中没有需要的重大更改(iOS设置指南)

  2. 更新您的配置在 capacitor.config.json,我们不再使用它在新插件:

{
"plugins": {
"GoogleAuth": {
"scopes": ["profile", "email"],
"serverClientId": "xxxxxx-xxxxxxxxxxxxxxxxxx.apps.googleusercontent.com",
"forceCodeForRefreshToken": true
}
}
  1. 从您的 index.html 如果您曾经使用它们:
<meta name="google-signin-client_id" content="{your client id here}" />
<meta name="google-signin-scope" content="profile email" />

认证响应现在提供一个结构化的对象,包含提供商信息、访问令牌、ID令牌和用户资料:

interface GoogleLoginResponse {
provider: 'google';
result: {
accessToken: {
token: string;
expires: string;
// ... other token fields
} | null;
idToken: string | null;
profile: {
email: string | null;
familyName: string | null;
givenName: string | null;
id: string | null;
name: string | null;
imageUrl: string | null;
};
};
}

响应结构包括:

  • provider: 确定身份验证提供者('google')
  • result.accessToken: 包含过期时间的访问令牌详细信息
  • result.idToken: 身份验证令牌
  • result.profile: 包含电子邮件、姓名和图片 URL 的用户资料

新包支持多个社交身份验证提供商,超出Google:

这种统一的方法提供:

  • 所有提供商中的API一致
  • 改进的TypeScript支持
  • 更好的错误处理
  • 积极的维护和社区支持

查看 主文档 获取这些额外提供商的详细设置指南。

从Google Auth迁移继续到@capgo/social-login

从 Google Auth Migration 到 @capgo/social-login 的持续迁移

如果您正在使用 Google Auth Migration 到 @capgo/social-login 规划身份验证和帐户流程,连接它 使用 @capgo/capacitor-social-login 使用 @capgo/capacitor-social-login 的原生能力 @capgo/capacitor-social-login @capgo/capacitor-social-login 的实现细节 @capgo/capacitor-passkey @capgo/capacitor-passkey 的实现细节 @capgo/capacitor-native-biometric @capgo/capacitor-native-biometric 的实现细节 双重验证 双重验证的实现细节。