Dokumen ini menjelaskan cara mengonfigurasi autentikasi ke repositori upstream Maven Central untuk repositori jarak jauh Artifact Registry.
Dokumen ini mengasumsikan bahwa Anda telah membuat repositori jarak jauh Maven Artifact Registry , dan akun Maven Central.
Untuk mengetahui informasi selengkapnya tentang repositori jarak jauh, lihat Ringkasan repositori jarak jauh.
Peran yang diperlukan
Untuk mendapatkan izin yang diperlukan untuk mengonfigurasi autentikasi ke Maven Central untuk repositori jarak jauh, minta administrator Anda untuk memberikan peran IAM berikut pada project:
- Admin Artifact Registry (
roles/artifactregistry.admin) - Admin Secret Manager (
roles/secretmanager.admin)
Untuk mengetahui informasi selengkapnya tentang pemberian peran, lihat Mengelola akses ke project, folder, dan organisasi.
Anda mungkin juga bisa mendapatkan izin yang diperlukan melalui peran khusus atau peran bawaan lainnya.
Membuat token akses pribadi Maven Central
- Login ke Maven Central.
Buat token akses.
Gunakan kode pengguna untuk token akses pribadi Anda sebagai nama pengguna saat menambahkan kredensial ke Artifact Registry. Untuk mengetahui informasi selengkapnya tentang cara mengelola token pengguna di Maven Central, lihat Penyiapan keamanan dengan token pengguna.
Menyimpan token akses pribadi Anda dalam versi secret
- Buat secret di Secret Manager.
- Simpan token akses pribadi Maven Central Anda sebagai a versi secret.
Memberikan akses akun layanan Artifact Registry ke secret Anda
Agen layanan Artifact Registry bertindak atas nama Artifact Registry saat berinteraksi dengan Google Cloud layanan. Untuk mengizinkan agen layanan menggunakan secret yang disimpan di Secret Manager, Anda harus memberikan izin kepada agen layanan untuk melihat versi secret Anda.
ID agen layanan adalah:
service-PROJECT-NUMBER@gcp-sa-artifactregistry.iam.gserviceaccount.com
PROJECT-NUMBER adalah nomor project dari Google Cloud project tempat Artifact Registry berjalan.
Untuk memberikan peran Secret Manager Secret Accessor kepada agen layanan Artifact Registry:
Konsol
-
Buka halaman Secret Manager di Google Cloud konsol.
-
Di halaman Secret Manager, klik kotak centang di samping nama secret.
-
Jika belum terbuka, klik Show Info Panel untuk membuka panel.
-
Di panel info, klik Add Principal.
-
Di area teks New principals, masukkan alamat email anggota yang akan ditambahkan.
-
Di dropdown Select a role , pilih Secret Manager , lalu Secret Manager Secret Accessor.
gcloud
$ gcloud secrets add-iam-policy-binding secret-id \
--member="member" \
--role="roles/secretmanager.secretAccessor"
Dengan member adalah anggota IAM, seperti pengguna, grup, atau akun layanan.
C#
Untuk melakukan autentikasi ke Artifact Registry, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Go
Untuk melakukan autentikasi ke Artifact Registry, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Java
Untuk melakukan autentikasi ke Artifact Registry, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Node.js
Untuk melakukan autentikasi ke Artifact Registry, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
PHP
Untuk melakukan autentikasi ke Artifact Registry, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Python
Untuk melakukan autentikasi ke Artifact Registry, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Ruby
Untuk melakukan autentikasi ke Artifact Registry, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
API
Catatan: Tidak seperti contoh lainnya, contoh ini menggantikan seluruh kebijakan IAM.
$ curl "https://secretmanager.googleapis.com/v1/projects/project-id/secrets/secret-id:setIamPolicy" \
--request "POST" \
--header "authorization: Bearer $(gcloud auth print-access-token)" \
--header "content-type: application/json" \
--data "{\"policy\": {\"bindings\": [{\"members\": [\"member\"], \"role\": \"roles/secretmanager.secretAccessor\"}]}}"
Untuk mengetahui informasi selengkapnya tentang cara memberikan atau mencabut akses ke secret, lihat Mengelola akses ke secret.
Menambahkan kredensial Maven Central ke repositori jarak jauh Anda
Untuk memperbarui repositori jarak jauh dengan kredensial Maven Central Anda:
Konsol
Buka halaman Repositories di Google Cloud konsol.
Di daftar repositori, pilih repositori, lalu klik Edit Repository.
Di bagian Remote repository authentication mode, perbarui atau tambahkan kode pengguna Maven Central yang terkait dengan token akses pribadi Anda sebagai nama pengguna, dan versi secret yang berisi token akses Maven Central Anda.
gcloud CLI
Untuk memperbarui repositori jarak jauh dengan kredensial Maven Central Anda, jalankan perintah berikut:
gcloud artifacts repositories update REPOSITORY \
--project=PROJECT_ID \
--location=LOCATION \
--remote-username=USER_CODE \
--remote-password-secret-version=projects/SECRET_PROJECT_ID/secrets/SECRET_ID/versions/SECRET_VERSION
Ganti kode berikut:
REPOSITORYdengan nama repositori jarak jauh Artifact Registry Anda.PROJECT_IDdengan ID project Anda. Google CloudLOCATIONdengan lokasi regional atau multi-regional location untuk repositori. Anda dapat menghapus flag ini jika menetapkan default. Untuk melihat daftar lokasi yang didukung, jalankan perintahgcloud artifacts locations list.USER_CODEkode pengguna yang terkait dengan token akses Maven Central Anda. Untuk mengetahui informasi selengkapnya tentang cara mengelola token pengguna di Maven Central, lihat Penyiapan keamanan dengan token pengguna.SECRET_PROJECT_IDdengan ID project tempat Anda membuat secret.SECRET_IDdengan nama yang Anda berikan ke secret Anda.SECRET_VERSIONdengan versi secret tempat Anda menyimpan token akses Maven Central.
Kredensial Anda akan digunakan saat repositori jarak jauh mengirimkan permintaan untuk artefak dari sumber upstream.