Halaman ini berisi ringkasan tentang daftar kontrol akses (ACL). Untuk mempelajari cara lain dalam mengontrol akses ke bucket dan objek, baca Ringkasan Kontrol Akses.
Haruskah menggunakan daftar kontrol akses?
Pada umumnya, Anda harus menghindari penggunaan ACL, dan Anda harus mengaktifkan akses level bucket yang seragam untuk bucket Anda, yang mencegah penggunaan ACL:
- ACL tidak dapat digunakan secara eksklusif untuk mengontrol akses ke resource Google Cloud Anda, karena ACL tidak dapat ditetapkan di keseluruhan project atau resource di luar Cloud Storage.
- Mengaktifkan akses level bucket yang seragam akan membuat platform kontrol akses yang lebih sederhana dan memungkinkan Anda menggunakan fitur Google Cloud tambahan. Untuk mengetahui informasi selengkapnya, lihat haruskah Anda menggunakan akses tingkat bucket yang seragam.
- Kebijakan organisasi berbagi dengan pembatasan domain dan kebijakan organisasi kustom tidak mencegah akses yang diberikan oleh ACL, yang berpotensi menyebabkan akses yang tidak diinginkan.
- Perilaku dan akses yang tidak terduga dapat terjadi saat menggunakan ACL dalam project yang memiliki kondisi IAM yang ditetapkan di atau di atas level project.
Anda kemungkinan besar akan menggunakan ACL dalam kasus berikut:
- Anda perlu menyesuaikan akses ke setiap objek dalam suatu bucket, seperti jika Anda ingin uploader objek memiliki kontrol penuh atas objek tersebut, tetapi memiliki akses yang lebih kecil ke objek lain di bucket Anda.
- Ketika Anda menggunakan XML API secara eksklusif atau memerlukan interoperabilitas dengan Amazon S3.
Identity and Access Management (IAM) dan ACL berfungsi bersama-sama untuk memberikan akses ke bucket dan objek. Dengan kata lain, pengguna hanya memerlukan izin yang relevan dari salah satu sistem ini untuk dapat mengakses bucket atau objek. Secara umum, izin yang diberikan oleh kebijakan IAM tidak muncul di ACL, dan izin yang diberikan oleh ACL tidak muncul di kebijakan IAM. Lihat Hubungan IAM dengan ACL untuk informasi selengkapnya.
Apa itu daftar kontrol akses?
Daftar kontrol akses (ACL) adalah mekanisme yang bisa digunakan untuk menentukan siapa saja yang memiliki akses ke bucket dan objek Anda, serta tingkat akses yang mereka miliki. Di Cloud Storage, Anda menerapkan ACL ke tiap-tiap bucket dan objek. Setiap ACL terdiri dari satu entri atau lebih. Suatu entri memberi pengguna tertentu (atau grup) kemampuan untuk melakukan tindakan tertentu. Setiap entri terdiri dari dua informasi:
Izin, yaitu informasi yang menentukan tindakan apa saja yang dapat dilakukan (misalnya, baca atau tulis).
Cakupan, (kadang disebut sebagai penerima akses), yaitu informasi yang menentukan siapa saja yang dapat melakukan tindakan tertentu (misalnya, pengguna atau grup pengguna tertentu).
Sebagai contoh, anggaplah Anda memiliki bucket yang akses objeknya ingin diberikan kepada semua orang. Namun, Anda juga ingin memberi kolaborator kemampuan untuk menambahkan atau menghapus objek dari bucket itu. Dalam kasus ini, ACL Anda akan terdiri dari dua entri:
Di satu entri, berikan izin
READER
untuk cakupanallUsers
.Di entri lainnya, berikan izin
WRITER
untuk cakupan kolaborator Anda (ada beberapa cara untuk menetapkan orang ini, seperti menggunakan email mereka).
Jumlah maksimum entri ACL yang dapat Anda buat untuk bucket atau objek adalah 100. Cakupan entri yang berupa grup atau domain akan dihitung sebagai satu entri ACL, berapa pun jumlah pengguna yang ada di dalam grup atau domain.
Saat pengguna meminta akses ke bucket atau objek, sistem Cloud Storage
akan membaca ACL bucket atau objek lalu menentukan apakah akan mengizinkan atau menolak
permintaan akses tersebut. Jika ACL memberi pengguna izin untuk operasi
yang diminta, permintaan akan diizinkan. Jika ACL tidak memberi pengguna izin
untuk operasi yang diminta, permintaan akan gagal dan error 403 Forbidden
akan
ditampilkan.
Perlu diingat bahwa meskipun ACL dapat digunakan untuk mengelola sebagian besar tindakan yang melibatkan bucket dan objek, kemampuan untuk membuat bucket berasal dari izin project yang sesuai.
Izin
Izin menjelaskan tindakan apa saja yang dapat dilakukan pada objek atau bucket tertentu.
Cloud Storage memungkinkan Anda untuk memberikan izin konsentris berikut pada bucket dan objek, seperti yang ditampilkan pada tabel di bawah:
Bucket | Objek | |
---|---|---|
READER |
Mengizinkan pengguna mencantumkan konten bucket. Juga mengizinkan pengguna membaca metadata bucket, kecuali ACL. | Mengizinkan pengguna mendownload data objek. |
WRITER |
Memberi pengguna semua akses yang diberikan oleh
izin READER . Juga mengizinkan pengguna membuat, mengganti, dan menghapus
objek dalam bucket, termasuk membuat objek menggunakan upload
multibagian. |
T/A. Anda tidak dapat menerapkan izin ini ke objek. |
OWNER |
Memberi pengguna semua akses yang diberikan oleh
izin WRITER . Juga mengizinkan pengguna membaca dan menulis metadata bucket,
termasuk ACL, dan memungkinkan pengguna untuk menggunakan tag pada bucket. |
Memberi pengguna semua akses yang diberikan oleh
izin READER . Dan mengizinkan pengguna membaca dan menulis metadata objek,
termasuk ACL. |
Default | Bucket memiliki ACL
project-private bawaan yang diterapkan
saat dibuat. Bucket selalu dimiliki oleh grup
project-owners . |
Objek memiliki ACL project-private bawaan yang diterapkan saat diupload. Objek selalu dimiliki oleh pemohon permintaan asli yang mengupload objek. |
Di halaman ini, kami umumnya menyebut izin tersebut sebagai READER
, WRITER
,
dan OWNER
, sebagaimana digunakan di JSON API dan
Konsol Google Cloud. Jika Anda menggunakan XML API, izin
yang setara adalah READ
, WRITE
, dan FULL_CONTROL
.
Cakupan
Cakupan menentukan siapa saja yang memiliki izin tertentu.
Suatu ACL terdiri dari satu entri atau lebih, dan setiap entrinya memberikan izin ke suatu cakupan. Anda dapat menentukan cakupan ACL menggunakan entity berikut:
Cakupan ("penerima akses") | Jenis Entity | Contoh |
---|---|---|
ID khusus untuk semua entitas | Pengguna | allUsers |
ID khusus untuk semua akun yang valid | Pengguna | allAuthenticatedUsers |
Alamat email akun pengguna | Pengguna | collaborator@gmail.com |
Alamat email akun layanan | Pengguna | my-service-account@my-project.iam.gserviceaccount.com |
Alamat email grup Google | Grup | work-group@googlegroups.com |
Nilai praktis untuk project | Project | owners-123456789012 |
Domain Google Workspace | Domain | dana@example.com |
Domain Cloud Identity | Domain | dana@example.com |
ID khusus untuk semua entitas:
ID cakupan khusus
allUsers
mewakili entity apa pun di Internet. Perlu diperhatikan bahwa meskipun termasuk dalam jenis entityUser
, ID ini diberi label sebagai jenis entityPublic
saat menggunakan Konsol Google Cloud.ID khusus untuk semua akun yang valid:
ID cakupan khusus
allAuthenticatedUsers
mewakili sebagian besar akun yang diautentikasi, termasuk akun layanan. Untuk informasi selengkapnya, lihat Ringkasan IAM. Perlu diperhatikan bahwa meskipun termasuk dalam jenis entityUser
, ID ini diberi label sebagai jenis entityPublic
saat menggunakan Konsol Google Cloud.Alamat email akun pengguna:
Setiap pengguna yang memiliki akun pengguna harus memiliki alamat email unik yang terkait dengan akun tersebut. Anda dapat menentukan cakupan dengan menggunakan alamat email yang terkait dengan akun pengguna.
Cloud Storage akan mengingat alamat email yang diberikan di ACL hingga entrinya dihapus atau diganti. Jika ada pengguna yang mengubah alamat email, Anda harus memperbarui entri ACL untuk menyesuaikan dengan perubahan tersebut.
Alamat email akun layanan:
Setiap akun layanan memiliki alamat email unik yang terkait dengannya. Anda dapat menentukan cakupan dengan menggunakan alamat email yang terkait dengan akun layanan.
Alamat email grup Google:
Setiap grup Google memiliki alamat email unik yang terkait dengan grup. Sebagai contoh, grup Cloud Storage Announce memiliki alamat email berikut: gs-announce@googlegroups.com. Anda dapat menemukan alamat email yang terkait dengan grup Google dengan mengklik Tentang di halaman beranda setiap grup Google.
Seperti halnya alamat email akun pengguna, Cloud Storage juga mengingat alamat email grup yang diberikan di ACL sampai entrinya dihapus. Anda tidak perlu mengkhawatirkan pembaruan alamat email grup Google karena alamat email Grup Google bersifat permanen dan kemungkinan besar tidak akan berubah.
Nilai praktis untuk project:
Nilai praktis memungkinkan Anda untuk memberikan akses massal kepada viewer, editor, dan pemilik project. Nilai praktis menggabungkan peran project dan nomor project yang terkait. Misalnya, dalam project
867489160491
, editor diidentifikasi sebagaieditors-867489160491
. Anda dapat menemukan nomor project di halaman beranda Konsol Google Cloud.Secara umum, Anda sebaiknya menghindari penggunaan nilai kemudahan di lingkungan produksi, karena nilai kemudahan memerlukan pemberian peran dasar, sebuah praktik yang tidak disarankan di lingkungan produksi.
Google Workspace atau Cloud Identity:
Pelanggan Google Workspace dan Cloud Identity dapat mengaitkan akun email mereka dengan nama domain internet. Saat Anda melakukannya, setiap akun email akan menjadi USERNAME@YOUR_DOMAIN.com. Anda dapat menentukan cakupan menggunakan nama domain internet yang terkait dengan Google Workspace atau Cloud Identity.
Izin dan cakupan konsentris
Saat menentukan ACL di Cloud Storage, Anda tidak perlu mencantumkan beberapa
cakupan untuk memberikan beberapa izin. Cloud Storage menggunakan izin
konsentris. Jadi, saat memberikan izin WRITER
, Anda juga memberikan izin READER
, dan jika memberikan OWNER
, Anda juga memberikan izin READER
dan
WRITER
.
Saat menentukan ACL, sebagian besar alat memungkinkan Anda untuk
menentukan beberapa cakupan sekaligus untuk entri yang sama. Izin akses yang paling permisif adalah
akses yang diberikan ke cakupan. Misalnya, jika Anda memberikan dua entri untuk seorang
pengguna, yaitu satu entri dengan izin READER
dan satu lagi dengan izin WRITER
di bucket,
pengguna tersebut akan memiliki izin WRITER
di bucket.
Di XML API, Anda tidak dapat memberikan dua entri ACL dengan cakupan yang
sama. Misalnya, jika Anda memberi pengguna izin READ
dan WRITE
di
bucket, error akan ditampilkan. Sebagai gantinya, beri pengguna izin WRITE
, yang
juga memberikan izin READ
kepada pengguna.
ACL bawaan
ACL bawaan, yang sering juga disebut sebagai ACL template, adalah nama lain untuk serangkaian entri ACL tertentu yang dapat Anda gunakan untuk menerapkan banyak entri ACL sekaligus ke bucket atau objek dengan cepat.
Tabel berikut berisi daftar ACL bawaan serta entri ACL mana yang diterapkan untuk setiap ACL bawaan. Saat menggunakan tabel berikut, perhatikan bahwa:
Grup project owner memiliki kepemilikan bucket di project, dan pengguna yang membuat objek menjadi pemilik objek tersebut. Jika objek dibuat oleh pengguna anonim, kepemilikan objek diberikan kepada grup project owner.
Tabel ini menggunakan deskripsi izin JSON API, yaitu
OWNER
,WRITER
, danREADER
. Cakupan XML API yang setara adalahFULL_CONTROL
,WRITE
, danREAD
.JSON API/ gcloud storage
XML API Deskripsi private
private
Memberi pemilik bucket atau objek izin OWNER
pada bucket atau objek.bucketOwnerRead
bucket-owner-read
Memberi pemilik objek izin OWNER
, dan memberi pemilik bucket izinREADER
. Izin ini hanya digunakan dengan objek.bucketOwnerFullControl
bucket-owner-full-control
Memberi pemilik objek dan bucket izin OWNER
. Izin ini hanya digunakan dengan objek.projectPrivate
project-private
Memberikan izin kepada tim project berdasarkan peran mereka. Semua orang yang menjadi anggota tim memiliki izin READER
. Project owner dan editor project memiliki izinOWNER
. ACL ini ditetapkan secara default untuk bucket yang baru dibuat. ACL ini juga ditetapkan secara default untuk objek yang baru dibuat, kecuali jika ACL objek default untuk bucket tersebut telah diubah.authenticatedRead
authenticated-read
Memberi pemilik bucket atau objek izin OWNER
, dan memberi semua pemegang akun pengguna terautentikasi izinREADER
.publicRead
public-read
Memberi pemilik bucket atau objek izin OWNER
, dan memberi semua pengguna, baik yang terautentikasi maupun anonim, izinREADER
. Saat menerapkannya ke objek, semua orang di internet dapat membaca objek tersebut tanpa perlu melakukan autentikasi. Saat menerapkannya ke bucket, semua orang di internet dapat mencantumkan objek tanpa perlu melakukan autentikasi.* Lihat catatan di akhir tabel tentang penyimpanan data ke dalam cache.
publicReadWrite
public-read-write
Memberi pemilik bucket izin OWNER
, dan memberi semua pengguna, baik yang terautentikasi maupun anonim, izinREADER
danWRITER
. ACL ini hanya berlaku untuk bucket. Jika Anda menerapkannya ke bucket, semua orang di internet dapat mencantumkan, membuat mengganti, dan menghapus objek tanpa perlu melakukan autentikasi.
* Lihat catatan di akhir tabel tentang penyimpanan data ke dalam cache.
* Secara default, objek yang dapat dibaca oleh publik disajikan dengan header Cache-Control
,
sehingga dapat di-cache selama 3.600 detik. Jika perlu
memastikan bahwa update segera terlihat, Anda harus
menetapkan metadata Cache-Control
untuk objek tersebut ke
Cache-Control:private, max-age=0, no-transform
.
ACL default
Saat bucket dibuat atau objek diupload, ACL default akan diberikan jika Anda tidak menetapkan ACL secara eksplisit pada bucket atau objek tersebut. Anda dapat mengubah ACL default yang ditetapkan ke object tersebut. Caranya dapat Anda temukan di Mengubah ACL objek default. Perlu diperhatikan bahwa jika Anda mengubah ACL default, ACL objek yang sudah ada pada bucket di project tidak akan berubah.
ACL bucket default
Semua bucket dimiliki oleh grup project owner. Project owner juga
diberi izin OWNER
untuk setiap bucket dalam project yang menggunakan
ACL bawaan.
Jika Anda membuat bucket dengan ACL bucket default, yaitu ketika Anda tidak
menentukan ACL bawaan saat membuat
bucket, ACL projectPrivate
bawaan ditetapkan ke bucket tersebut.
ACL objek default
Secara default, setiap pengguna yang memiliki izin OWNER
atau WRITER
di bucket
dapat mengupload objek ke bucket tersebut. Saat mengupload objek, Anda dapat memberikan
ACL bawaan atau tidak menentukan ACL sama sekali. Jika Anda tidak
menentukan ACL, Cloud Storage akan menerapkan ACL objek default bucket ke objek tersebut. Setiap bucket memiliki ACL objek default, dan ACL ini diterapkan ke
semua objek yang diupload ke bucket tersebut yang tidak memiliki ACL bawaan atau ACL yang ditentukan di permintaan (khusus JSON API). Nilai awal ACL objek default untuk setiap bucket adalah projectPrivate
.
Berdasarkan cara objek diupload, ACL objek diterapkan sebagai berikut:
Upload yang Diautentikasi
Jika membuat permintaan terautentikasi untuk mengupload objek dan tidak menentukan ACL objek apa pun saat menguploadnya, Anda akan dicantumkan sebagai pemilik objek dan ACL
projectPrivate
bawaan diterapkan ke objek secara default. Artinya:Anda (orang yang mengupload objek) dicantumkan sebagai pemilik objek. Kepemilikan objek tidak dapat diubah dengan memodifikasi ACL. Anda dapat mengubah kepemilikan objek hanya dengan mengganti objek.
Anda (pemilik objek) diberi izin
OWNER
pada objek. Jika Anda mencoba memberikan izin yang lebih rendah dariOWNER
kepada pemilik, Cloud Storage akan otomatis mengeskalasi izin tersebut menjadiOWNER
Grup project owner dan editor project memiliki izin
OWNER
pada objek.Grup anggota tim project memiliki izin
READER
pada objek.
Upload Anonim
Jika pengguna yang tidak diautentikasi (anonim) mengupload objek, yang bisa terjadi jika bucket memberi grup
allUsers
izinWRITER
atauOWNER
, ACL bucket default akan diterapkan ke objek tersebut seperti yang dijelaskan di atas.Pengguna anonim tidak dapat menentukan ACL bawaan selama objek diupload.
Perilaku ACL
Cloud Storage membantu Anda mengikuti praktik terbaik dengan menerapkan beberapa aturan modifikasi ACL, yang mencegah Anda agar tidak menetapkan ACL yang membuat data tidak dapat diakses.
Anda tidak dapat menerapkan ACL yang menentukan bucket atau pemilik objek yang berbeda.
Kepemilikan bucket dan objek tidak dapat diubah dengan memodifikasi ACL. Jika Anda menerapkan ACL baru ke bucket atau objek, pastikan pemilik bucket atau objek tidak diubah di ACL baru.
Pemilik bucket atau objek selalu memiliki izin
OWNER
pada bucket atau objek.Pemilik bucket adalah grup project owner, dan pemilik objek adalah pengguna yang mengupload objek, atau grup project owner jika objek diupload oleh pengguna anonim.
Saat Anda menerapkan ACL baru ke bucket atau objek, Cloud Storage menambahkan izin
OWNER
ke bucket atau menambahkan pemilik objek jika Anda menghapus pemberian aksesnya. Tindakan ini tidak memberi grup project owner izinOWNER
untuk objek (kecuali jika objek dibuat oleh pengguna anonim), jadi Anda harus menyertakannya secara eksplisit.
Anda tidak dapat menerapkan ACL yang mengubah kepemilikan bucket atau objek (yang
tidak boleh disamakan dengan izin OWNER
). Setelah dibuat di
Cloud Storage, kepemilikan bucket dan objek bersifat permanen. Namun, Anda dapat
mengubah kepemilikan objek (bukan bucket) secara efektif dengan
menggantinya. Penggantian ini pada dasarnya adalah operasi penghapusan yang langsung diikuti dengan operasi upload. Selama operasi upload, orang yang melakukan
upload akan menjadi pemilik objek tersebut. Perlu diingat bahwa untuk mengganti
objek, orang yang melakukan penggantian (dan mendapat kepemilikan
objek karenanya) harus memiliki izin WRITER
atau OWNER
pada bucket
tempat objek diupload.
Langkah berikutnya
- Pelajari cara menggunakan ACL.
- Pelajari cara menyederhanakan kontrol akses menggunakan akses level bucket seragam.
- Pelajari praktik terbaik untuk menggunakan ACL.