Getting Started
Copy sebuah prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-native-biometric`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/native-biometric/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
bun add @capgo/capacitor-native-biometricbunx cap syncimport { NativeBiometric } from '@capgo/capacitor-native-biometric';API Ringkasan
Bagian berjudul āAPI RingkasanāisAvailable
Bagian berjudul āisAvailableāMengecek apakah perangkat autentikasi biometrik tersedia.
import { NativeBiometric } from '@capgo/capacitor-native-biometric';
await NativeBiometric.isAvailable();verifyIdentity
Bagian berjudul āverifyIdentityāMengajak pengguna untuk melakukan autentikasi dengan biometrik.
import { NativeBiometric } from '@capgo/capacitor-native-biometric';
await NativeBiometric.verifyIdentity();getCredentials
Bagian berjudul āgetCredentialsāMengambil kredit yang disimpan untuk server tertentu.
import { NativeBiometric } from '@capgo/capacitor-native-biometric';
await NativeBiometric.getCredentials({} as GetCredentialOptions);setCredentials
Bagian berjudul āsetCredentialsāMenyimpan kredit yang diberikan untuk server tertentu.
import { NativeBiometric } from '@capgo/capacitor-native-biometric';
await NativeBiometric.setCredentials({} as SetCredentialOptions);deleteCredentials
Bagian berjudul ādeleteCredentialsāMenghapus kredit yang disimpan untuk server tertentu.
import { NativeBiometric } from '@capgo/capacitor-native-biometric';
await NativeBiometric.deleteCredentials({} as DeleteCredentialOptions);getSecureCredentials
Bagian berjudul āgetSecureCredentialsāMengambil kreditensi yang disimpan untuk server tertentu, memerlukan verifikasi biometrik. Kreditensi harus telah disimpan dengan accessControl diatur ke BIOMETRY_CURRENT_SET atau BIOMETRY_ANY.
Pada iOS, sistem secara otomatis menampilkan prompt biometrik ketika mengakses item Keychain yang dilindungi. Pada Android, BiometricPrompt ditampilkan dengan CryptoObject terikat pada kunci dekripsi kreditensi.
import { NativeBiometric } from '@capgo/capacitor-native-biometric';
await NativeBiometric.getSecureCredentials({} as GetSecureCredentialsOptions);isCredentialsSaved
Bab berjudul āisCredentialsSavedāMemeriksa apakah kreditensi sudah disimpan untuk server tertentu.
import { NativeBiometric } from '@capgo/capacitor-native-biometric';
await NativeBiometric.isCredentialsSaved({} as IsCredentialsSavedOptions);Referensi Tipe
Bab berjudul āReferensi TipeāIsAvailableOptions
Bab berjudul āIsAvailableOptionsāexport interface IsAvailableOptions { /** * Only for iOS. * Specifies if should fallback to passcode authentication if biometric authentication is not available. * On Android, this parameter is ignored due to BiometricPrompt API constraints: * DEVICE_CREDENTIAL authenticator and negative button (cancel) are mutually exclusive. */ useFallback: boolean;}AvailableResult
Bab berjudul āAvailableResultāHasil dari metode isAvailable() menunjukkan ketersediaan verifikasi biometrik.
export interface AvailableResult { /** * Whether authentication is available (biometric or fallback if useFallback is true) */ isAvailable: boolean; /** * The strength of available authentication method (STRONG, WEAK, or NONE) */ authenticationStrength: AuthenticationStrength; /** * The primary biometry type available on the device. * On Android devices with multiple biometry types, this returns MULTIPLE. * Use this for display purposes only - always use isAvailable for logic decisions. */ biometryType: BiometryType; /** * Whether the device has a secure lock screen (PIN, pattern, or password). * This is independent of biometric enrollment. */ deviceIsSecure: boolean; /** * Whether strong biometry (Face ID, Touch ID, or fingerprint on devices that consider it strong) * is specifically available, separate from weak biometry or device credentials. */ strongBiometryIsAvailable: boolean; /** * Error code from BiometricAuthError enum. Only present when isAvailable is false. * Indicates why biometric authentication is not available. * @see BiometricAuthError */ errorCode?: BiometricAuthError;}BiometryChangeListener
Bagian berjudul āPengubah Perubahan BiometrikāTipe panggilan balik untuk pengubah perubahan biometrik.
export type BiometryChangeListener = (result: AvailableResult) => void;BiometricOptions
Bagian berjudul āOpsi Biometrikāexport interface BiometricOptions { reason?: string; title?: string; subtitle?: string; description?: string; negativeButtonText?: string; /** * Only for iOS. * Specifies if should fallback to passcode authentication if biometric authentication fails. * On Android, this parameter is ignored due to BiometricPrompt API constraints: * DEVICE_CREDENTIAL authenticator and negative button (cancel) are mutually exclusive. */ useFallback?: boolean; /** * Only for iOS. * Set the text for the fallback button in the authentication dialog. * If this property is not specified, the default text is set by the system. */ fallbackTitle?: string; /** * Only for Android. * Set a maximum number of attempts for biometric authentication. The maximum allowed by android is 5. * @default 1 */ maxAttempts?: number; /** * Only for Android. * Specify which biometry types are allowed for authentication. * If not specified, all available types will be allowed. * @example [BiometryType.FINGERPRINT, BiometryType.FACE_AUTHENTICATION] */ allowedBiometryTypes?: BiometryType[];}GetCredentialOptions
Bagian berjudul āOpsi Mendapatkan Kredensialāexport interface GetCredentialOptions { server: string;}Credentials
Bagian berjudul āKredensialāexport interface Credentials { username: string; password: string;}SetCredentialOptions
Bagian berjudul āOpsi Mengatur Kredensialāexport interface SetCredentialOptions { username: string; password: string; server: string; /** * Access control level for the stored credentials. * When set to BIOMETRY_CURRENT_SET or BIOMETRY_ANY, the credentials are * hardware-protected and require biometric authentication to access. * * On iOS, this adds SecAccessControl to the Keychain item. * On Android, this creates a biometric-protected Keystore key and requires * BiometricPrompt authentication for both storing and retrieving credentials. * * @default AccessControl.NONE * @since 8.4.0 */ accessControl?: AccessControl;}DeleteCredentialOptions
Bagian berjudul āDeleteCredentialOptionsāexport interface DeleteCredentialOptions { server: string;}GetSecureCredentialsOptions
Bagian berjudul āGetSecureCredentialsOptionsāexport interface GetSecureCredentialsOptions { server: string; /** * Reason for requesting biometric authentication. * Displayed in the biometric prompt on both iOS and Android. */ reason?: string; /** * Title for the biometric prompt. * Only for Android. */ title?: string; /** * Subtitle for the biometric prompt. * Only for Android. */ subtitle?: string; /** * Description for the biometric prompt. * Only for Android. */ description?: string; /** * Text for the negative/cancel button. * Only for Android. */ negativeButtonText?: string;}IsCredentialsSavedOptions
Bagian berjudul āIsCredentialsSavedOptionsāexport interface IsCredentialsSavedOptions { server: string;}IsCredentialsSavedResult
Bagian berjudul āIsCredentialsSavedResultāexport interface IsCredentialsSavedResult { isSaved: boolean;}AuthenticationStrength
Bagian berjudul āAuthenticationStrengthāexport enum AuthenticationStrength { /** * No authentication available, even if PIN is available but useFallback = false */ NONE = 0, /** * Strong authentication: Face ID on iOS, fingerprints on devices that consider fingerprints strong (Android). * Note: PIN/pattern/password is NEVER considered STRONG, even when useFallback = true. */ STRONG = 1, /** * Weak authentication: Face authentication on Android devices that consider face weak, * or PIN/pattern/password if useFallback = true (PIN is always WEAK, never STRONG). */ WEAK = 2,}Sumber Kebenaran
Bagian berjudul āSumber KebenaranāThis page is generated from the pluginās src/definitions.tsRe-run the sync when the public API changes upstream.
Teruskan dari Getting Started
Judul bagian āTeruskan dari Getting StartedāJika Anda menggunakan Getting Started untuk merencanakan autentikasi dan aliran akun, hubungkannya dengan Menggunakan @capgo/capacitor-native-biometric untuk kemampuan asli dalam Menggunakan @capgo/capacitor-native-biometric, @capgo/capacitor-social-login untuk detail implementasi dalam @capgo/capacitor-social-login, @capgo/capacitor-passkey untuk detail implementasi di @capgo/capacitor-passkey, @capgo/capacitor-native-biometric untuk detail implementasi di @capgo/capacitor-native-biometric, dan Autentikasi Dua Faktor untuk detail implementasi di Autentikasi Dua Faktor.