.NET

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

Для начала создайте новый проект в выбранной вами среде IDE или добавьте зависимость к существующему проекту. Google публикует артефакты клиентской библиотеки в репозитории NuGet как Google.Ads.AdManager.V1 .

Справочник пакетов

<!-- MyProject.csproj -->
<PackageReference Include="Google.Ads.AdManager.V1" Version="1.0.0-beta01" />

.NET интерфейс командной строки

dotnet add package Google.Ads.AdManager.V1 --version 1.0.0-beta01

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

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

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

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

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

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

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

    using Google.Ads.AdManager.V1;

    public sealed partial class GeneratedNetworkServiceClientSnippets
    {
        public void GetNetwork()
        {
            // Create client
            NetworkServiceClient networkServiceClient = NetworkServiceClient.Create();
            // Initialize request argument(s)
            string name = "networks/[NETWORK_CODE]";
            // Make the request
            Network response = networkServiceClient.GetNetwork(name);
        }
    }

Примеры других методов и ресурсов см. в репозитории GitHub googleapis/google-cloud-dotnet .

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

Все ошибки API Менеджера рекламы имеют тип Grpc.Core.RpcException в клиентской библиотеке .NET.

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

using Google.Ads.AdManager.V1;
using Google.Api.Gax.Grpc;
using Google.Rpc;
using Grpc.Core;

try
{
    NetworkServiceClient networkServiceClient = NetworkServiceClient.Create();
    Network network = networkServiceClient.GetNetwork("networks/[NETWORK_CODE]");
}
catch(RpcException e)
{
    // HTTP Status code
    StatusCode statusCode = e.Status.StatusCode;
    // Error message
    string errorMessage = e.Status.Detail;
    // Unique request identifier.
    RequestInfo requestInfo = e.GetStatusDetail<RequestInfo>();
    string requestId = requestInfo?.RequestId ?? "Unexpected null request identifier";
}

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

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

//  Represents a resource name in the format:
//  "networks/{networkCode}/orders/{orderId}"
OrderName name = OrderName.FromNetworkCodeOrder("123", "456");
Order response = orderServiceClient.GetOrder(name);