Lompat ke konten

Penyedia Oauth2 umum

Plugin Login Sosial Capgo termasuk mesin OAuth2 dan OpenID Connect bawaan. Anda dapat menggunakan itu untuk terhubung dengan penyedia identitas berbasis standar, termasuk:

  • GitHub
  • Azure AD / Microsoft Entra ID
  • Auth0
  • Okta
  • Keycloak
  • Server OAuth2 atau OIDC kustom

Konfigurasi ini dirancang untuk multi-provider. Anda dapat mendaftarkan beberapa penyedia sekaligus dan kemudian memilih salah satu pada saat login dengan oauth2 Apa yang Anda butuhkan providerId.

Bagian berjudul “Apa yang Anda butuhkan”

Sebelum Anda mengonfigurasi penyedia, kumpulkan:

ID klien OAuth Anda

  • URL redirect yang sesuai dengan skema aplikasi atau URL panggilan balik web Anda
  • URL yang Anda gunakan untuk mengarahkan pengguna ke penyedia OAuth Anda
  • Endpoint otorisasi
  • Endpoint token untuk aliran otorisasi code atau issuerUrl untuk penemuan OIDC
  • Skop yang dibutuhkan aplikasi Anda, seperti openid profile email

Gunakan SocialLogin.initialize() sekali selama aplikasi startup dan daftarkan setiap penyedia yang dibutuhkan:

import { SocialLogin } from '@capgo/capacitor-social-login';
await SocialLogin.initialize({
oauth2: {
github: {
appId: 'your-github-client-id',
authorizationBaseUrl: 'https://github.com/login/oauth/authorize',
accessTokenEndpoint: 'https://github.com/login/oauth/access_token',
redirectUrl: 'myapp://oauth/github',
scope: 'read:user user:email',
pkceEnabled: true,
resourceUrl: 'https://api.github.com/user',
},
azure: {
appId: 'your-azure-client-id',
authorizationBaseUrl: 'https://login.microsoftonline.com/common/oauth2/v2.0/authorize',
accessTokenEndpoint: 'https://login.microsoftonline.com/common/oauth2/v2.0/token',
redirectUrl: 'myapp://oauth/azure',
scope: 'openid profile email User.Read',
pkceEnabled: true,
resourceUrl: 'https://graph.microsoft.com/v1.0/me',
},
auth0: {
issuerUrl: 'https://your-tenant.auth0.com',
appId: 'your-auth0-client-id',
redirectUrl: 'myapp://oauth/auth0',
scope: 'openid profile email offline_access',
pkceEnabled: true,
additionalParameters: {
audience: 'https://your-api.example.com',
},
},
},
});

Jika penyedia Anda menampilkan dokumen penemuan OpenID Connect, issuerUrl adalah konfigurasi paling sederhana:

await SocialLogin.initialize({
oauth2: {
keycloak: {
issuerUrl: 'https://sso.example.com/realms/mobile',
clientId: 'mobile-app',
redirectUrl: 'myapp://oauth/keycloak',
scope: 'openid profile email offline_access',
pkceEnabled: true,
},
},
});

Plugin ini juga mendukung alias OAuth dan OIDC yang umum:

  • clientId sebagai alias dari appId
  • authorizationEndpoint sebagai alias dari authorizationBaseUrl
  • tokenEndpoint sebagai alias dari accessTokenEndpoint
  • endSessionEndpoint sebagai alias dari logoutUrl
  • scopes sebagai alias dari scope

Juga tersedia:

  • additionalParameters untuk pengaturan pengganti permintaan autentikasi
  • additionalTokenParameters untuk pengaturan pengganti tukar token
  • additionalResourceHeaders untuk header endpoint sumber daya yang disesuaikan
  • additionalLogoutParameters dan postLogoutRedirectUrl untuk aliran keluar
  • loginHint, prompt, dan iosPrefersEphemeralSession

Preset yang kompatibel dengan Auth Connect

Judul Bagian “Preset yang kompatibel dengan Auth Connect”

Jika Anda sedang melakukan migrasi dari Ionic Auth Connect dan ingin menjaga nama-nama penyedia yang sama, gunakan SocialLoginAuthConnect.

import { SocialLoginAuthConnect } from '@capgo/capacitor-social-login';
await SocialLoginAuthConnect.initialize({
authConnect: {
auth0: {
domain: 'https://your-tenant.auth0.com',
clientId: 'your-auth0-client-id',
redirectUrl: 'myapp://oauth/auth0',
audience: 'https://your-api.example.com',
},
azure: {
tenantId: 'common',
clientId: 'your-azure-client-id',
redirectUrl: 'myapp://oauth/azure',
},
okta: {
issuer: 'https://dev-12345.okta.com/oauth2/default',
clientId: 'your-okta-client-id',
redirectUrl: 'myapp://oauth/okta',
},
},
});

ID penyedia preset yang didukung:

  • auth0
  • azure
  • cognito
  • okta
  • onelogin

Jika penyedia yang dibutuhkan memiliki endpoint yang khusus, baik override-nya di preset atau lewati preset dan atur penyedia secara langsung di oauth2.

PilihanJenisDiperlukanDeskripsi
appId / clientIdstringYaIdentifikasi klien OAuth2
issuerUrlstringTidakURL dasar penemuan OIDC
authorizationBaseUrl / authorizationEndpointstringYa*URL endpoint otorisasi
accessTokenEndpoint / tokenEndpointBahasa IndonesiaTidakURL Endpoint Token
redirectUrlBahasa IndonesiaYaURL Panggilan Balik
scope / scopesstring / string[]TidakIstilah yang Dibutuhkan
pkceEnabledbooleanTidak__CAPGO_KEEP_0__ true
responseType'code' atau 'token'TidakDefault ke 'code'
resourceUrlstringTidakURL informasi pengguna atau endpoint sumber daya
logoutUrl / endSessionEndpointstringTidakURL keluar atau akhir sesi
postLogoutRedirectUrlstringTidakURL alih arah setelah keluar
additionalParametersRecord<string, string>TidakParameter tambahan autentikasi
additionalTokenParametersRecord<string, string>TidakParameter tambahan token
additionalResourceHeadersRecord<string, string>Tidak__CAPGO_KEEP_0__ untuk resourceUrl
additionalLogoutParametersRecord<string, string>TidakParameter tambahan keluar
loginHint__CAPGO_KEEP_0__Tidak__CAPGO_KEEP_0__ untuk additionalParameters.login_hint
prompt__CAPGO_KEEP_0__TidakPintasan untuk additionalParameters.prompt
iosPrefersEphemeralSessionbooleanTidakMenggunakan browser sementara pada iOS
logsEnabledbooleanTidakMengaktifkan pencatatan debug verbose

authorizationBaseUrl dan accessTokenEndpoint hanya optional ketika issuerUrl adalah cukup untuk penemuan. Endpoint eksplisit selalu menang atas nilai yang ditemukan.

Menggunakan login OAuth2

Menggunakan Login OAuth2
const result = await SocialLogin.login({
provider: 'oauth2',
options: {
providerId: 'github',
scope: 'read:user user:email',
loginHint: 'user@example.com',
},
});

Aliran Redirect di Web

Bagian: Aliran Redirect di Web

Gunakan flow: 'redirect' Jika Anda ingin aliran redirect penuh halaman daripada popup:

await SocialLogin.login({
provider: 'oauth2',
options: {
providerId: 'auth0',
flow: 'redirect',
},
});

Pada halaman yang menerima panggilan balik, analisis hasil login:

const result = await SocialLogin.handleRedirectCallback();
if (result?.provider === 'oauth2') {
console.log(result.result.providerId);
}

Status Login dan Logout

Status login dan keluar
const status = await SocialLogin.isLoggedIn({
provider: 'oauth2',
providerId: 'github',
});
await SocialLogin.logout({
provider: 'oauth2',
providerId: 'github',
});
await SocialLogin.refresh({
provider: 'oauth2',
options: {
providerId: 'github',
},
});
const refreshed = await SocialLogin.refreshToken({
provider: 'oauth2',
providerId: 'github',
refreshToken: 'existing-refresh-token',
});

refresh() Contoh spesifik penyedia refreshToken() Salin ke clipboard

const code = await SocialLogin.getAuthorizationCode({
provider: 'oauth2',
providerId: 'github',
});
console.log(code.accessToken);

Salin ke clipboard

Contoh spesifik penyedia

Gunakan GitHub ketika Anda ingin aliran aplikasi OAuth sederhana dan data profil dasar:

await SocialLogin.initialize({
oauth2: {
github: {
appId: 'your-github-client-id',
authorizationBaseUrl: 'https://github.com/login/oauth/authorize',
accessTokenEndpoint: 'https://github.com/login/oauth/access_token',
redirectUrl: 'myapp://oauth/github',
scope: 'read:user user:email',
pkceEnabled: true,
resourceUrl: 'https://api.github.com/user',
},
},
});
const githubResult = await SocialLogin.login({
provider: 'oauth2',
options: {
providerId: 'github',
},
});
console.log(githubResult.result.accessToken?.token);
console.log(githubResult.result.resourceData);

Gunakan Azure ketika Anda membutuhkan data Microsoft Graph seperti profil pengguna:

await SocialLogin.initialize({
oauth2: {
azure: {
appId: 'your-azure-client-id',
authorizationBaseUrl: 'https://login.microsoftonline.com/common/oauth2/v2.0/authorize',
accessTokenEndpoint: 'https://login.microsoftonline.com/common/oauth2/v2.0/token',
redirectUrl: 'myapp://oauth/azure',
scope: 'openid profile email User.Read',
pkceEnabled: true,
resourceUrl: 'https://graph.microsoft.com/v1.0/me',
},
},
});
const azureResult = await SocialLogin.login({
provider: 'oauth2',
options: {
providerId: 'azure',
},
});
console.log(azureResult.result.idToken);
console.log(azureResult.result.resourceData);

Auth0 cocok digunakan ketika Anda membutuhkan OIDC plus audiens API yang disesuaikan:

await SocialLogin.initialize({
oauth2: {
auth0: {
appId: 'your-auth0-client-id',
authorizationBaseUrl: 'https://your-tenant.auth0.com/authorize',
accessTokenEndpoint: 'https://your-tenant.auth0.com/oauth/token',
redirectUrl: 'myapp://oauth/auth0',
scope: 'openid profile email offline_access',
pkceEnabled: true,
additionalParameters: {
audience: 'https://your-api.example.com',
},
},
},
});
const auth0Result = await SocialLogin.login({
provider: 'oauth2',
options: {
providerId: 'auth0',
flow: 'redirect',
},
});

Jika Anda menggunakan alur redirect di web, baca hasilnya kembali pada halaman panggilan balik:

const auth0Result = await SocialLogin.handleRedirectCallback();
if (auth0Result?.provider === 'oauth2') {
console.log(auth0Result.result.idToken);
}
await SocialLogin.initialize({
oauth2: {
okta: {
appId: 'your-okta-client-id',
authorizationBaseUrl: 'https://your-domain.okta.com/oauth2/default/v1/authorize',
accessTokenEndpoint: 'https://your-domain.okta.com/oauth2/default/v1/token',
redirectUrl: 'myapp://oauth/okta',
scope: 'openid profile email offline_access',
pkceEnabled: true,
resourceUrl: 'https://your-domain.okta.com/oauth2/default/v1/userinfo',
},
},
});
const oktaResult = await SocialLogin.login({
provider: 'oauth2',
options: {
providerId: 'okta',
},
});
console.log(oktaResult.result.resourceData);

Salin ke papan klip /.well-known/openid-configuration:

await SocialLogin.initialize({
oauth2: {
keycloak: {
issuerUrl: 'https://sso.example.com/realms/mobile',
clientId: 'mobile-app',
redirectUrl: 'myapp://oauth/keycloak',
scope: 'openid profile email offline_access',
pkceEnabled: true,
},
},
});
const keycloakResult = await SocialLogin.login({
provider: 'oauth2',
options: {
providerId: 'keycloak',
},
});
console.log(keycloakResult.result.idToken);

Bagian berjudul “Bentuk respons OAuth2”

Login OAuth2 sukses kembali:

Baca hasilnya kembali pada halaman panggilan balik:

BidangDeskripsi
providerIdKunci penyedia yang telah dikonfigurasi untuk login
accessTokenIsi token akses atau null
idTokenToken ID OIDC jika penyedia mengembalikannya
refreshTokenToken refresh jika ruang lingkup yang diminta memungkinkannya
resourceDataJSON mentah yang diambil dari resourceUrl
scopeRuangan yang diberikan
tokenTypeBiasanya bearer
expiresInMasa hidup token dalam detik
  1. Buat aplikasi OAuth Buka GitHub Pengaturan Pengembang dan buat aplikasi OAuth baru.

  2. Atur URL panggil balik Gunakan URL redirect aplikasi Anda, misalnya myapp://oauth/github.

  3. Konfigurasi plugin

    await SocialLogin.initialize({
    oauth2: {
    github: {
    appId: 'your-github-client-id',
    authorizationBaseUrl: 'https://github.com/login/oauth/authorize',
    accessTokenEndpoint: 'https://github.com/login/oauth/access_token',
    redirectUrl: 'myapp://oauth/github',
    scope: 'read:user user:email',
    pkceEnabled: true,
    resourceUrl: 'https://api.github.com/user',
    },
    },
    });
  1. Daftarkan aplikasi Buka Azure Portal, buka App registrations, dan daftarkan aplikasi native atau aplikasi seluler.

  2. Tambahkan URI redirect Tambahkan URI redirect seluler atau desktop yang sesuai dengan URL panggilan balik aplikasi Anda.

  3. Konfigurasi plugin

    await SocialLogin.initialize({
    oauth2: {
    azure: {
    appId: 'your-azure-client-id',
    authorizationBaseUrl: 'https://login.microsoftonline.com/common/oauth2/v2.0/authorize',
    accessTokenEndpoint: 'https://login.microsoftonline.com/common/oauth2/v2.0/token',
    redirectUrl: 'myapp://oauth/azure',
    scope: 'openid profile email User.Read',
    pkceEnabled: true,
    resourceUrl: 'https://graph.microsoft.com/v1.0/me',
    },
    },
    });
  1. Buat aplikasi native Buka Auth0 Dashboard dan buat aplikasi Native.

  2. Tentukan URL panggilan balik yang diizinkan Tambahkan URL redirect yang tepat digunakan oleh aplikasi Capacitor Anda.

  3. Konfigurasi plugin

    await SocialLogin.initialize({
    oauth2: {
    auth0: {
    appId: 'your-auth0-client-id',
    authorizationBaseUrl: 'https://your-tenant.auth0.com/authorize',
    accessTokenEndpoint: 'https://your-tenant.auth0.com/oauth/token',
    redirectUrl: 'myapp://oauth/auth0',
    scope: 'openid profile email offline_access',
    pkceEnabled: true,
    additionalParameters: {
    audience: 'https://your-api.example.com',
    },
    logoutUrl: 'https://your-tenant.auth0.com/v2/logout',
    },
    },
    });
  1. Buat aplikasi OIDC native Dalam Okta Admin Console, buatlah Aplikasi OIDC Native.

  2. Tambahkan URI pengalihan Anda Daftarkan URL panggil balik yang tepat yang digunakan oleh aplikasi Anda.

  3. Konfigurasi plugin

    await SocialLogin.initialize({
    oauth2: {
    okta: {
    appId: 'your-okta-client-id',
    authorizationBaseUrl: 'https://your-domain.okta.com/oauth2/default/v1/authorize',
    accessTokenEndpoint: 'https://your-domain.okta.com/oauth2/default/v1/token',
    redirectUrl: 'myapp://oauth/okta',
    scope: 'openid profile email offline_access',
    pkceEnabled: true,
    resourceUrl: 'https://your-domain.okta.com/oauth2/default/v1/userinfo',
    },
    },
    });

Salin ke clipboard issuerUrl:

await SocialLogin.initialize({
oauth2: {
keycloak: {
issuerUrl: 'https://sso.example.com/realms/mobile',
clientId: 'mobile-app',
redirectUrl: 'myapp://oauth/keycloak',
scope: 'openid profile email offline_access',
pkceEnabled: true,
},
},
});

Catatan spesifik platform

Jika penyedia Anda mendukung penemuan OpenID Connect, prefer

Salin ke clipboard
  • Plugin ini menggunakan ASWebAuthenticationSession.
  • Tetapkan iosPrefersEphemeralSession: true Jika Anda ingin sesi browser pribadi tanpa cookie yang dibagikan.
  • Pengalihan OAuth kembali melalui skema aplikasi dan host Anda.
  • Pastikan URL panggilan balik penyedia persis cocok dengan pengaturan tautan dalam aplikasi Android Anda.
  • Plugin ini sudah menghandle aktivitas OAuth. Tambahkan hanya filter intent yang diinginkan jika aplikasi Anda memerlukan pola pengalihan yang berbeda.
  • Aliran popup adalah default dan berfungsi baik untuk aplikasi satu halaman.
  • Aliran redirect lebih baik ketika penyedia memblokir popup atau aturan autentikasi Anda memerlukan navigasi tingkat atas.
  • Beberapa penyedia memblokir pertukaran token browser langsung dengan CORS. Dalam kasus tersebut, gunakan pertukaran backend atau pengaturan penyedia yang memungkinkan klien publik.
  1. Gunakan PKCE Tetapkan pkceEnabled: true untuk klien publik.

  2. Prefer aliran autentikasi code responseType: 'code' lebih aman daripada aliran implisit.

  3. Validasi token di backend Anda Dekode dan verifikasi issuer, audience, expiration, dan tanda tangan di server.

  4. Simpan token refresh secara aman Untuk aplikasi native, pair plugin ini dengan @capgo/capacitor-akun-tetap.

  5. Gunakan HTTPS di mana-mana Endpoint autentikasi produksi dan endpoint logout harus selalu menggunakan HTTPS.

Setiap metode OAuth2 memerlukan kunci penyedia yang dikonfigurasi:

await SocialLogin.login({
provider: 'oauth2',
options: { providerId: 'github' },
});

Panggil SocialLogin.initialize() sebelum login dan pastikan itu providerId sesuai dengan kunci objek di bawah oauth2.

  • Bandingkan URL redirect yang diatur di aplikasi dan dashboard dashboard penyedia karakter per karakter.
  • Perhatikan apakah ada slash akhir, kesalahan skema, dan host yang berbeda.
  • Pastikan URL skema aplikasi mobile terdaftar sebelum melakukan pengujian di perangkat.

Hampir semua penyedia hanya mengembalikan token refresh ketika Anda meminta skop seperti offline_access atau secara eksplisit memaksa persetujuan. Tinjau kebijakan penyedia khusus.

Aktifkan logsEnabled: true Aktifkan pada konfigurasi penyedia untuk memeriksa URL dan detail pertukaran token yang dihasilkan.