Хотя Mutate , Search и SearchStream являются наиболее распространёнными методами в API Google Ads, существует множество других методов для конкретных целей. Все сервисы и их API описаны в справочной документации .
Сопоставление буфера протокола RPC с REST
Все конечные точки служб (использующие как REST, так и gRPC) в конечном итоге определяются в файлах .proto пакета служб с использованием языка определения интерфейсов proto3 .
Пример: ListAccessibleCustomers
Например, файл customer_service.proto определяет метод ListAccessibleCustomers , помимо стандартного Mutate . Его аннотация google.api.http описывает, как этот метод сопоставляется с HTTP. Он использует HTTP- GET с пользовательским методом listAccessibleCustomers :
rpc ListAccessibleCustomers(ListAccessibleCustomersRequest) returns (ListAccessibleCustomersResponse) { option (google.api.http) = { get: "/v22/customers:listAccessibleCustomers" }; }
Это соответствует методу REST customers.listAccessibleCustomers .
Пример: CreateCustomerClient
Другой пример из customer_service.proto — метод CreateCustomerClient . Его аннотация google.api.http описывает HTTP-запрос POST с использованием специального глагола createCustomerClient :
rpc CreateCustomerClient(CreateCustomerClientRequest) returns (CreateCustomerClientResponse) { option (google.api.http) = { post: "/v22/customers/{customer_id=*}:createCustomerClient" body: "*" }; option (google.api.method_signature) = "customer_id,customer_client"; }
Это соответствует методу REST customers.createCustomerClient .