PHP

Google предоставляет клиентскую библиотеку PHP для взаимодействия с API Менеджера рекламы. Мы рекомендуем использовать клиентскую библиотеку с Composer .

Для начала создайте новый проект в выбранной вами среде IDE или добавьте зависимость к существующему проекту. Google публикует артефакты клиентской библиотеки в Packagist как googleads/ad-manager .

composer require googleads/ad-manager

Настройка учетных данных

Клиентская библиотека PHP использует OAuth2 и учетные данные приложения по умолчанию (ADC) для аутентификации.

ADC ищет учетные данные по порядку в следующих местах:

  1. Переменная среды GOOGLE_APPLICATION_CREDENTIALS .
  2. Учетные данные пользователя, настроенные через Google Cloud CLI (gcloud CLI).
  3. При работе в Google Cloud учетная запись службы привязывается к ресурсу Google Cloud.

Для создания и настройки учетных данных ADC см. раздел Аутентификация .

Сделайте свой первый запрос

Каждая служба имеет объект ServiceClient с методами для каждого метода REST. В следующем примере считывается объект Network .

<?php

use Google\Ads\AdManager\V1\Client\NetworkServiceClient;
use Google\Ads\AdManager\V1\GetNetworkRequest; use Google\Ads\AdManager\V1\Network; use Google\ApiCore\ApiException; /** * API to retrieve a Network object. * * @param string $formattedName Resource name of Network. * Format: networks/{network_code} * Please see {@see NetworkServiceClient::networkName()} for help formatting this field. */ function get_network_sample(string $formattedName): void { // Create a client. $networkServiceClient = new NetworkServiceClient(); // Prepare the request message. $request = (new GetNetworkRequest()) ->setName($formattedName); // Call the API and handle any network failures. try { /** @var Network $response */ $response = $networkServiceClient->getNetwork($request); printf('Response data: %s' . PHP_EOL, $response->serializeToJsonString()); } catch (ApiException $ex) { printf('Call failed with message: %s' . PHP_EOL, $ex->getMessage()); } } /** * Helper to execute the sample. * */ function callSample(): void { $formattedName = NetworkServiceClient::networkName('NETWORK_CODE'); get_network_sample($formattedName); }

Примеры других методов и ресурсов см. в репозитории GitHub googleapis/php-ads-ad-manager .

Регистрировать HTTP-запросы и ответы

Клиентская библиотека PHP поддерживает средства ведения журнала, совместимые с PSR-3, для регистрации HTTP-запросов и ответов. По умолчанию ведение журнала отключено.

Чтобы включить ведение журнала по умолчанию на стандартный вывод, установите для переменной среды GOOGLE_SDK_PHP_LOGGING значение true либо в вашем PHP-коде, либо в вашей среде:

putenv('GOOGLE_SDK_PHP_LOGGING=true');

$client = new NetworkServiceClient();
export GOOGLE_SDK_PHP_LOGGING=true

В качестве альтернативы вы можете передать любой регистратор, совместимый с PSR-3, при создании клиента службы:

use Monolog\Handler\StreamHandler;
use Monolog\Level;
use Monolog\Logger;

$monologLogger = new Logger('sdk client');
$monologLogger->pushHandler(new StreamHandler('php://stdout', Level::Debug));

$client = new NetworkServiceClient([
    'logger' => $monologLogger
]);

Обработка ошибок

В клиентской библиотеке PHP все ошибки API Менеджера рекламы вызывают исключение типа ApiException :

Ошибки разбора

Поле причины ошибки однозначно идентифицирует типы ошибок. Используйте это поле, чтобы определить, как обработать ошибку.

try {
    $response = $networkServiceClient->getNetwork($formattedName);
    printf('Response data: %s' . PHP_EOL, $response->serializeToJsonString());
} catch (ApiException $ex) {
    printf('Error message: %s' . PHP_EOL, $ex->getBasicMessage());
    printf('Reason: %s' . PHP_EOL, $ex->getReason());
}

Ошибки API Менеджера рекламы также включают уникальный request_id , который вы можете предоставить службе поддержки для устранения неполадок. В следующем примере извлекается request_id .

$requestInfo = null;
foreach ($ex->getMetadata() as $metadata) {
    if($metadata["@type"] === "type.googleapis.com/google.rpc.RequestInfo") {
        $requestInfo = $metadata;
        break;
    }
}
if ($requestInfo == null) {
    printf('Unexpected empty RequestInfo');
} else {
    printf('RequestId: %s' . PHP_EOL, $requestInfo['requestId']);
}

Создание имен ресурсов

Клиентская библиотека предоставляет вспомогательные классы для создания имен ресурсов на основе идентификаторов.

use Google\Ads\AdManager\V1\Client\OrderServiceClient;

//  Constructs a String in the format:
//  "networks/{networkCode}/orders/{orderId}"
$orderName = OrderServiceClient::orderName("NETWORK_CODE", "ORDER_ID");

Настройте параметры прокси

Клиентская библиотека PHP учитывает настройки среды HTTP_PROXY и HTTPS_PROXY .