クライアントを構成する方法は複数あります。
認証構成
Google Ads API へのアクセスに必要な OAuth 認証情報を管理する方法は複数あります。選択するアプローチは、使用する構成フィールドに影響します。詳しくは、認証ガイドをご覧ください。
YAML ファイルを使用した構成
Google Ads API にリクエストを行うために必要な情報を含む YAML ファイルを、クライアントの初期化時に使用するよう指定できます。このファイルは、load_from_storage メソッドを使用してクライアントが初期化されるときにアクセスされます。このファイルを生成する最も簡単な方法は、GitHub リポジトリから google-ads.yaml の例をコピーし、デベロッパー トークン、更新トークン、クライアント ID、クライアント シークレットなどの認証情報を含めるように変更することです。
パスを指定しない場合、ライブラリは $HOME ディレクトリでファイルを検索します。
from google.ads.googleads.client import GoogleAdsClient
client = GoogleAdsClient.load_from_storage()
google-ads.yaml ファイルの場所を指定するには、メソッドを呼び出すときにパスを文字列として渡します。
from google.ads.googleads.client import GoogleAdsClient
client = GoogleAdsClient.load_from_storage("path/to/google-ads.yaml")
特定の環境変数を定義してパスを指定することもできます。
import os
os.environ["GOOGLE_ADS_CONFIGURATION_FILE_PATH"] = "path/to/google-ads.yaml"
from google.ads.googleads.client import GoogleAdsClient
client = GoogleAdsClient.load_from_storage()
両方の値(メソッドに渡されるパスと環境変数)が指定されている場合、ライブラリはメソッドに渡されるパスを優先します。
環境変数を使用した構成
すべてのクライアント構成を環境変数として保存できます。これは、クライアントの load_from_env メソッドを使用するときに読み取られます。環境変数は、google-ads.yaml ファイルで定義されている変数と同じ名前にする必要がありますが、すべて大文字で、GOOGLE_ADS_ Namespace を接頭辞として付ける必要があります。たとえば、client_id は GOOGLE_ADS_CLIENT_ID として保存する必要があります。
通常、環境変数は $HOME ディレクトリにある .bashrc ファイルや .bash_profile ファイルなどの bash 構成ファイルで定義されます。コマンドラインを使用して定義することもできます。これらの手順は bash を使用していることを前提としています。別のシェルを使用している場合は、使用しているシェルで環境変数を設定する方法に関するドキュメントを参照する必要がある場合があります。
ターミナルを使用して .bashrc ファイルで環境変数を定義する基本的な手順は次のとおりです。
# Append the line "export GOOGLE_ADS_CLIENT_ID=1234567890" to
# the bottom of your .bashrc file.
$ echo "export GOOGLE_ADS_CLIENT_ID=1234567890" >> ~/.bashrc
# Update your bash environment to use the most recently updated
# version of your .bashrc file.
$ src ~/.bashrc
環境変数は、コマンドラインからターミナル インスタンスで直接設定することもできます。
$ export GOOGLE_ADS_CLIENT_ID=1234567890
$ echo $GOOGLE_ADS_CLIENT_ID
1234567890
load_from_env メソッドは、Python の組み込み os モジュールの environ 属性から構成データを読み込みます。例:
os.environ["GOOGLE_ADS_CLIENT_ID"]
環境変数の構成を使用してクライアント インスタンスを初期化する例を次に示します。
from google.ads.googleads.client import GoogleAdsClient
client = GoogleAdsClient.load_from_env()
環境変数を使用して logging を構成するには、構成値が、サンプル google-ads.yaml 構成ファイルの YAML キーの構造と一致する JSON オブジェクトである必要があります。
.bashrc ファイルを使用して設定する例を次に示します。
export GOOGLE_ADS_LOGGING='{
"version": 1,
"disable_existing_loggers": false,
"formatters": {
"default_fmt": {
"format": "[%(asctime)s - %(levelname)s] %(message).5000s",
"datefmt": "%Y-%m-%d %H:%M:%S"
}
},
"handlers": {
"default_handler": {
"class": "logging.StreamHandler",
"formatter": "default_fmt"
}
},
"loggers": {
"": {
"handlers": ["default_handler"],
"level": "INFO"
}
}
}'
YAML 文字列を使用した構成
YAML ファイルをメモリに読み取った場合は、初期化時にクライアントに直接提供できます。これを行うには、load_from_string メソッドを使用します。
from google.ads.googleads.client import GoogleAdsClient
with open("/path/to/yaml", "rb") as handle:
yaml = handle.read()
client = GoogleAdsClient.load_from_string(yaml)
dict を使用した構成
dict を load_from_dict メソッドに直接渡すことができます。次に例を示します。
from google.ads.googleads.client import GoogleAdsClient
credentials = {
"developer_token": "abcdef123456",
"refresh_token": "1//0abcdefghijklABCDEF",
"client_id": "123456-abcdef.apps.googleusercontent.com",
"client_secret": "aBcDeFgHiJkL"}
client = GoogleAdsClient.load_from_dict(credentials)
構成フィールド
クライアント ライブラリ構成は、次のフィールドをサポートしています。
認証
使用する認証アプローチに応じて、これらのフィールド グループのいずれかのみを使用します。
- アプリケーションのデフォルト認証情報を使用する単一ユーザー(ドキュメント)
use_application_default_credentials: 認証にアプリケーションのデフォルト認証情報(ADC)を使用するかどうか。
- OAuth トークンを使用する単一ユーザー(ドキュメント)
client_id: OAuth クライアント ID。client_secret: OAuth クライアント シークレット。refresh_token: 実際の OAuth 更新トークン。
- サービス アカウント(ドキュメント)
json_key_file_path: ローカルの秘密鍵ファイルへのパス。これは、サービス アカウントを使用した認証に使用されます。
ライブラリの動作
これらのフィールドは、ライブラリの動作を決定します。
logging: ロギング構成の詳細をご覧ください。http_proxy: プロキシのドキュメントをご覧ください。use_proto_plus: proto-plus メッセージを使用するかどうか。protobuf メッセージのドキュメントをご覧ください。
リクエスト レベルの構成
developer_token: 必須。API にアクセスするためのデベロッパー トークン。linked_customer_id: リンクされた顧客 ID のドキュメントをご覧ください。login_customer_id: login-customer-id のドキュメントをご覧ください。
環境変数
環境変数を使用してライブラリを構成するには、次のものを使用します。
GOOGLE_ADS_CLIENT_IDGOOGLE_ADS_CLIENT_SECRETGOOGLE_ADS_CONFIGURATION_FILE_PATHGOOGLE_ADS_DEVELOPER_TOKENGOOGLE_ADS_HTTP_PROXYGOOGLE_ADS_JSON_KEY_FILE_PATHGOOGLE_ADS_LINKED_CUSTOMER_IDGOOGLE_ADS_LOGIN_CUSTOMER_IDGOOGLE_ADS_LOGGINGGOOGLE_ADS_REFRESH_TOKENGOOGLE_ADS_USE_PROTO_PLUSGOOGLE_ADS_USE_APPLICATION_DEFAULT_CREDENTIALS
ロギング構成
ロギング フィールド(logging 構成フィールドの下にあるフィールド)は、ライブラリが logging 名前空間のすべてのフィールドを logging.config.dictConfig メソッドに直接渡すため、logging.config 組み込みモジュールから直接派生します。詳細については、ロギング ガイドをご覧ください。
version: スキーマ バージョンを表す整数値。disable_existing_loggers: アプリケーションの他の場所で構成されたロガーを無効にするかどうか。formatters: さまざまな種類のフォーマッタを定義する辞書。handlers: ログの書き込み先と使用するフォーマッタを制御する、さまざまなハンドラを定義する辞書。loggers: ハンドラとログレベルを含む、さまざまなタイプのロガーを定義する辞書。