factories は、オペレーションとリソースを作成するための高レベル インターフェースを提供する
クライアント ライブラリを使用します。
ファクトリ メソッドは、すべてのリソース、列挙型、 オペレーション、サービスタイプが含まれます。
運用
このライブラリでは、client.operation.create_resource.<resource_type>、
client.operation.update_resource.<resource_type>
client.operation.remove_resource.<resource_type>
Google Ads API と連携するオペレーションを簡単に作成できます。
リソースの作成例を次に示します。
campaign_budget_operation = client.operation.create_resource.campaign_budget do |cb|
cb.name = "Interplanetary Budget #{(Time.new.to_f * 1000).to_i}"
cb.delivery_method = :STANDARD
cb.amount_micros = 500000
end
return_budget = client.service.campaign_budget.mutate_campaign_budgets(
customer_id,
[campaign_budget_operation]
)
ブロック cb に生成されるオブジェクトは、
CampaignBudget
変更可能なオブジェクトと、そのプロパティに
CampaignBudgetService が返されます。
同様に、以下を更新するための便利なメソッドも用意されています。
# if you only have a resource name
update_operation = client.operation.update_resource.campaign(campaign_resource_name) do |camp|
camp.status = :PAUSED
end
campaign_service.mutate_campaigns(customer_id, [update_operation])
# if you have a full resource proto
update_operation = client.operation.update_resource.campaign(campaign) do
campaign.name = "A different interplanetary Cruise #{(Time.new.to_f * 1000).to_i}"
end
campaign_service.mutate_campaigns(customer_id, [update_operation])
これらの呼び出しは、正しい形式の update オペレーションを返します。 Google Ads API でリソースを更新するためのフィールド マスクです。
リソースパスを使用してリソースを削除する例を次に示します。
remove_operation = client.operation.remove_resource.campaign(campaign_resource_name)
campaign_service.mutate_campaigns(customer_id, [remove_operation])
ご自身でオペレーションを操作する場合は、未加工オペレーションを取得し、 フィールドに手動で入力します。
operation = client.operation.campaign
リソース
このライブラリでは、client.resource.<resource_type> を使用して、
リソース オブジェクトを初期化します。
campaign.network_settings = client.resource.network_settings do |ns|
ns.target_google_search = true
ns.target_search_network = true
ns.target_content_network = false
ns.target_partner_search_network = false
end
リクエストされたリソースタイプの新しいインスタンスが、 設定します。
サービス
このライブラリでは、client.service.<service_name> を使用して、
サービス オブジェクトを取得します。
campaign_service = client.service.campaign
列挙型
列挙型フィールドを静的に設定するには、シンボル構文を使用することをおすすめします。
(例:campaign.status = :PAUSED)。ただし、すべてのテーブルを列挙したい場合は、
列挙値が有効である場合は、その値を取得するためのメソッドも用意されています。
client.enum.ad_type.each { |x| p x }
:SHOPPING_PRODUCT_AD
:GMAIL_AD
:UNKNOWN
:UNSPECIFIED
:CALL_ONLY_AD
:VIDEO_AD
:IMAGE_AD
:EXPANDED_DYNAMIC_SEARCH_AD
:RESPONSIVE_DISPLAY_AD
:TEXT_AD
:LEGACY_RESPONSIVE_DISPLAY_AD
:LEGACY_APP_INSTALL_AD
:APP_AD
:SHOPPING_SMART_AD
:EXPANDED_TEXT_AD
:HOTEL_AD
:RESPONSIVE_SEARCH_AD
Google Ads API のバージョンを明示的に設定する
バージョンを明示的に設定することもできます。
client.resource.v22.[entity]
client.operation.v22.[operation]
client.service.v22.[service]
client.enum.v22.[enum]