Mengautentikasi pengguna dengan identitas eksternal
Panduan memulai ini menunjukkan cara mengamankan aplikasi menggunakan Identity-Aware Proxy (IAP) dan identitas eksternal. Dengan menggabungkan IAP dan Identity Platform, Anda dapat mengautentikasi pengguna dengan berbagai penyedia identitas, seperti OAuth, SAML, dan OIDC, selain Akun Google.
Dalam panduan memulai ini, Anda akan mengamankan aplikasi contoh App Engine menggunakan autentikasi Facebook.
Sebelum memulai
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Verify that billing is enabled for your Google Cloud project.
Menginstal Google Cloud CLI. Setelah penginstalan, lakukan inisialisasi Google Cloud CLI dengan menjalankan perintah berikut:
gcloud init
Jika Anda menggunakan penyedia identitas (IdP) eksternal, Anda harus login ke gcloud CLI dengan identitas gabungan Anda terlebih dahulu.
Lakukan inisialisasi App Engine untuk project Anda:
gcloud app create --project=project-id
Instal Node.js versi saat ini.
Instal alat command line Firebase:
npm install -g firebase-tools
Mengaktifkan API
Pertama, aktifkan Identity Platform:
Buka halaman Identity Platform Marketplace di konsol Google Cloud .
Klik Aktifkan Identity Platform. Halaman Identity Platform akan muncul di konsol Google Cloud .
Kemudian, aktifkan IAP:
Buka halaman IAP di konsol Google Cloud .
Pilih project yang sama dengan yang Anda gunakan untuk Identity Platform. Menggunakan project yang berbeda tidak didukung.
Klik Enable API.
Mendownload dan men-deploy kode contoh
Kode untuk panduan memulai ini memiliki dua komponen: aplikasi klien dan aplikasi autentikasi.
Aplikasi klien dilindungi oleh IAP. Saat menerima permintaan dari pengguna yang tidak diautentikasi, aplikasi akan mengalihkan permintaan ke aplikasi autentikasi untuk memverifikasi identitas pengguna. Jika pengguna berhasil login, aplikasi autentikasi akan merespons dengan Token Web JSON (JWT). Untuk tujuan demonstrasi, aplikasi klien menampilkan JWT.
Pertama, download kode, lalu deploy aplikasi klien:
Download kode contoh:
git clone https://github.com/GoogleCloudPlatform/iap-gcip-web-toolkit.git
Ubah ke direktori aplikasi klien:
cd iap-gcip-web-toolkit/sample/app
Instal dependensi:
npm install
Deploy aplikasi klien ke App Engine:
npm run deploy
Aplikasi klien diluncurkan di URL:
https://[PROJECT-ID].appspot.com
Selanjutnya, deploy aplikasi autentikasi:
Ubah ke direktori untuk aplikasi autentikasi:
cd ../authui-firebaseui
Instal dependensi:
npm install export NODE_OPTIONS=--openssl-legacy-provider
Konfigurasi aplikasi autentikasi untuk menggunakan Firebase Hosting. Tentukan Google Cloud project ID dari project Google Cloud yang berisi aplikasi klien yang dilindungi IAP:
firebase use project-id
Deploy aplikasi:
npm run deploy
Aplikasi autentikasi diluncurkan di URL:
https://[PROJECT-ID].firebaseapp.com
Anda telah men-deploy aplikasi klien dan autentikasi. Langkah berikutnya adalah mengonfigurasi Identity Platform dan IAP.
Menyiapkan Identity Platform
IAP menggunakan Identity Platform untuk mengautentikasi identitas eksternal. Panduan memulai ini menggunakan Facebook sebagai contoh, tetapi Identity Platform mendukung berbagai penyedia identitas.
Buat aplikasi Facebook
Untuk mengautentikasi pengguna dengan Facebook, Anda memerlukan App ID dan App Secret.
Login ke Facebook for Developers. Jika belum memiliki akun Facebook, Anda harus membuatnya.
Buka halaman Aplikasi Facebook.
Klik Tambahkan Aplikasi Baru.
Di menu kiri, pilih Setelan > Dasar.
Di kotak URL Kebijakan Privasi, masukkan URL yang valid. Jika men-deploy aplikasi ke produksi nanti, Anda dapat memperbarui URL untuk mengarah ke kebijakan privasi Anda.
Catat ID Aplikasi dan Rahasia Aplikasi Anda. Anda akan memerlukannya di bagian berikutnya.
Menambahkan Facebook sebagai penyedia identitas
Konfigurasi Identity Platform untuk menggunakan Facebook sebagai autentikasi:
Buka halaman Penyedia Identitas di konsol Google Cloud .
Klik Tambahkan Penyedia.
Pilih Facebook dari daftar penyedia.
Masukkan ID Aplikasi dan Rahasia Aplikasi yang Anda peroleh di bagian sebelumnya.
Klik Simpan.
Mengonfigurasi URI pengalihan OAuth
Saat Facebook selesai memproses permintaan dari aplikasi autentikasi, Facebook memerlukan URI untuk mengalihkan.
Kembali ke halaman Aplikasi Facebook dan pilih aplikasi Anda.
Di menu kiri, klik Produk.
Temukan produk Login dengan Facebook, lalu klik Siapkan.
Di menu navigasi kiri, pilih Setelan (Anda tidak perlu menyelesaikan alur mulai cepat terpandu).
Di kotak Valid OAuth Redirect URIs, masukkan URI pengalihan:
https://project-id.firebaseapp.com/__/auth/handler
Anda juga dapat menemukan URI ini di halaman konfigurasi penyedia Identity Platform.
Klik Simpan Perubahan.
Anda telah selesai menyiapkan Identity Platform. Sekarang Anda dapat mengonfigurasi IAP untuk menggunakannya dalam autentikasi.
Mengaktifkan IAP untuk menggunakan identitas eksternal
Buka halaman IAP di konsol Google Cloud .
Klik tab APLIKASI.
Pilih aplikasi App Engine contoh yang Anda deploy sebelumnya. URL dalam kategori Dipublikasikan akan terlihat seperti:
https://project-id.appspot.com
Di kolom IAP, alihkan tombol ke Aktif.
Di panel samping, klik Mulai untuk Gunakan identitas eksternal untuk otorisasi.
Di bagian Halaman login, pilih Saya akan menyediakannya sendiri.
Di kolom Authentication URL, masukkan URL aplikasi autentikasi. URL tersebut akan terlihat seperti:
https://project-id.firebaseapp.com/
Setelah Anda memasukkan URL, konsol Google Cloud akan otomatis menambahkan kunci API Anda.
Centang kotak dengan nama project Anda. Facebook harus tercantum sebagai penyedia identitas.
Klik Simpan.
Anda telah selesai menyiapkan IAP.
Menguji autentikasi pengguna
Untuk menguji bahwa IAP melindungi aplikasi Anda dan mengautentikasi pengguna dengan Facebook:
Buka aplikasi App Engine klien di browser Anda:
https://project-id.appspot.com
Setelah layar pemuatan singkat, Anda akan dialihkan ke halaman login Identity Platform.
Ikuti perintah di layar untuk melakukan autentikasi dengan Facebook.
Anda akan dialihkan kembali ke aplikasi klien, yang akan menampilkan JWT yang ditampilkan oleh Identity Platform.
Untuk logout sepenuhnya, Anda harus logout dari aplikasi contoh yang Anda buat dan Facebook. Anda harus logout dari kedua aplikasi karena Firebase membuat sesi dengan Facebook yang valid selama satu jam. Untuk mengetahui informasi selengkapnya, lihat Mengelola Sesi Pengguna.
Selamat! Anda berhasil men-deploy aplikasi ke App Engine dan melindunginya dengan IAP dan identitas eksternal.
Pembersihan
Agar akun Google Cloud Anda tidak dikenai biaya untuk resource yang digunakan pada halaman ini, ikuti langkah-langkah berikut.
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
Selain itu, Anda mungkin ingin menghapus aplikasi Facebook yang Anda buat.
Langkah berikutnya
- Sesuaikan UI autentikasi Anda dengan FirebaseUI, atau buat UI kustom dari awal.
- Pelajari lebih lanjut cara mengonfigurasi penyedia identitas dengan Identity Platform.
- Pelajari cara membuat silo pengguna dan konfigurasi unik dengan multi-tenancy Identity Platform.