google-adwords-api 0.17.0 → 0.18.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -13
- data/ChangeLog +5 -0
- data/README.md +3 -3
- data/adwords_api.yml +3 -0
- data/examples/v201509/{campaign_management → advanced_operations}/add_complete_campaigns_using_batch_job.rb +10 -16
- data/examples/v201509/advanced_operations/add_keywords_using_incremental_batch_job.rb +179 -0
- data/examples/v201509/reporting/stream_criteria_report_results.rb +97 -0
- data/lib/adwords_api/api_config.rb +0 -86
- data/lib/adwords_api/batch_job_utils.rb +124 -51
- data/lib/adwords_api/incremental_upload_helper.rb +71 -0
- data/lib/adwords_api/report_header_handler.rb +1 -1
- data/lib/adwords_api/report_stream.rb +64 -0
- data/lib/adwords_api/report_utils.rb +88 -8
- data/lib/adwords_api/version.rb +1 -1
- data/test/adwords_api/test_batch_job_utils.rb +15 -0
- metadata +18 -168
- data/examples/v201502/account_management/create_account.rb +0 -88
- data/examples/v201502/account_management/get_account_changes.rb +0 -139
- data/examples/v201502/account_management/get_account_hierarchy.rb +0 -94
- data/examples/v201502/advanced_operations/add_ad_customizers.rb +0 -184
- data/examples/v201502/advanced_operations/add_ad_group_bid_modifier.rb +0 -101
- data/examples/v201502/advanced_operations/add_click_to_download_ad.rb +0 -133
- data/examples/v201502/advanced_operations/add_text_ad_with_upgraded_urls.rb +0 -134
- data/examples/v201502/advanced_operations/create_and_attach_shared_keyword_set.rb +0 -133
- data/examples/v201502/advanced_operations/find_and_remove_criteria_from_shared_set.rb +0 -166
- data/examples/v201502/advanced_operations/get_ad_group_bid_modifiers.rb +0 -102
- data/examples/v201502/advanced_operations/upload_offline_conversions.rb +0 -113
- data/examples/v201502/advanced_operations/use_shared_bidding_strategy.rb +0 -147
- data/examples/v201502/basic_operations/add_ad_groups.rb +0 -140
- data/examples/v201502/basic_operations/add_campaigns.rb +0 -139
- data/examples/v201502/basic_operations/add_keywords.rb +0 -114
- data/examples/v201502/basic_operations/add_text_ads.rb +0 -109
- data/examples/v201502/basic_operations/get_ad_groups.rb +0 -102
- data/examples/v201502/basic_operations/get_campaigns.rb +0 -97
- data/examples/v201502/basic_operations/get_campaigns_with_awql.rb +0 -89
- data/examples/v201502/basic_operations/get_keywords.rb +0 -108
- data/examples/v201502/basic_operations/get_text_ads.rb +0 -110
- data/examples/v201502/basic_operations/pause_ad.rb +0 -88
- data/examples/v201502/basic_operations/remove_ad.rb +0 -89
- data/examples/v201502/basic_operations/remove_ad_group.rb +0 -85
- data/examples/v201502/basic_operations/remove_campaign.rb +0 -87
- data/examples/v201502/basic_operations/remove_keyword.rb +0 -94
- data/examples/v201502/basic_operations/update_ad_group.rb +0 -85
- data/examples/v201502/basic_operations/update_campaign.rb +0 -86
- data/examples/v201502/basic_operations/update_keyword.rb +0 -106
- data/examples/v201502/campaign_management/add_campaign_labels.rb +0 -82
- data/examples/v201502/campaign_management/add_experiment.rb +0 -162
- data/examples/v201502/campaign_management/add_keywords_in_bulk.rb +0 -153
- data/examples/v201502/campaign_management/get_all_disapproved_ads.rb +0 -97
- data/examples/v201502/campaign_management/get_all_disapproved_ads_with_awql.rb +0 -89
- data/examples/v201502/campaign_management/get_campaigns_by_label.rb +0 -108
- data/examples/v201502/campaign_management/promote_experiment.rb +0 -81
- data/examples/v201502/campaign_management/set_ad_parameters.rb +0 -118
- data/examples/v201502/campaign_management/set_criterion_bid_modifier.rb +0 -104
- data/examples/v201502/campaign_management/validate_text_ad.rb +0 -110
- data/examples/v201502/error_handling/handle_partial_failures.rb +0 -130
- data/examples/v201502/error_handling/handle_policy_violation_error.rb +0 -141
- data/examples/v201502/extensions/add_google_my_business_location_extensions.rb +0 -179
- data/examples/v201502/extensions/add_site_links.rb +0 -164
- data/examples/v201502/extensions/add_site_links_using_feeds.rb +0 -271
- data/examples/v201502/migration/migrate_to_extension_settings.rb +0 -386
- data/examples/v201502/migration/upgrade_ad_url.rb +0 -93
- data/examples/v201502/misc/create_ad_words_session_without_properties_file.rb +0 -92
- data/examples/v201502/misc/get_all_images_and_videos.rb +0 -104
- data/examples/v201502/misc/setup_oauth2.rb +0 -84
- data/examples/v201502/misc/upload_image.rb +0 -93
- data/examples/v201502/misc/use_oauth2_jwt.rb +0 -93
- data/examples/v201502/optimization/estimate_keyword_traffic.rb +0 -146
- data/examples/v201502/optimization/get_keyword_bid_simulations.rb +0 -95
- data/examples/v201502/optimization/get_keyword_ideas.rb +0 -126
- data/examples/v201502/remarketing/add_audience.rb +0 -118
- data/examples/v201502/remarketing/add_conversion_tracker.rb +0 -100
- data/examples/v201502/remarketing/add_rule_based_user_lists.rb +0 -167
- data/examples/v201502/reporting/download_criteria_report.rb +0 -85
- data/examples/v201502/reporting/download_criteria_report_with_awql.rb +0 -84
- data/examples/v201502/reporting/get_report_fields.rb +0 -75
- data/examples/v201502/reporting/parallel_report_download.rb +0 -166
- data/examples/v201502/shopping_campaigns/add_product_partition_tree.rb +0 -267
- data/examples/v201502/shopping_campaigns/add_product_scope.rb +0 -129
- data/examples/v201502/shopping_campaigns/add_shopping_campaign.rb +0 -129
- data/examples/v201502/shopping_campaigns/get_product_category_taxonomy.rb +0 -115
- data/examples/v201502/targeting/add_campaign_targeting_criteria.rb +0 -169
- data/examples/v201502/targeting/add_demographic_targeting_criteria.rb +0 -112
- data/examples/v201502/targeting/get_campaign_targeting_criteria.rb +0 -106
- data/examples/v201502/targeting/get_targetable_languages_and_carriers.rb +0 -89
- data/examples/v201502/targeting/lookup_location.rb +0 -108
- data/lib/adwords_api/v201502/account_label_service.rb +0 -46
- data/lib/adwords_api/v201502/account_label_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_customizer_feed_service.rb +0 -46
- data/lib/adwords_api/v201502/ad_customizer_feed_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_group_ad_service.rb +0 -70
- data/lib/adwords_api/v201502/ad_group_ad_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_group_bid_modifier_service.rb +0 -54
- data/lib/adwords_api/v201502/ad_group_bid_modifier_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_group_criterion_service.rb +0 -62
- data/lib/adwords_api/v201502/ad_group_criterion_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_group_extension_setting_service.rb +0 -54
- data/lib/adwords_api/v201502/ad_group_extension_setting_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_group_feed_service.rb +0 -54
- data/lib/adwords_api/v201502/ad_group_feed_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_group_service.rb +0 -62
- data/lib/adwords_api/v201502/ad_group_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/ad_param_service.rb +0 -46
- data/lib/adwords_api/v201502/ad_param_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/adwords_user_list_service.rb +0 -46
- data/lib/adwords_api/v201502/adwords_user_list_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/bidding_strategy_service.rb +0 -54
- data/lib/adwords_api/v201502/bidding_strategy_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/budget_order_service.rb +0 -54
- data/lib/adwords_api/v201502/budget_order_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/budget_service.rb +0 -54
- data/lib/adwords_api/v201502/budget_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/campaign_criterion_service.rb +0 -54
- data/lib/adwords_api/v201502/campaign_criterion_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/campaign_extension_setting_service.rb +0 -54
- data/lib/adwords_api/v201502/campaign_extension_setting_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/campaign_feed_service.rb +0 -54
- data/lib/adwords_api/v201502/campaign_feed_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/campaign_service.rb +0 -62
- data/lib/adwords_api/v201502/campaign_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/campaign_shared_set_service.rb +0 -46
- data/lib/adwords_api/v201502/campaign_shared_set_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/constant_data_service.rb +0 -102
- data/lib/adwords_api/v201502/constant_data_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/conversion_tracker_service.rb +0 -54
- data/lib/adwords_api/v201502/conversion_tracker_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/customer_extension_setting_service.rb +0 -54
- data/lib/adwords_api/v201502/customer_extension_setting_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/customer_feed_service.rb +0 -54
- data/lib/adwords_api/v201502/customer_feed_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/customer_service.rb +0 -46
- data/lib/adwords_api/v201502/customer_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/customer_sync_service.rb +0 -38
- data/lib/adwords_api/v201502/customer_sync_service_registry.rb +0 -47
- data/lib/adwords_api/v201502/data_service.rb +0 -78
- data/lib/adwords_api/v201502/data_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/experiment_service.rb +0 -46
- data/lib/adwords_api/v201502/experiment_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/feed_item_service.rb +0 -54
- data/lib/adwords_api/v201502/feed_item_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/feed_mapping_service.rb +0 -54
- data/lib/adwords_api/v201502/feed_mapping_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/feed_service.rb +0 -54
- data/lib/adwords_api/v201502/feed_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/geo_location_service.rb +0 -38
- data/lib/adwords_api/v201502/geo_location_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/label_service.rb +0 -54
- data/lib/adwords_api/v201502/label_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/location_criterion_service.rb +0 -46
- data/lib/adwords_api/v201502/location_criterion_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/managed_customer_service.rb +0 -78
- data/lib/adwords_api/v201502/managed_customer_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/media_service.rb +0 -54
- data/lib/adwords_api/v201502/media_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/mutate_job_service.rb +0 -54
- data/lib/adwords_api/v201502/mutate_job_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/offline_conversion_feed_service.rb +0 -38
- data/lib/adwords_api/v201502/offline_conversion_feed_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/report_definition_service.rb +0 -38
- data/lib/adwords_api/v201502/report_definition_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/shared_criterion_service.rb +0 -46
- data/lib/adwords_api/v201502/shared_criterion_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/shared_set_service.rb +0 -46
- data/lib/adwords_api/v201502/shared_set_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/targeting_idea_service.rb +0 -38
- data/lib/adwords_api/v201502/targeting_idea_service_registry.rb +0 -46
- data/lib/adwords_api/v201502/traffic_estimator_service.rb +0 -38
- data/lib/adwords_api/v201502/traffic_estimator_service_registry.rb +0 -46
- data/test/templates/v201502/basic_operations_get_campaigns.def +0 -116
- data/test/templates/v201502/misc_use_oauth2_service_account.def +0 -131
@@ -1,110 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# Encoding: utf-8
|
3
|
-
#
|
4
|
-
# Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
|
5
|
-
#
|
6
|
-
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
-
# you may not use this file except in compliance with the License.
|
8
|
-
# You may obtain a copy of the License at
|
9
|
-
#
|
10
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
-
#
|
12
|
-
# Unless required by applicable law or agreed to in writing, software
|
13
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
-
# implied.
|
16
|
-
# See the License for the specific language governing permissions and
|
17
|
-
# limitations under the License.
|
18
|
-
#
|
19
|
-
# This example shows how to use the 'validate only' header. No objects will be
|
20
|
-
# created, but exceptions will still be thrown.
|
21
|
-
|
22
|
-
require 'adwords_api'
|
23
|
-
|
24
|
-
def validate_text_ad(ad_group_id)
|
25
|
-
# AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
|
26
|
-
# when called without parameters.
|
27
|
-
adwords = AdwordsApi::Api.new
|
28
|
-
|
29
|
-
# To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
|
30
|
-
# the configuration file or provide your own logger:
|
31
|
-
# adwords.logger = Logger.new('adwords_xml.log')
|
32
|
-
|
33
|
-
ad_group_ad_srv = adwords.service(:AdGroupAdService, API_VERSION)
|
34
|
-
|
35
|
-
# Enable 'validate only' option.
|
36
|
-
adwords.validate_only = true
|
37
|
-
|
38
|
-
# Prepare for adding text ad.
|
39
|
-
operation = {
|
40
|
-
:operator => 'ADD',
|
41
|
-
:operand => {
|
42
|
-
:ad_group_id => ad_group_id,
|
43
|
-
:ad => {
|
44
|
-
:xsi_type => 'TextAd',
|
45
|
-
:headline => 'Luxury Cruise to Mars',
|
46
|
-
:description1 => 'Visit the Red Planet in style.',
|
47
|
-
:description2 => 'Low-gravity fun for everyone!',
|
48
|
-
:final_urls => ['http://www.example.com'],
|
49
|
-
:display_url => 'www.example.com'
|
50
|
-
}
|
51
|
-
}
|
52
|
-
}
|
53
|
-
|
54
|
-
# Validate text ad add operation.
|
55
|
-
response = ad_group_ad_srv.mutate([operation])
|
56
|
-
if response and response[:value]
|
57
|
-
ad = response[:value].first
|
58
|
-
puts "Unexpected ad creation! Name '%s', ID %d and status '%s'." %
|
59
|
-
[campaign[:name], campaign[:id], campaign[:status]]
|
60
|
-
else
|
61
|
-
puts 'Text ad validated, no error thrown and no ad created.'
|
62
|
-
end
|
63
|
-
|
64
|
-
# Now let's check an invalid ad using extra punctuation to trigger an error.
|
65
|
-
operation[:operand][:ad][:headline] = 'Luxury Cruise to Mars!!!!!'
|
66
|
-
|
67
|
-
# Validate text ad add operation.
|
68
|
-
begin
|
69
|
-
response = ad_group_ad_srv.mutate([operation])
|
70
|
-
if response and response[:value]
|
71
|
-
ad = response[:value].first
|
72
|
-
raise StandardError, ("Unexpected ad creation! Name '%s', ID %d and " +
|
73
|
-
"status '%s'.") % [campaign[:name], campaign[:id], campaign[:status]]
|
74
|
-
end
|
75
|
-
rescue AdwordsApi::Errors::ApiException => e
|
76
|
-
puts "Validation correctly failed with an exception: %s" % e.class
|
77
|
-
end
|
78
|
-
end
|
79
|
-
|
80
|
-
if __FILE__ == $0
|
81
|
-
API_VERSION = :v201502
|
82
|
-
|
83
|
-
begin
|
84
|
-
ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
|
85
|
-
validate_text_ad(ad_group_id)
|
86
|
-
|
87
|
-
# Authorization error.
|
88
|
-
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
89
|
-
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
90
|
-
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
91
|
-
"to retrieve and store OAuth2 tokens."
|
92
|
-
puts "See this wiki page for more details:\n\n " +
|
93
|
-
'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
|
94
|
-
|
95
|
-
# HTTP errors.
|
96
|
-
rescue AdsCommon::Errors::HttpError => e
|
97
|
-
puts "HTTP Error: %s" % e
|
98
|
-
|
99
|
-
# API errors.
|
100
|
-
rescue AdwordsApi::Errors::ApiException => e
|
101
|
-
puts "Message: %s" % e.message
|
102
|
-
puts 'Errors:'
|
103
|
-
e.errors.each_with_index do |error, index|
|
104
|
-
puts "\tError [%d]:" % (index + 1)
|
105
|
-
error.each do |field, value|
|
106
|
-
puts "\t\t%s: %s" % [field, value]
|
107
|
-
end
|
108
|
-
end
|
109
|
-
end
|
110
|
-
end
|
@@ -1,130 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# Encoding: utf-8
|
3
|
-
#
|
4
|
-
# Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
|
5
|
-
#
|
6
|
-
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
-
# you may not use this file except in compliance with the License.
|
8
|
-
# You may obtain a copy of the License at
|
9
|
-
#
|
10
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
-
#
|
12
|
-
# Unless required by applicable law or agreed to in writing, software
|
13
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
-
# implied.
|
16
|
-
# See the License for the specific language governing permissions and
|
17
|
-
# limitations under the License.
|
18
|
-
#
|
19
|
-
# This example demonstrates how to handle partial failures.
|
20
|
-
|
21
|
-
require 'adwords_api'
|
22
|
-
require 'adwords_api/utils'
|
23
|
-
|
24
|
-
def handle_partial_failures(ad_group_id)
|
25
|
-
# AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
|
26
|
-
# when called without parameters.
|
27
|
-
adwords = AdwordsApi::Api.new
|
28
|
-
|
29
|
-
# To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
|
30
|
-
# the configuration file or provide your own logger:
|
31
|
-
# adwords.logger = Logger.new('adwords_xml.log')
|
32
|
-
|
33
|
-
ad_group_criterion_srv =
|
34
|
-
adwords.service(:AdGroupCriterionService, API_VERSION)
|
35
|
-
|
36
|
-
# Set partial failures flag.
|
37
|
-
adwords.partial_failure = true
|
38
|
-
|
39
|
-
# Create keywords.
|
40
|
-
keyword_text = ['mars cruise', 'inv@lid cruise', 'venus cruise',
|
41
|
-
'b(a)d keyword cruise']
|
42
|
-
keywords = []
|
43
|
-
keyword_text.each do |text|
|
44
|
-
keyword = {
|
45
|
-
# The 'xsi_type' field allows you to specify the xsi:type of the object
|
46
|
-
# being created. It's only necessary when you must provide an explicit
|
47
|
-
# type that the client library can't infer.
|
48
|
-
:xsi_type => 'Keyword',
|
49
|
-
:match_type => 'BROAD',
|
50
|
-
:text => text
|
51
|
-
}
|
52
|
-
keywords << keyword
|
53
|
-
end
|
54
|
-
|
55
|
-
# Create biddable ad group criteria and operations.
|
56
|
-
operations = []
|
57
|
-
keywords.each do |kwd|
|
58
|
-
operation = {
|
59
|
-
:operator => 'ADD',
|
60
|
-
:operand => {
|
61
|
-
:xsi_type => 'BiddableAdGroupCriterion',
|
62
|
-
:ad_group_id => ad_group_id,
|
63
|
-
:criterion => kwd
|
64
|
-
}
|
65
|
-
}
|
66
|
-
operations << operation
|
67
|
-
end
|
68
|
-
|
69
|
-
# Add criteria.
|
70
|
-
response = ad_group_criterion_srv.mutate(operations)
|
71
|
-
if response and response[:value]
|
72
|
-
ad_group_criteria = response[:value]
|
73
|
-
ad_group_criteria.each do |ad_group_criterion|
|
74
|
-
if ad_group_criterion[:criterion]
|
75
|
-
puts "Ad group criterion with ad group id " +
|
76
|
-
"#{ad_group_criterion[:ad_group_id]}, criterion id "+
|
77
|
-
"#{ad_group_criterion[:criterion][:id]} and keyword \"" +
|
78
|
-
"#{ad_group_criterion[:criterion][:text]}\" was added."
|
79
|
-
end
|
80
|
-
end
|
81
|
-
else
|
82
|
-
puts "No criteria were added."
|
83
|
-
end
|
84
|
-
|
85
|
-
# Check partial failures.
|
86
|
-
if response and response[:partial_failure_errors]
|
87
|
-
response[:partial_failure_errors].each do |error|
|
88
|
-
operation_index = AdwordsApi::Utils.operation_index_for_error(error)
|
89
|
-
if operation_index
|
90
|
-
ad_group_criterion = operations[operation_index][:operand]
|
91
|
-
puts "Ad group criterion with ad group id " +
|
92
|
-
"#{ad_group_criterion[:ad_group_id]} and keyword \"" +
|
93
|
-
"#{ad_group_criterion[:criterion][:text]}\" triggered an error " +
|
94
|
-
"for the following reason: \"#{error[:error_string]}\"."
|
95
|
-
end
|
96
|
-
end
|
97
|
-
end
|
98
|
-
end
|
99
|
-
|
100
|
-
if __FILE__ == $0
|
101
|
-
API_VERSION = :v201502
|
102
|
-
|
103
|
-
begin
|
104
|
-
ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
|
105
|
-
handle_partial_failures(ad_group_id)
|
106
|
-
|
107
|
-
# Authorization error.
|
108
|
-
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
109
|
-
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
110
|
-
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
111
|
-
"to retrieve and store OAuth2 tokens."
|
112
|
-
puts "See this wiki page for more details:\n\n " +
|
113
|
-
'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
|
114
|
-
|
115
|
-
# HTTP errors.
|
116
|
-
rescue AdsCommon::Errors::HttpError => e
|
117
|
-
puts "HTTP Error: %s" % e
|
118
|
-
|
119
|
-
# API errors.
|
120
|
-
rescue AdwordsApi::Errors::ApiException => e
|
121
|
-
puts "Message: %s" % e.message
|
122
|
-
puts 'Errors:'
|
123
|
-
e.errors.each_with_index do |error, index|
|
124
|
-
puts "\tError [%d]:" % (index + 1)
|
125
|
-
error.each do |field, value|
|
126
|
-
puts "\t\t%s: %s" % [field, value]
|
127
|
-
end
|
128
|
-
end
|
129
|
-
end
|
130
|
-
end
|
@@ -1,141 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# Encoding: utf-8
|
3
|
-
#
|
4
|
-
# Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
|
5
|
-
#
|
6
|
-
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
-
# you may not use this file except in compliance with the License.
|
8
|
-
# You may obtain a copy of the License at
|
9
|
-
#
|
10
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
-
#
|
12
|
-
# Unless required by applicable law or agreed to in writing, software
|
13
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
-
# implied.
|
16
|
-
# See the License for the specific language governing permissions and
|
17
|
-
# limitations under the License.
|
18
|
-
#
|
19
|
-
# This example demonstrates how to handle policy violation errors. To create
|
20
|
-
# an ad group, run add_ad_group.rb.
|
21
|
-
|
22
|
-
require 'adwords_api'
|
23
|
-
require 'adwords_api/utils'
|
24
|
-
|
25
|
-
def handle_policy_violation_error(ad_group_id)
|
26
|
-
# AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
|
27
|
-
# when called without parameters.
|
28
|
-
adwords = AdwordsApi::Api.new
|
29
|
-
|
30
|
-
# To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
|
31
|
-
# the configuration file or provide your own logger:
|
32
|
-
# adwords.logger = Logger.new('adwords_xml.log')
|
33
|
-
|
34
|
-
ad_group_ad_srv = adwords.service(:AdGroupAdService, API_VERSION)
|
35
|
-
|
36
|
-
# Create text ad.
|
37
|
-
text_ad_operation = {
|
38
|
-
:operator => 'ADD',
|
39
|
-
:operand => {
|
40
|
-
:ad_group_id => ad_group_id,
|
41
|
-
:ad => {
|
42
|
-
# The 'xsi_type' field allows you to specify the xsi:type of the object
|
43
|
-
# being created. It's only necessary when you must provide an explicit
|
44
|
-
# type that the client library can't infer.
|
45
|
-
:xsi_type => 'TextAd',
|
46
|
-
:headline => 'Mars Cruise!!!',
|
47
|
-
:description1 => 'Visit the Red Planet in style.',
|
48
|
-
:description2 => 'Low-gravity fun for everyone!',
|
49
|
-
:final_urls => ['http://www.example.com'],
|
50
|
-
:display_url => 'www.example.com',
|
51
|
-
}
|
52
|
-
}
|
53
|
-
}
|
54
|
-
|
55
|
-
operations = [text_ad_operation]
|
56
|
-
|
57
|
-
# Validate ad.
|
58
|
-
begin
|
59
|
-
# Enable "validate only" for the length of this block
|
60
|
-
adwords.validate_only do
|
61
|
-
ad_group_ad_srv.mutate(operations)
|
62
|
-
end
|
63
|
-
puts 'Validation successful, no errors returned.'
|
64
|
-
rescue AdwordsApi::Errors::ApiException => e
|
65
|
-
e.errors.each do |error|
|
66
|
-
if error[:xsi_type] == 'PolicyViolationError'
|
67
|
-
operation_index = AdwordsApi::Utils.operation_index_for_error(error)
|
68
|
-
operation = operations[operation_index]
|
69
|
-
puts "Ad with headline '%s' violated %s policy '%s'." %
|
70
|
-
[operation[:operand][:ad][:headline],
|
71
|
-
error[:is_exemptable] ? 'exemptable' : 'non-exemptable',
|
72
|
-
error[:external_policy_name]]
|
73
|
-
if error[:is_exemptable]
|
74
|
-
# Add exemption request to the operation.
|
75
|
-
puts "Adding exemption request for policy name '%s' on text '%s'." %
|
76
|
-
[error[:key][:policy_name], error[:key][:violating_text]]
|
77
|
-
unless operation[:exemption_requests]
|
78
|
-
operation[:exemption_requests] = []
|
79
|
-
end
|
80
|
-
operation[:exemption_requests] << {
|
81
|
-
:key => error[:key]
|
82
|
-
}
|
83
|
-
else
|
84
|
-
# Remove non-exemptable operation
|
85
|
-
puts "Removing the operation from the request."
|
86
|
-
operations.delete(operation)
|
87
|
-
end
|
88
|
-
else
|
89
|
-
# Non-policy error returned, re-throw exception.
|
90
|
-
raise e
|
91
|
-
end
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
# Add ads.
|
96
|
-
if operations.size > 0
|
97
|
-
response = ad_group_ad_srv.mutate(operations)
|
98
|
-
if response and response[:value]
|
99
|
-
ads = response[:value]
|
100
|
-
puts "Added #{ads.length} ad(s) to ad group #{ad_group_id}."
|
101
|
-
ads.each do |ad|
|
102
|
-
puts " Ad id is #{ad[:ad][:id]}, type is #{ad[:ad][:xsi_type]} and " +
|
103
|
-
"status is \"#{ad[:status]}\"."
|
104
|
-
end
|
105
|
-
else
|
106
|
-
puts "No ads were added."
|
107
|
-
end
|
108
|
-
end
|
109
|
-
end
|
110
|
-
|
111
|
-
if __FILE__ == $0
|
112
|
-
API_VERSION = :v201502
|
113
|
-
|
114
|
-
begin
|
115
|
-
ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
|
116
|
-
handle_policy_violation_error(ad_group_id)
|
117
|
-
|
118
|
-
# Authorization error.
|
119
|
-
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
120
|
-
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
121
|
-
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
122
|
-
"to retrieve and store OAuth2 tokens."
|
123
|
-
puts "See this wiki page for more details:\n\n " +
|
124
|
-
'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
|
125
|
-
|
126
|
-
# HTTP errors.
|
127
|
-
rescue AdsCommon::Errors::HttpError => e
|
128
|
-
puts "HTTP Error: %s" % e
|
129
|
-
|
130
|
-
# API errors.
|
131
|
-
rescue AdwordsApi::Errors::ApiException => e
|
132
|
-
puts "Message: %s" % e.message
|
133
|
-
puts 'Errors:'
|
134
|
-
e.errors.each_with_index do |error, index|
|
135
|
-
puts "\tError [%d]:" % (index + 1)
|
136
|
-
error.each do |field, value|
|
137
|
-
puts "\t\t%s: %s" % [field, value]
|
138
|
-
end
|
139
|
-
end
|
140
|
-
end
|
141
|
-
end
|
@@ -1,179 +0,0 @@
|
|
1
|
-
#!/usr/bin/env ruby
|
2
|
-
# Encoding: utf-8
|
3
|
-
#
|
4
|
-
# Copyright:: Copyright 2014, Google Inc. All Rights Reserved.
|
5
|
-
#
|
6
|
-
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
-
# you may not use this file except in compliance with the License.
|
8
|
-
# You may obtain a copy of the License at
|
9
|
-
#
|
10
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
-
#
|
12
|
-
# Unless required by applicable law or agreed to in writing, software
|
13
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
-
# implied.
|
16
|
-
# See the License for the specific language governing permissions and
|
17
|
-
# limitations under the License.
|
18
|
-
#
|
19
|
-
# This example adds a feed that syncs feed items from a Google My Business (GMB)
|
20
|
-
# account and associates the feed with a customer.
|
21
|
-
|
22
|
-
require 'adwords_api'
|
23
|
-
require 'date'
|
24
|
-
|
25
|
-
def add_gmb_location_extensions(gmb_email_address, gmb_access_token,
|
26
|
-
business_account_identifier)
|
27
|
-
# AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
|
28
|
-
# when called without parameters.
|
29
|
-
adwords = AdwordsApi::Api.new
|
30
|
-
|
31
|
-
# To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
|
32
|
-
# the configuration file or provide your own logger:
|
33
|
-
# adwords.logger = Logger.new('adwords_xml.log')
|
34
|
-
|
35
|
-
feed_srv = adwords.service(:FeedService, API_VERSION)
|
36
|
-
customer_feed_srv = adwords.service(:CustomerFeedService, API_VERSION)
|
37
|
-
|
38
|
-
# Create a feed that will sync to the Google My Business account specified
|
39
|
-
# by gmb_email_address. Do not add FeedAttributes to this object, as AdWords
|
40
|
-
# will add them automatically because this will be a system generated feed.
|
41
|
-
gmb_feed = {
|
42
|
-
:name => "GMB feed #%d" % (Time.new.to_f * 1000).to_i,
|
43
|
-
:system_feed_generation_data => {
|
44
|
-
:xsi_type => 'PlacesLocationFeedData',
|
45
|
-
:o_auth_info => {
|
46
|
-
:http_method => 'GET',
|
47
|
-
:http_request_url => 'https://www.googleapis.com/auth/adwords',
|
48
|
-
:http_authorization_header => "Bearer %s" % gmb_access_token
|
49
|
-
},
|
50
|
-
:email_address => gmb_email_address
|
51
|
-
},
|
52
|
-
# Since this feed's feed items will be managed by AdWords, you must set
|
53
|
-
# its origin to ADWORDS.
|
54
|
-
:origin => 'ADWORDS'
|
55
|
-
}
|
56
|
-
# Only include the business_account_identifier if it's specified.
|
57
|
-
# A nil value will cause an invalid request.
|
58
|
-
unless business_account_identifier.nil?
|
59
|
-
gmb_feed[:system_feed_generation_data][:business_account_identifier] =
|
60
|
-
business_account_identifier
|
61
|
-
end
|
62
|
-
|
63
|
-
gmb_operation = {
|
64
|
-
:operator => 'ADD',
|
65
|
-
:operand => gmb_feed
|
66
|
-
}
|
67
|
-
|
68
|
-
result = feed_srv.mutate([gmb_operation])
|
69
|
-
added_feed = result[:value].first
|
70
|
-
puts "Added GMB feed with ID %d" % added_feed[:id]
|
71
|
-
|
72
|
-
# Add a CustomerFeed that associates the feed with this customer for the
|
73
|
-
# LOCATION placeholder type.
|
74
|
-
customer_feed = {
|
75
|
-
:feed_id => added_feed[:id],
|
76
|
-
:placeholder_types => [PLACEHOLDER_TYPE_LOCATION],
|
77
|
-
:matching_function => {
|
78
|
-
:operator => 'IDENTITY',
|
79
|
-
:lhs_operand => [{
|
80
|
-
:xsi_type => 'ConstantOperand',
|
81
|
-
:type => 'BOOLEAN',
|
82
|
-
:boolean_value => true
|
83
|
-
}]
|
84
|
-
}
|
85
|
-
}
|
86
|
-
|
87
|
-
customer_feed_operation = {
|
88
|
-
:xsi_type => 'CustomerFeedOperation',
|
89
|
-
:operator => 'ADD',
|
90
|
-
:operand => customer_feed
|
91
|
-
}
|
92
|
-
|
93
|
-
added_customer_feed = nil
|
94
|
-
number_of_attempts = 0
|
95
|
-
while i < MAX_CUSTOMER_FEED_ADD_ATTEMPTS && !added_customer_feed
|
96
|
-
number_of_attempts += 1
|
97
|
-
begin
|
98
|
-
result = customer_feed_srv.mutate([customer_feed_operation])
|
99
|
-
added_customer_feed = result[:value].first
|
100
|
-
puts "Attempt #%d to add the CustomerFeed was successful" %
|
101
|
-
number_of_attempts
|
102
|
-
rescue
|
103
|
-
sleep_seconds = 5 * (2 ** number_of_attempts)
|
104
|
-
puts ("Attempt #%d to add the CustomerFeed was not succeessful. " +
|
105
|
-
"Waiting %d seconds before trying again.") %
|
106
|
-
[number_of_attempts, sleep_seconds]
|
107
|
-
sleep(sleep_seconds)
|
108
|
-
end
|
109
|
-
end
|
110
|
-
|
111
|
-
unless added_customer_feed
|
112
|
-
raise StandardError, ("Could not create the CustomerFeed after %d " +
|
113
|
-
"attempts. Please retry the CustomerFeed ADD operation later.") %
|
114
|
-
MAX_CUSTOMER_FEED_ADD_ATTEMPTS
|
115
|
-
end
|
116
|
-
|
117
|
-
puts "Added CustomerFeed for feed ID %d and placeholder type %d" %
|
118
|
-
[added_customer_feed[:id], added_customer_feed[:placeholder_types].first]
|
119
|
-
|
120
|
-
# OPTIONAL: Create a CampaignFeed to specify which FeedItems to use at the
|
121
|
-
# Campaign level. This will be similar to the CampaignFeed in the
|
122
|
-
# add_site_links example, except you can filter based on the business name
|
123
|
-
# and category of each FeedItem by using a FeedAttributeOperand in your
|
124
|
-
# matching function.
|
125
|
-
|
126
|
-
# OPTIONAL: Create an AdGroupFeed for even more fine grained control over
|
127
|
-
# which feed items are used at the AdGroup level.
|
128
|
-
end
|
129
|
-
|
130
|
-
if __FILE__ == $0
|
131
|
-
API_VERSION = :v201502
|
132
|
-
PLACEHOLDER_TYPE_LOCATION = 7
|
133
|
-
MAX_CUSTOMER_FEED_ADD_ATTEMPTS = 10
|
134
|
-
|
135
|
-
begin
|
136
|
-
# The email address of either an owner or a manager of the GMB account.
|
137
|
-
gmb_email_address = 'INSERT_GMB_EMAIL_ADDRESS_HERE'
|
138
|
-
|
139
|
-
# To obtain an access token for your GMB account, generate a refresh token
|
140
|
-
# as you did for AdWords, but make sure you are logged in as the same user
|
141
|
-
# as gmb_email_address above when you follow the link, then capture
|
142
|
-
# the generated access token
|
143
|
-
gmb_access_token = 'INSERT_GMB_OAUTH_ACCESS_TOKEN_HERE'
|
144
|
-
|
145
|
-
# If the gmb_email_address above is for a GMB manager instead of
|
146
|
-
# the GMB account owner, then set business_account_identifier to the
|
147
|
-
# +Page ID of a location for which the manager has access. See the
|
148
|
-
# location extensions guide at
|
149
|
-
# https://developers.google.com/adwords/api/docs/guides/feed-services-locations
|
150
|
-
# for details.
|
151
|
-
business_account_identifier = nil
|
152
|
-
|
153
|
-
add_gmb_location_extensions(gmb_email_address, gmb_access_token,
|
154
|
-
business_account_identifier)
|
155
|
-
|
156
|
-
# Authorization error.
|
157
|
-
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
158
|
-
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
159
|
-
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
160
|
-
"to retrieve and store OAuth2 tokens."
|
161
|
-
puts "See this wiki page for more details:\n\n " +
|
162
|
-
'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
|
163
|
-
|
164
|
-
# HTTP errors.
|
165
|
-
rescue AdsCommon::Errors::HttpError => e
|
166
|
-
puts "HTTP Error: %s" % e
|
167
|
-
|
168
|
-
# API errors.
|
169
|
-
rescue AdwordsApi::Errors::ApiException => e
|
170
|
-
puts "Message: %s" % e.message
|
171
|
-
puts 'Errors:'
|
172
|
-
e.errors.each_with_index do |error, index|
|
173
|
-
puts "\tError [%d]:" % (index + 1)
|
174
|
-
error.each do |field, value|
|
175
|
-
puts "\t\t%s: %s" % [field, value]
|
176
|
-
end
|
177
|
-
end
|
178
|
-
end
|
179
|
-
end
|