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
方法将从默认配置路径加载,该路径为:
- 名为
GOOGLE_ADS_CONFIGURATION_FILE_PATH
的环境变量的值(如果已设置)。 - 否则,请使用
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();
配置字段
配置设置支持按类别整理多个字段。
OAuth2TokenBuilder
使用的字段:- 应用模式
[OAUTH2] clientId
:您的 OAuth2 客户端 ID。[OAUTH2] clientSecret
:您的 OAuth2 客户端密钥。[OAUTH2] refreshToken
:您的 OAuth2 刷新令牌。
- 服务账号模式
[OAUTH2] jsonKeyFilePath
:Json 密钥文件路径。[OAUTH2] scopes
:镜重。[OAUTH2] impersonatedEmail
:要模拟的电子邮件。
- 应用模式
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 拦截器。
配置验证
系统会在实例化客户端时检查配置设置,并在配置无效时抛出异常。具体规则如下:
- 不得同时为应用模式和服务账号模式设置
[OAUTH2]
字段。 - 使用服务账号模式时,必须设置
[OAUTH2] jsonKeyFilePath
和[OAUTH2] scopes
。 - 使用应用模式时,必须设置
[OAUTH2] clientId
、[OAUTH2] clientSecret
和[OAUTH2] refreshToken
。 - 必须始终设置
[GOOGLE_ADS] developerToken
。 - 如果设置,
[GOOGLE_ADS] loginCustomerId
和[GOOGLE_ADS] linkedCustomerId
必须为正数。 - 如果设置了
[CONNECTION] proxy
,则其必须是有效的网址(请参阅过滤条件 FILTER_VALIDATE_URL)。 - 如果设置了
[LOGGING] logLevel
,则其必须是有效的 PSR 日志级别,且采用大写形式,例如INFO
。 - 如果设置,
[CONNECTION] transport
必须为grpc
或rest
。 - 如果
[CONNECTION] transport
设置为grpc
,则环境必须支持 gRPC 传输方式(请参阅指南传输方式)。 - 如果
[CONNECTION] transport
未设置为grpc
,[CONNECTION] grpcChannelIsSecure
必须为true
。 - 只有当
[CONNECTION] transport
设置为grpc
时才能设置[CONNECTION] grpcChannelCredential
。 - 只有当
[CONNECTION] grpcChannelIsSecure
为true
时才能设置[CONNECTION] grpcChannelCredential
。