Supabase Apple Login pada Android
Salin prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Prasyarat
Bagian berjudul “Prasyarat”Panduan ini akan membantu Anda mengintegrasikan Sign-In Apple dengan Supabase Authentication pada Android. Diperkirakan bahwa Anda telah menyelesaikan:
Langkah 1: Deploy Backend Edge Function
Judul Bagian “Langkah 1: Deploy Backend Edge Function”Pertama, kami perlu mengdeploy Supabase Edge Function yang akan menghandle callback OAuth Apple.
-
Navigasikan ke direktori proyek Supabase Anda
Jendela Terminal cd your-project/supabase -
Buat fungsi edge (jika tidak ada)
Jendela terminal supabase functions new apple-signin-callback -
Salin fungsi edge code
Implementasi lengkap fungsi edge tersedia di contoh aplikasi.
Salin berikut file ke proyek Anda:
supabase/functions/apple-signin-callback/index.ts- Fungsi edge utama codesupabase/functions/apple-signin-callback/deno.json- Peta import untuk dependensi (termasukjoselibrary untuk menandatangani JWT)
-
Konfigurasi verifikasi JWT
Apple harus membuat endpoint callback OAuth-nya publik (tidak memerlukan autentikasi) karena Apple akan mengarahkan ke sana. Perbarui dengan
supabase/config.tomlfile:[functions.apple-signin-callback]enabled = trueverify_jwt = false # Important: Set to false for public OAuth callbackimport_map = "./functions/apple-signin-callback/deno.json"entrypoint = "./functions/apple-signin-callback/index.ts" -
Deploy fungsi
Jendela terminal supabase functions deploy apple-signin-callback -
Dapatkan URL fungsi Anda
Setelah pengembangan, Anda akan mendapatkan URL seperti:
https://your-project-ref.supabase.co/functions/v1/apple-signin-callbackJika Anda tidak dapat menemukannya, Anda dapat melakukan hal berikut:
- Buka
https://supabase.com/dashboard/project/YOUR_PROJECT_REF/functions - Klik pada
apple-signin-callbackfungsi URL untuk menyalinnya.
- Buka
Langkah 2: Konfigurasi Portal Pengembang Apple
Bagian berjudul “Langkah 2: Konfigurasi Portal Pengembang Apple”Sekarang kita perlu mengonfigurasi Portal Pengembang Apple dengan URL backend dan mendapatkan semua nilai yang diperlukan.
-
Ikuti Panduan Pengaturan Login Apple Android
Lengkapi langkah Panduan Pengaturan Login Apple Android untuk:
- Buat ID Layanan
- Generate kunci pribadi (.p8 file)
- Dapatkan ID Tim dan ID Kunci
- Konfigurasi URL Kembali
-
Atur URL Kembali di Portal Pengembang Apple
When mengatur URL Pengembalian di Portal Pengembang Apple (langkah 6.9 dari panduan Apple), gunakan URL Fungsi Edge Supabase Anda:
https://your-project-ref.supabase.co/functions/v1/apple-signin-callbackPenting: Gunakan URL Fungsi Edge Supabase Anda
TIDAK gunakan URL pengalihan dari Petunjuk Pengaturan Login Android Apple. Panduan itu menggunakan URL server backend kustom. Untuk integrasi Supabase, Anda harus gunakan URL Fungsi Edge Supabase Anda.
-
Setelah menyelesaikan panduan pengaturan Apple, Anda harus memiliki:
ID TIM APPLE
- : ID Tim Pengembang Apple AndaID KUNJUNGAN APPLE
- : ID Kunjungan dari Portal Pengembang AppleKUNJUNGAN APPLE Pribadi
- : File kunci pribadi .p8 Anda (perlu dikodekan base64)ID JASA ANDROID
- : ID Jasa Apple Anda (misal,__CAPGO_KEEP_0__
com.example.app.service) - BASE_REDIRECT_URL: URL URL Anda (misalnya,
capgo-demo-app://path)
Langkah 3: Atur Rahasia Supabase
Bagian berjudul “Langkah 3: Atur Rahasia Supabase”Sekarang kita perlu mengatur variabel lingkungan (rahasia) untuk Fungsi Edge Supabase.
-
Enkripsi kunci pribadi Anda
Pertama, enkripsi kunci pribadi Apple (.p8 file) ke base64:
Tampilan jendela terminal base64 -i AuthKey_XXXXX.p8Salin seluruh output (ini adalah string panjang tunggal).
-
Atur rahasia menggunakan Supabase CLI
Tampilan jendela terminal supabase secrets set APPLE_TEAM_ID=your_team_idsupabase secrets set APPLE_KEY_ID=your_key_idsupabase secrets set APPLE_PRIVATE_KEY=your_base64_encoded_keysupabase secrets set ANDROID_SERVICE_ID=your.service.idsupabase secrets set BASE_REDIRECT_URL=your-app://pathsupabase secrets set APPLE_REDIRECT_URI=https://your-project-ref.supabase.co/functions/v1/apple-signin-callback -
Alternatif: Atur rahasia di Dashboard Supabase
Jika Anda lebih suka menggunakan dashboard:
- Buka dashboard proyek Supabase Anda
- Navigasikan ke Fungsi Pemangku → Pengaturan → Rahasia
- Tambahkan variabel rahasia masing-masing dengan nilai
Langkah 4: Gunakan Bantuan Autentikasi
Judul Bagian “Langkah 4: Gunakan Bantuan Autentikasi”Sekarang Anda dapat menggunakan bantuan autentikasi di aplikasi Anda code.
Implementasi
Judul Bagian “Implementasi”Implementasi lengkap tersedia di file aplikasi contoh. supabaseAuthUtils.ts Menggunakan Bantuan Autentikasi
Bab berjudul “Menggunakan Bantuan Autentikasi”
Salin ke clipboardimport { authenticateWithAppleSupabase } from './supabaseAuthUtils';
const result = await authenticateWithAppleSupabase();if (result.success) { console.log('Signed in:', result.user); // Navigate to your authenticated area} else { console.error('Error:', result.error);}Bab berjudul “Perbarui Fungsi Bantuan”
Saat menggunakan fungsi bantuan, Andawajib authenticateWithAppleSupabase mengupdate nilai-nilai berikut untuk sesuai dengan konfigurasi Anda: example app’s file.
-
Perbarui
redirectUrl- Atur ke URL Fungsi Edge Supabase Anda:const redirectUrl = platform === 'android'? 'https://your-project-ref.supabase.co/functions/v1/apple-signin-callback': undefined; -
Perbarui
clientId- Atur ke ID Layanan Apple Anda:await SocialLogin.initialize({apple: {clientId: isIOS? undefined // iOS uses bundle ID automatically: 'your.service.id.here', // Your Apple Service ID for AndroidredirectUrl: redirectUrl,},});
Lihat implementasi lengkap sebagai referensi.
Langkah 5: Uji Integrasi
Judul Bagian “Langkah 5: Uji Integrasi”-
Bangun dan jalankan aplikasi Android Anda
Jendela Terminal npx cap sync androidnpx cap run android -
Uji alur autentikasi
- Tetikkan tombol “Masuk dengan Apple”
- Anda harus melihat halaman OAuth Apple di browser
- Setelah autentikasi, Anda harus diarahkan kembali ke aplikasi Anda
- Cek log konsol untuk kesalahan apa pun
-
Verifikasi aliran
Aliran lengkap harus seperti ini:
- Pengguna menekan tombol “Masuk dengan Apple”
- Aplikasi membuka browser dengan Apple OAuth
- Pengguna mengautentikasi dengan Apple
- Apple mengarahkan ke:
https://your-project-ref.supabase.co/functions/v1/apple-signin-callback - Fungsi Edge mengganti code dengan token
- Fungsi Edge mengarahkan ke:
your-app://path?id_token=...&access_token=... - Aplikasi Android menerima tautan dalam dan memproses token identitas
- Aplikasi masuk ke Supabase dengan token identitas
Pengaturan Perbaikan
Bagian berjudul “Pengaturan Perbaikan”If otentikasi gagal:
- URI Redirect tidak sesuai: Pastikan URL Pengembalian di Portal Pengembang Apple sesuai dengan
APPLE_REDIRECT_URIrahasia - Tautan dalam mendalam tidak berfungsi: Periksa bahwa
AndroidManifest.xmlfilter tujuan sesuai denganBASE_REDIRECT_URL - Rahasia hilang: Pastikan semua rahasia telah diset dengan benar menggunakan
supabase secrets list - Pertukaran Token gagal: Periksa log fungsi tepi di Dashboard Supabase untuk pesan kesalahan rinci
- Aplikasi tidak menerima panggilan kembali: Pastikan
onNewIntentdiimplementasikan dengan benar di MainActivity - Review aplikasi contoh __CAPGO_KEEP_0__ example app code Bagaimana Cara Kerjanya
Bab berjudul “Bagaimana Cara Kerjanya”
Pada Android, Sign-In Apple menggunakan aliran OAuth redirect:Penyiapan
- : Plugin ini diinisialisasi dengan ID Layanan Anda dan URL redirect backendAliran OAuth
- : Membuka browser/Tab Chrome Kustom dengan halaman OAuth AppleAliran OAuth ini digunakan untuk mengautentikasi pengguna
- Panggilan Balik Backend: Apple mengarahkan ke fungsi Edge Supabase Anda dengan otorisasi code
- Pertukaran Token: Fungsi Edge mengganti code dengan token menggunakan endpoint token Apple
- Pengalihan Tautan dalam: Fungsi Edge mengarahkan kembali ke aplikasi Anda dengan token identitas
- Autentikasi Supabase: Aplikasi menerima token dan masuk ke Supabase
Alur ini diperlukan karena Apple tidak menyediakan dukungan native Android untuk Sign in dengan Apple.
Teruskan dari Supabase Apple Login on Android
Jika Anda menggunakanPanggilan Balik Backend Supabase Apple Login on Android untuk merencanakan autentikasi dan alur akun, hubungkannya dengan Menggunakan @capgo/capacitor-login-sosial untuk kemampuan native di Menggunakan @capgo/capacitor-login-sosial, @capgo/capacitor-login-sosial untuk detail implementasi di @capgo/capacitor-login-sosial, @capgo/capacitor-passkey untuk detail implementasi di @capgo/capacitor-passkey, @capgo/capacitor-biometrik-native untuk detail implementasi di @capgo/capacitor-biometrik-native, dan Dua faktor autentikasi untuk detail implementasi di Dua faktor autentikasi.