配置

Google Ads API PHP 客户端库提供了多个配置设置,您可以使用这些设置来自定义库行为。

配置文件

您可以将大多数这些配置设置存储在 ini 文件中,并在实例化客户端(例如 google_ads_php.ini)时使用这些设置。

凭据构建器和客户端构建器都提供了 fromFile 方法,用于从此类文件加载设置:

$oAuth2Credential = (new OAuth2TokenBuilder())
    ->fromFile('/path/to/google_ads_php.ini')
    ->build();

$googleAdsClient = (new GoogleAdsClientBuilder())
    ->fromFile('/path/to/google_ads_php.ini')
    ->withOAuth2Credential($oAuth2Credential)
    ->build();

如果未以参数的形式提供配置路径,fromFile 方法将从默认配置路径加载,该路径为:

  1. 名为 GOOGLE_ADS_CONFIGURATION_FILE_PATH 的环境变量的值(如果已设置)。
  2. 否则,请使用 HOME 目录中的 google_ads_php.ini 文件。
$oAuth2Credential = (new OAuth2TokenBuilder())
    ->fromFile()
    ->build();

$googleAdsClient = (new GoogleAdsClientBuilder())
    ->fromFile()
    ->withOAuth2Credential($oAuth2Credential)
    ->build();

动态配置

您可以在实例化客户端时动态设置这些配置设置。

$oAuth2Credential = (new OAuth2TokenBuilder())
    ->withClientId('INSERT_CLIENT_ID')
    // ...
    ->build();

$googleAdsClient = (new GoogleAdsClientBuilder())
    ->withOAuth2Credential($oAuth2Credential)
    ->withDeveloperToken('INSERT_DEVELOPER_TOKEN_HERE')
    // ...
    ->build();

配置环境变量

您可以在实例化客户端时通过环境变量设置某些配置设置(请参阅详尽列表)。

凭据构建器和客户端构建器都提供了 fromEnvironmentVariables 方法,用于从环境变量加载设置:

$oAuth2Credential = (new OAuth2TokenBuilder())
    // ...
    ->fromEnvironmentVariables()
    ->build();

$googleAdsClient = (new GoogleAdsClientBuilder())
    ->withOAuth2Credential($oAuth2Credential)
    // ...
    ->fromEnvironmentVariables()
    ->build();

配置字段

配置设置支持按类别整理多个字段。

  1. OAuth2TokenBuilder 使用的字段:
    • 应用模式
      • [OAUTH2] clientId:您的 OAuth2 客户端 ID。
      • [OAUTH2] clientSecret:您的 OAuth2 客户端密钥。
      • [OAUTH2] refreshToken:您的 OAuth2 刷新令牌。
    • 服务账号模式
      • [OAUTH2] jsonKeyFilePath:Json 密钥文件路径。
      • [OAUTH2] scopes:镜重。
      • [OAUTH2] impersonatedEmail:要模拟的电子邮件。
  2. GoogleAdsClientBuilder 使用的字段:
    • [GOOGLE_ADS] developerToken:用于访问 API 的开发者令牌。
    • [GOOGLE_ADS] loginCustomerId:要在请求中使用的已获授权的客户的 ID
    • [GOOGLE_ADS] linkedCustomerId:关联的客户 ID。
    • [LOGGING] logFilePath:用于日志记录的文件路径。
    • [LOGGING] logLevel:日志记录级别。
    • [CONNECTION] proxy:用于互联网连接的代理服务器网址。
    • [CONNECTION] transport:传输方式。
    • [CONNECTION] grpcChannelIsSecure:gRPC 通道是否安全。
    • [CONNECTION] grpcChannelCredential:gRPC 通道凭据。
    • [CONNECTION] unaryMiddlewares:单元操作中间件。
    • [CONNECTION] streamingMiddlewares:流式中间件。
    • [CONNECTION] grpcInterceptors:gRPC 拦截器。

配置验证

系统会在实例化客户端时检查配置设置,并在配置无效时抛出异常。具体规则如下:

  1. 不得同时为应用模式和服务账号模式设置 [OAUTH2] 字段。
  2. 使用服务账号模式时,必须设置 [OAUTH2] jsonKeyFilePath[OAUTH2] scopes
  3. 使用应用模式时,必须设置 [OAUTH2] clientId[OAUTH2] clientSecret[OAUTH2] refreshToken
  4. 必须始终设置 [GOOGLE_ADS] developerToken
  5. 如果设置,[GOOGLE_ADS] loginCustomerId[GOOGLE_ADS] linkedCustomerId 必须为正数。
  6. 如果设置了 [CONNECTION] proxy,则其必须是有效的网址(请参阅过滤条件 FILTER_VALIDATE_URL)。
  7. 如果设置了 [LOGGING] logLevel,则其必须是有效的 PSR 日志级别,且采用大写形式,例如 INFO
  8. 如果设置,[CONNECTION] transport 必须为 grpcrest
  9. 如果 [CONNECTION] transport 设置为 grpc,则环境必须支持 gRPC 传输方式(请参阅指南传输方式)。
  10. 如果 [CONNECTION] transport 未设置为 grpc[CONNECTION] grpcChannelIsSecure 必须为 true
  11. 只有当 [CONNECTION] transport 设置为 grpc 时才能设置 [CONNECTION] grpcChannelCredential
  12. 只有当 [CONNECTION] grpcChannelIsSecuretrue 时才能设置 [CONNECTION] grpcChannelCredential