В этом руководстве описывается общая структура всех вызовов API.
Если вы используете клиентскую библиотеку для взаимодействия с API, вам не потребуется знать детали базового запроса. Однако некоторые знания о структуре вызовов API могут пригодиться при тестировании и отладке.
Google Ads API — это gRPC API с REST-привязками. Это означает, что существует два способа обращения к API.
Предпочтительно :
Создайте тело запроса в формате Protocol Buffer .
Отправьте его на сервер, используя HTTP/2 .
Десериализуйте ответ в буфер протокола.
Проанализируйте результаты.
Большая часть нашей документации описывает использование gRPC .
Необязательный :
Создайте тело запроса в виде объекта JSON .
Отправьте его на сервер, используя протокол HTTP 1.1.
Десериализуйте ответ в виде объекта JSON.
Проанализируйте результаты.
Для получения дополнительной информации об использовании REST обратитесь к руководству по REST-интерфейсу .
Названия ресурсов
Большинство объектов в API идентифицируются по строковым именам ресурсов. Эти строки также служат в качестве URL-адресов при использовании REST-интерфейса. Структуру имен ресурсов см. в разделе «Имена ресурсов » REST-интерфейса.
Составные идентификаторы
Если идентификатор объекта не является уникальным в глобальном масштабе, для этого объекта создается составной идентификатор путем добавления перед ним идентификатора его родителя и тильды (~).
Например, поскольку идентификатор группы объявлений не является уникальным в глобальном масштабе, мы добавляем к нему идентификатор родительского объекта (группы объявлений), чтобы создать уникальный составной идентификатор:
-
AdGroupIdof123+~+AdGroupAdIdof45678= составной идентификатор группы объявлений123~45678.
Заголовки запроса
Это HTTP-заголовки (или метаданные grpc ), сопровождающие тело запроса:
Авторизация
Необходимо указать токен доступа OAuth2 в формате Authorization: Bearer YOUR_ACCESS_TOKEN , который идентифицирует либо учетную запись менеджера, действующую от имени клиента, либо рекламодателя, непосредственно управляющего своей собственной учетной записью. Инструкции по получению токена доступа можно найти в руководстве по OAuth2 . Токен доступа действителен в течение часа после его получения; по истечении срока действия обновите токен доступа, чтобы получить новый. Обратите внимание, что наши клиентские библиотеки автоматически обновляют просроченные токены.
Если вы столкнулись с ошибками авторизации, убедитесь, что используете правильные учетные данные и имеете достаточные права доступа. Ошибка USER_PERMISSION_DENIED указывает на то, что авторизованный пользователь может не иметь доступа к учетной записи клиента, указанной в запросе. Подробную информацию об управлении правами доступа см. в разделе «Уровни доступа Google Ads» .
токен разработчика
Токен разработчика — это 22-символьная строка, которая однозначно идентифицирует разработчика Google Ads API. Пример строки токена разработчика: ABcdeFGH93KL-NOPQ_STUv . Токен разработчика должен быть представлен в формате developer-token : ABcdeFGH93KL-NOPQ_STUv .
login-customer-id
Это идентификатор клиента, авторизованного для использования в запросе, без дефисов ( - ). Если ваш доступ к учетной записи клиента осуществляется через учетную запись менеджера, этот заголовок обязателен и должен быть установлен на идентификатор клиента учетной записи менеджера. Если вы не укажете login-customer-id при аутентификации через учетную запись менеджера, это приведет к ошибке AuthorizationError.USER_PERMISSION_DENIED . Для получения дополнительной информации об этом типе ошибки см. раздел «Распространенные ошибки ».
https://googleads.googleapis.com/v22/customers/1234567890/campaignBudgets:mutate
Установка параметра login-customer-id эквивалентна выбору учетной записи в пользовательском интерфейсе Google Ads после входа в систему или щелчку по изображению профиля в правом верхнем углу. Если этот заголовок не указан, по умолчанию используется идентификатор работающего клиента .
связанный-идентификатор-клиента
Этот заголовок используется только сторонними поставщиками аналитики приложений при загрузке данных о конверсиях в связанный аккаунт Google Ads .
Рассмотрим сценарий, в котором пользователи учетной записи A предоставляют учетной записи B доступ на чтение и редактирование своих сущностей через ThirdPartyAppAnalyticsLink . После установления связи пользователь учетной записи B может совершать вызовы API к учетной записи A в соответствии с разрешениями, предоставленными ссылкой. В этом случае разрешения на вызовы API для учетной записи A определяются ссылкой стороннего приложения на учетную запись B , а не отношениями между менеджером и учетной записью, которые используются в других вызовах API.
Сторонний поставщик аналитики приложений выполняет вызов API следующим образом:
-
linked-customer-id: Учетная запись стороннего сервиса аналитики приложений, которая загружает данные (учетная записьB). -
customer-id: Аккаунт Google Ads, в который загружаются данные (аккаунтA). - Заголовки
login-customer-idиAuthorization: комбинация значений для идентификации пользователя, имеющего доступ к учетной записиB
Заголовки ответа
В теле ответа возвращаются следующие заголовки (или grpc trailing-metadata ). Рекомендуется записывать эти значения в лог для целей отладки.
идентификатор запроса
request-id — это строка, которая однозначно идентифицирует данный запрос.