Decorator Cloud Endpoints Frameworks untuk Python menjelaskan konfigurasi API, metode, parameter, dan detail penting lainnya yang menentukan properti dan perilaku Endpoint.
Halaman ini menjelaskan decorator yang tersedia secara mendetail. Untuk mengetahui informasi tentang cara menggunakan dekorator untuk membuat API, lihat artikel berikut:
Menentukan API (@endpoints.api
)
Anda dapat memberikan beberapa argumen ke @endpoints.api
untuk menentukan
API Anda. Tabel berikut menjelaskan argumen yang tersedia:
Argumen @endpoints.api | Deskripsi | Contoh |
---|---|---|
allowed_client_ids |
Wajib diisi jika API Anda menggunakan autentikasi. Daftar ID klien untuk klien yang diizinkan meminta token. Untuk mengetahui informasi selengkapnya, lihat Audiens dan ID klien yang diizinkan. | allowed_client_ids=['1-web-apps.apps.googleusercontent.com','2-android-apps.apps.googleusercontent.com', endpoints.API_EXPLORER_CLIENT_ID ] |
api_key_required |
Opsional. Digunakan untuk membatasi akses ke permintaan yang menyediakan kunci API. | api_key_required=True |
audiences |
Wajib diisi jika API Anda memerlukan autentikasi dan jika Anda mendukung klien Android. Untuk token ID Google, ini dapat berupa daftar ID klien yang tokennya diminta. Jika token dikeluarkan oleh penyedia autentikasi pihak ketiga, seperti Auth0, ini harus berupa pemetaan kamus dari nama penerbit autentikasi ke daftar audiens. Untuk mengetahui informasi selengkapnya, lihat Audiens dan ID klien yang diizinkan. | audiences=['1-web-apps.apps.googleusercontent.com'] atau audiences={"auth0": ["aud-1.auth0.com", "aud-2.auth0.com"]} |
base_path |
Opsional. Digunakan untuk menayangkan API Anda dari jalur yang ditentukan. Jika menentukan argumen ini, Anda juga harus mengubah bagian handlers dalam file app.yaml . |
Lihat Menayangkan API dari jalur yang berbeda. |
canonical_name |
Opsional. Digunakan untuk menentukan nama yang berbeda atau lebih mudah dibaca untuk API di library klien. Nama ini digunakan untuk membuat nama di library klien; backend API terus menggunakan nilai yang ditentukan dalam properti name .Misalnya, jika API Anda memiliki name yang ditetapkan ke dfaanalytics, Anda dapat menggunakan properti ini untuk menentukan nama kanonis DFA Group Analytics; class klien yang dibuat kemudian akan berisi nama DfaGroupAnalytics .Anda harus menyertakan spasi yang relevan di antara nama seperti yang ditunjukkan; spasi ini diganti dengan huruf camel case atau garis bawah yang sesuai. |
canonical_name='DFA Analytics' |
description |
Deskripsi singkat API. Hal ini diekspos di layanan penemuan untuk mendeskripsikan API Anda, dan secara opsional juga dapat digunakan untuk membuat dokumentasi seperti yang dijelaskan dalam Membuat library klien. | description='Sample API for a simple game' |
documentation |
Opsional. URL tempat pengguna dapat menemukan dokumentasi tentang versi API ini. Hal ini ditampilkan dalam sorotan "Pelajari Lebih Lanjut" API Explorer di bagian atas halaman API Explorer agar pengguna dapat mempelajari layanan Anda. | documentation='http://link_to/docs' |
hostname |
Nama host aplikasi App Engine Anda. Alat command line Endpoints Frameworks menggunakan nilai yang Anda tentukan di sini saat menghasilkan dokumen Discovery atau dokumen OpenAPI. Jika Anda tidak menentukan nama host di sini, Anda harus menentukan nama host di kolom application pada file app.yaml atau menentukan ID project saat men-deploy aplikasi App Engine. |
hostname='your_app_id.appspot.com' |
issuers |
Opsional. Konfigurasi penerbit JWT kustom. Ini harus berupa pemetaan kamus dari nama penerbit ke objek endpoints.Issuer . |
issuers={"auth0": endpoints.Issuer("https://test.auth0.com", "https://test.auth0.com/.well-known/jwks.json")} |
name |
Wajib. Nama API, yang digunakan sebagai awalan untuk semua metode dan jalur API. Nilai name :
[a-z][a-z0-9]{0,39} , yaitu nama harus diawali dengan huruf kecil, karakter lainnya harus berupa huruf kecil atau angka, dan panjang maksimumnya adalah 40 karakter. |
name='yourApi' atau name='yourapi' |
limit_definitions |
Opsional. Digunakan untuk menentukan kuota untuk API Anda. Lihat limit_definitions untuk mengetahui informasi selengkapnya. | |
owner_domain |
Opsional. Nama domain entitas yang memiliki API. Digunakan bersama dengan owner_name untuk memberikan petunjuk tentang cara memberi nama library klien dengan benar saat dibuat untuk API ini. (Jalur paket adalah kebalikan dari owner_domain dan package_path jika disediakan. Defaultnya adalah menggunakan appid.apppost.com |
owner_domain='your-company.com' |
owner_name |
Opsional. Nama entitas yang memiliki API. Digunakan bersama dengan owner_domain untuk memberikan petunjuk tentang cara memberi nama library klien dengan benar saat dibuat untuk API ini. |
owner_name='Your-Company' |
package_path |
Opsional. Digunakan untuk lebih mencakup "paket" tempat API ini berada, dengan nilai yang dipisahkan oleh / yang menentukan pengelompokan logis API.Misalnya, menentukan cloud/platform akan menghasilkan jalur library klien yang ditetapkan ke cloud/platform/<ApiName> dan paket library klien yang ditetapkan ke cloud.plaform.<ApiName> . |
package_path='cloud/platform' |
scopes |
Jika tidak diberikan, defaultnya adalah cakupan email (https://www.googleapis.com/auth/userinfo.email ), yang diperlukan untuk OAuth. Anda dapat mengganti ini untuk menentukan cakupan OAuth 2.0 lainnya jika diinginkan. Anda juga dapat mengganti cakupan yang ditentukan di sini untuk metode API tertentu dengan menentukan cakupan yang berbeda dalam dekorator @endpoints.method . Namun, jika Anda menentukan lebih dari satu cakupan, perhatikan bahwa pemeriksaan cakupan akan berhasil jika token dibuat untuk cakupan mana pun yang ditentukan. Untuk mewajibkan beberapa cakupan, tentukan satu string dengan spasi di antara setiap cakupan. |
scopes=['ss0', 'ss1 and_ss2'] |
title |
Opsional. Teks yang ditampilkan di API Explorer sebagai judul API Anda, dan diekspos di layanan penemuan dan direktori. | title='My Backend API' |
version |
Wajib. Menentukan versi Cloud Endpoints Anda. Nilai ini muncul di jalur API Anda. Jika Anda menentukan string versi yang kompatibel dengan standar SemVer, hanya nomor versi utama yang muncul di jalur API saat Anda men-deploy API. Misalnya, API yang disebut echo dengan versi 2.1.0 akan memiliki jalur yang mirip dengan /echo/v2 . Jika Anda mengupdate echo API ke versi 2.2.0 dan men-deploy perubahan yang kompatibel dengan versi lama, jalur akan tetap /echo/v2 . Hal ini memungkinkan Anda memperbarui nomor versi API saat melakukan perubahan yang kompatibel mundur tanpa merusak jalur yang ada untuk klien Anda. Namun, jika Anda mengupdate echo API ke versi 3.0.0 (karena Anda men-deploy perubahan yang menyebabkan gangguan), jalur akan diubah menjadi /echo/v3 . |
version='v1' atau version='2.1.0' |
limit_definitions
Untuk menentukan kuota untuk API, Anda menentukan argumen limit_definitions
opsional ke @endpoints.api
. Untuk
mengonfigurasi kuota, Anda juga harus:
- Instal library Endpoints Frameworks versi 2.4.5 atau yang lebih baru.
- Tambahkan argumen
metric_costs
ke decorator metode untuk setiap metode yang ingin Anda terapkan kuotanya.
Lihat Mengonfigurasi kuota untuk semua langkah yang diperlukan untuk menyiapkan kuota.
Anda menentukan daftar satu atau beberapa instance LimitDefinition
, mirip dengan
berikut:
quota_limits = [
endpoints.LimitDefinition(
"name",
"Display name",
limit)
]
Setiap instance LimitDefinition
harus memiliki nilai berikut:
Elemen | Deskripsi |
---|---|
nama | Nama untuk penghitung permintaan API. Biasanya, ini adalah jenis permintaan (misalnya, “permintaan baca” atau “permintaan tulis”) yang mengidentifikasi kuota secara unik. |
Nama tampilan | Teks yang ditampilkan untuk mengidentifikasi kuota di tab Quotas pada halaman Endpoints > Services. Teks ini juga ditampilkan kepada konsumen API Anda di halaman Kuota IAM & admin dan API & Layanan. Nama tampilan harus maksimal 40 karakter. Untuk tujuan keterbacaan, teks “per menit per project” secara otomatis ditambahkan ke nama tampilan di halaman Kuota. Untuk menjaga konsistensi dengan nama tampilan layanan Google yang tercantum di halaman Kuota yang dilihat konsumen API Anda, sebaiknya gunakan nama tampilan berikut:
|
batas | Nilai bilangan bulat yang merupakan jumlah maksimum permintaan per menit per project konsumen untuk kuota. |
Contoh
quota_limits = [ endpoints.LimitDefinition('read-requests', 'Read Requests', 1000), endpoints.LimitDefinition('list-requests', 'List Requests', 100), endpoints.LimitDefinition('write-requests', 'Write Requests', 50) ] @endpoints.api(name='bookstore', version='v1', limit_definitions=quota_limits)
Client ID dan audiens yang diizinkan
Untuk autentikasi OAuth2, token OAuth2 dikeluarkan untuk client ID tertentu,
yang berarti bahwa client ID ini dapat digunakan untuk membatasi akses ke API Anda.
Saat mendaftarkan aplikasi Android di konsol Google Cloud , Anda akan membuat ID klien untuk aplikasi tersebut. ID klien ini adalah ID yang meminta token OAuth2
dari Google untuk tujuan autentikasi. Saat API backend dilindungi oleh autentikasi, token akses OAuth2 akan dikirim dan dibuka oleh Endpoints Frameworks untuk App Engine, ID klien akan diekstrak dari token, lalu ID tersebut akan dibandingkan dengan daftar ID klien yang dapat diterima yang dideklarasikan backend (daftar allowed_client_ids
).
Daftar allowed_client_ids
harus terdiri dari semua
ID klien yang telah Anda peroleh melalui Google Cloud console untuk web,
Android,
dan aplikasi klien lainnya. Artinya, klien harus diketahui pada waktu pembuatan API. Jika Anda menentukan daftar kosong, tidak ada klien yang dapat mengakses API.
Perhatikan bahwa di setiap metode API tempat Anda ingin memeriksa autentikasi yang tepat, Anda harus memanggil endpoints.get_current_user()
.
Lihat Mengautentikasi pengguna
untuk mengetahui informasi selengkapnya.
Jika menggunakan argumen allowed_client_ids
dan ingin menguji panggilan yang diautentikasi ke API menggunakan API Explorer, Anda harus memberikan client ID-nya dalam daftar allowed_client_ids
dengan menentukan konstanta endpoints.API_EXPLORER_CLIENT_ID
. Perhatikan bahwa jika allowed_client_ids
hanya berisi
endpoints.API_EXPLORER_CLIENT_ID
, dan Anda men-deploy API, API Anda
masih dapat ditemukan dan diakses secara publik di API Explorer.
Tentang audiens
Daftar allowed_client_ids
melindungi backend API dari klien yang tidak sah. Namun, perlindungan lebih lanjut diperlukan untuk melindungi klien, sehingga token autentikasi mereka hanya berfungsi untuk API backend yang dimaksud. Untuk klien Android, mekanisme ini adalah argumen audiences
, yang digunakan untuk menentukan
client ID backend API.
Perhatikan bahwa saat Anda membuat project konsol Google Cloud , ID klien default akan dibuat dan diberi nama secara otomatis untuk digunakan oleh project. Saat Anda mengupload backend API ke App Engine, API tersebut menggunakan client ID tersebut. Ini adalah client ID web yang disebutkan dalam autentikasi API.
Penerbit token autentikasi pihak ketiga
Jika aplikasi Anda menerima token autentikasi yang bukan token ID Google
dan dikeluarkan oleh penerbit pihak ketiga, Anda harus menyetel argumen audiences
dan
issuers
dengan benar di @endpoints.api
untuk memberikan informasi tentang
penerbit pihak ketiga. Contoh:
@endpoints.api(
audiences={'auth0': ['aud-1.auth0.com', 'aud-2.auth0.com']},
issuers={'auth0': endpoints.Issuer('https://test.auth0.com',
'https://test.auth0.com/.well-known/jwks.json')})
class GreetingApi(remote.Service):
Menentukan metode API (@endpoints.method
)
Anda dapat menetapkan setelan audiences
, scopes
, dan allowed_client_ids
untuk seluruh API menggunakan @endpoints.api
, atau untuk metode, menggunakan @endpoints.method
. Jika setelan ini ditentukan di tingkat API dan metode, setelan metode akan menggantikan.
Untuk membuat metode di API, hiasi metode Python yang sesuai dengan @endpoints.method
, dengan memberikan argumen untuk mengonfigurasi penggunaan metode. Misalnya, Anda menentukan class Message
permintaan dan respons yang akan digunakan.
Argumen yang tersedia tercantum dalam tabel berikut:
Argumen @endpoints.method |
Deskripsi | Contoh |
---|---|---|
allowed_client_ids |
Setelan ini menggantikan atribut yang setara yang ditentukan dalam @endpoints.api . Untuk mengetahui informasi selengkapnya, lihat Audiens dan ID klien yang diizinkan. |
['1-web-apps.apps.googleusercontent.com', '2-android-apps.apps.googleusercontent.com'] |
api_key_required |
Opsional. Digunakan untuk membatasi akses ke permintaan yang menyediakan kunci API. | api_key_required=True |
audiences |
Mengganti argumen yang setara yang ditentukan dalam @endpoints.api . Untuk mengetahui informasi selengkapnya, lihat Audiens dan ID klien yang diizinkan. |
['1-web-apps.apps.googleusercontent.com'] |
metric_costs |
Opsional. Menunjukkan bahwa metode memiliki batas kuota. Ini adalah kamus dengan pasangan nilai kunci berikut:
|
metric_costs={'read-requests': 1} |
http_method |
Metode HTTP yang akan digunakan. Jika Anda tidak menyetelnya, 'POST' akan digunakan secara default. |
'GET' |
name |
Nama alternatif untuk metode ini. Nilai name :
|
'yourApi' |
path |
Jalur URI untuk mengakses metode ini. Jika Anda tidak menyetelnya, nama metode Python akan digunakan. Jika Anda berencana untuk menambahkan pengelolaan API, jangan sertakan garis miring di akhir jalur. | 'yourapi/path' |
Class Request Message |
Class Request Message Google Protocol RPC yang akan digunakan dalam panggilan metode. Atau, Anda dapat memberikan nama class. |
YourRequestClass |
Class Response Message |
Class Response Message Google Protocol RPC yang akan digunakan dalam panggilan metode. Atau, Anda dapat memberikan nama class. |
YourResponseClass |
Menggunakan ResourceContainer
untuk argumen string kueri atau jalur
Jika permintaan berisi argumen string kueri atau jalur, Anda tidak dapat menggunakan class Message
sederhana seperti yang dijelaskan dalam
Buat API.
Sebagai gantinya, Anda harus menggunakan class ResourceContainer
, seperti berikut:
Tentukan class
Message
yang memiliki semua argumen yang diteruskan di isi permintaan. Jika tidak ada argumen dalam isi permintaan, Anda tidak perlu menentukan classMessage
: cukup gunakanmessage_types.VoidMessage
.) Misalnya:Tentukan
ResourceContainer
dengan classMessage
yang Anda tentukan di langkah sebelumnya sebagai parameter pertama. Tentukan argumen jalur dan string kueri dalam parameter berikutnya. Contoh:dengan argumen pertama adalah class
Message
untuk data dalam isi permintaan dantimes
adalah angka yang diharapkan dalam jalur atau string kueri yang menyertai permintaan.Berikan
ResourceContainer
ke metode yang menangani permintaan, di parameter pertama yang menggantikan classMessage
permintaan yang seharusnya diberikan di lokasi tersebut. Cuplikan ini menampilkanResourceContainer
danendpoints.method
:Tambahkan parameter
path
seperti yang ditunjukkan, untuk menyertakan API Anda.Jika
ResourceContainer
Anda memiliki argumen wajib, permintaan klien harus menyertakannya dalam string kueri (misalnya,yourApi?times=2
), atau jalur URL (misalnya,yourApi/2
). Namun, agar API Anda menerima nilai argumen menggunakan jalur URL, Anda juga harus menambahkan nama argumen ke jalur API seperti yang ditunjukkan untuk argumen{times}
dipath='yourApi/{times}
.