Referensi: AuthorizationPolicy
AuthorizationPolicy adalah resource yang menentukan cara server mengizinkan koneksi yang masuk. Resource ini sendiri tidak mengubah konfigurasi kecuali jika dilampirkan ke resource pemilih konfigurasi endpoint atau proxy https target.
Representasi JSON |
---|
{ "name": string, "description": string, "createTime": string, "updateTime": string, "labels": { string: string, ... }, "action": enum ( |
Kolom | |
---|---|
name |
Wajib. Nama resource AuthorizationPolicy. Hasil ini cocok dengan pola |
description |
Opsional. Deskripsi teks bebas resource. |
createTime |
Hanya output. Stempel waktu saat resource dibuat. Stempel waktu dalam format RFC3339 UTC "Zulu", dengan resolusi nanodetik dan maksimal sembilan digit fraksional. Contoh: |
updateTime |
Hanya output. Stempel waktu saat resource diupdate. Stempel waktu dalam format RFC3339 UTC "Zulu", dengan resolusi nanodetik dan maksimal sembilan digit fraksional. Contoh: |
labels |
Opsional. Kumpulan tag label yang terkait dengan resource AuthorizationPolicy. Objek yang berisi daftar pasangan |
action |
Wajib. Tindakan yang harus diambil jika ditemukan kecocokan aturan. Nilai yang mungkin adalah "ALLOW" atau "DENY". |
rules[] |
Opsional. Daftar aturan yang akan dicocokkan. Perlu diketahui bahwa setidaknya salah satu aturan harus cocok agar tindakan yang ditentukan di kolom 'tindakan' dapat diambil. Aturan dianggap cocok jika terdapat sumber dan tujuan yang cocok. Jika dibiarkan kosong, tindakan yang ditentukan di kolom |
internalCaller |
Opsional. Tanda yang ditetapkan untuk mengidentifikasi pengontrol internal. Setelan ini akan memicu pemeriksaan P4SA untuk memvalidasi pemanggil berasal dari P4SA layanan yang diizinkan meskipun kolom opsional lainnya tidak disetel. |
Tindakan
Nilai yang mungkin yang menentukan tindakan yang akan diambil.
Enum | |
---|---|
ACTION_UNSPECIFIED |
Nilai default. |
ALLOW |
Berikan akses. |
DENY |
Tolak akses. Aturan penolakan harus dihindari kecuali jika digunakan untuk menyediakan penggantian "tolak semua" default. |
Aturan
Spesifikasi aturan.
Representasi JSON |
---|
{ "sources": [ { object ( |
Kolom | |
---|---|
sources[] |
Opsional. Daftar atribut untuk sumber traffic. Semua sumber harus cocok. Sumber dianggap cocok jika akun utama dan ipBlocks cocok. Jika tidak disetel, tindakan yang ditentukan dalam kolom 'tindakan' akan diterapkan tanpa pemeriksaan aturan apa pun untuk sumbernya. |
destinations[] |
Opsional. Daftar atribut untuk tujuan traffic. Semua tujuan harus cocok. Tujuan dianggap cocok jika permintaan cocok dengan semua host, port, metode, dan header yang ditentukan. Jika tidak disetel, tindakan yang ditentukan dalam kolom 'tindakan' akan diterapkan tanpa pemeriksaan aturan untuk tujuan. |
Sumber
Spesifikasi atribut sumber traffic.
Representasi JSON |
---|
{ "principals": [ string ], "ipBlocks": [ string ] } |
Kolom | |
---|---|
principals[] |
Opsional. Daftar identitas sejawat yang akan dicocokkan untuk otorisasi. Setidaknya satu akun utama harus cocok. Setiap peer dapat berupa pencocokan persis, atau pencocokan awalan (contoh, "namespace/*") atau pencocokan akhiran (contoh, "*/service-account") atau kecocokan kehadiran "*". Otorisasi berdasarkan nama utama tanpa validasi sertifikat (dikonfigurasi oleh resource ServerTlsPolicy) dianggap tidak aman. |
ipBlocks[] |
Opsional. Daftar rentang CIDR yang akan dicocokkan berdasarkan alamat IP sumber. Setidaknya satu blok IP harus cocok. IP tunggal (mis., "1.2.3.4") dan CIDR (mis., "1.2.3.0/24") didukung. Otorisasi berdasarkan IP sumber saja harus dihindari. Alamat IP dari load balancer atau proxy harus dianggap tidak tepercaya. |
Tujuan
Spesifikasi atribut tujuan traffic.
Representasi JSON |
---|
{
"hosts": [
string
],
"ports": [
integer
],
"paths": [
string
],
"methods": [
string
],
"httpHeaderMatch": {
object ( |
Kolom | |
---|---|
hosts[] |
Wajib. Daftar nama host yang akan dicocokkan. Cocok dengan header ":authority" di permintaan http. Setidaknya satu host harus cocok. Tiap host dapat berupa pencocokan persis, atau pencocokan awalan (contoh "domainsaya.*") atau pencocokan akhiran (contoh "*.myorg.com") atau pencocokan kehadiran (apa saja) cocok dengan "*". |
ports[] |
Wajib. Daftar port tujuan yang akan dicocokkan. Setidaknya satu port harus cocok. |
paths[] |
Opsional. Daftar jalur HTTP yang akan dicocokkan. Metode gRPC harus ditampilkan sebagai nama yang sepenuhnya memenuhi syarat dalam bentuk "/packageName.serviceName/methodName". Setidaknya satu jalur harus cocok. Setiap jalur dapat berupa pencocokan persis, atau pencocokan awalan (contoh, "/packageName.serviceName/*") atau pencocokan akhiran (contoh, "*/video") atau kecocokan keberadaan (apa saja) dengan "*". |
methods[] |
Opsional. Daftar metode HTTP yang akan dicocokkan. Setidaknya satu metode harus cocok. Tidak boleh ditetapkan untuk layanan gRPC. |
httpHeaderMatch |
Opsional. Mencocokkan pasangan key:value di header http. Memberikan pencocokan fleksibel berdasarkan header HTTP, untuk kasus penggunaan yang berpotensi lanjutan. Minimal satu header harus cocok. Hindari penggunaan kecocokan header untuk membuat keputusan otorisasi kecuali jika ada jaminan kuat bahwa permintaan diterima melalui klien atau proxy yang tepercaya. |
HttpHeaderMatch
Spesifikasi atribut pencocokan header HTTP.
Representasi JSON |
---|
{ "headerName": string, // Union field |
Kolom | |
---|---|
headerName |
Wajib. Nama header HTTP yang akan dicocokkan. Untuk mencocokkan dengan otoritas permintaan HTTP, gunakan headerMatch dengan nama header ":authority". Untuk mencocokkan metode permintaan, gunakan headerName ":method". |
Kolom union
|
|
regexMatch |
Wajib. Nilai header harus cocok dengan ekspresi reguler yang ditentukan dalam regexMatch. Untuk tata bahasa ekspresi reguler, lihat: en.cppreference.com/w/cpp/regex/ecmascript Untuk pencocokan dengan port yang ditentukan dalam permintaan HTTP, gunakan headerMatch dengan headerName yang disetel ke Host dan ekspresi reguler yang memenuhi specifier port header RFC2616 Host. |
Metode |
|
---|---|
|
Membuat AuthorizationPolicy baru di project dan lokasi tertentu. |
|
Menghapus satu AuthorizationPolicy. |
|
Mendapatkan detail satu AuthorizationPolicy. |
|
Mendapatkan kebijakan kontrol akses untuk resource. |
|
Mencantumkan AuthorizationPolicies dalam project dan lokasi tertentu. |
|
Memperbarui parameter satu AuthorizationPolicy. |
|
Menetapkan kebijakan kontrol akses pada resource yang ditentukan. |
|
Menampilkan izin yang dimiliki pemanggil atas resource yang ditentukan. |