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.
Files changed (170) hide show
  1. checksums.yaml +5 -13
  2. data/ChangeLog +5 -0
  3. data/README.md +3 -3
  4. data/adwords_api.yml +3 -0
  5. data/examples/v201509/{campaign_management → advanced_operations}/add_complete_campaigns_using_batch_job.rb +10 -16
  6. data/examples/v201509/advanced_operations/add_keywords_using_incremental_batch_job.rb +179 -0
  7. data/examples/v201509/reporting/stream_criteria_report_results.rb +97 -0
  8. data/lib/adwords_api/api_config.rb +0 -86
  9. data/lib/adwords_api/batch_job_utils.rb +124 -51
  10. data/lib/adwords_api/incremental_upload_helper.rb +71 -0
  11. data/lib/adwords_api/report_header_handler.rb +1 -1
  12. data/lib/adwords_api/report_stream.rb +64 -0
  13. data/lib/adwords_api/report_utils.rb +88 -8
  14. data/lib/adwords_api/version.rb +1 -1
  15. data/test/adwords_api/test_batch_job_utils.rb +15 -0
  16. metadata +18 -168
  17. data/examples/v201502/account_management/create_account.rb +0 -88
  18. data/examples/v201502/account_management/get_account_changes.rb +0 -139
  19. data/examples/v201502/account_management/get_account_hierarchy.rb +0 -94
  20. data/examples/v201502/advanced_operations/add_ad_customizers.rb +0 -184
  21. data/examples/v201502/advanced_operations/add_ad_group_bid_modifier.rb +0 -101
  22. data/examples/v201502/advanced_operations/add_click_to_download_ad.rb +0 -133
  23. data/examples/v201502/advanced_operations/add_text_ad_with_upgraded_urls.rb +0 -134
  24. data/examples/v201502/advanced_operations/create_and_attach_shared_keyword_set.rb +0 -133
  25. data/examples/v201502/advanced_operations/find_and_remove_criteria_from_shared_set.rb +0 -166
  26. data/examples/v201502/advanced_operations/get_ad_group_bid_modifiers.rb +0 -102
  27. data/examples/v201502/advanced_operations/upload_offline_conversions.rb +0 -113
  28. data/examples/v201502/advanced_operations/use_shared_bidding_strategy.rb +0 -147
  29. data/examples/v201502/basic_operations/add_ad_groups.rb +0 -140
  30. data/examples/v201502/basic_operations/add_campaigns.rb +0 -139
  31. data/examples/v201502/basic_operations/add_keywords.rb +0 -114
  32. data/examples/v201502/basic_operations/add_text_ads.rb +0 -109
  33. data/examples/v201502/basic_operations/get_ad_groups.rb +0 -102
  34. data/examples/v201502/basic_operations/get_campaigns.rb +0 -97
  35. data/examples/v201502/basic_operations/get_campaigns_with_awql.rb +0 -89
  36. data/examples/v201502/basic_operations/get_keywords.rb +0 -108
  37. data/examples/v201502/basic_operations/get_text_ads.rb +0 -110
  38. data/examples/v201502/basic_operations/pause_ad.rb +0 -88
  39. data/examples/v201502/basic_operations/remove_ad.rb +0 -89
  40. data/examples/v201502/basic_operations/remove_ad_group.rb +0 -85
  41. data/examples/v201502/basic_operations/remove_campaign.rb +0 -87
  42. data/examples/v201502/basic_operations/remove_keyword.rb +0 -94
  43. data/examples/v201502/basic_operations/update_ad_group.rb +0 -85
  44. data/examples/v201502/basic_operations/update_campaign.rb +0 -86
  45. data/examples/v201502/basic_operations/update_keyword.rb +0 -106
  46. data/examples/v201502/campaign_management/add_campaign_labels.rb +0 -82
  47. data/examples/v201502/campaign_management/add_experiment.rb +0 -162
  48. data/examples/v201502/campaign_management/add_keywords_in_bulk.rb +0 -153
  49. data/examples/v201502/campaign_management/get_all_disapproved_ads.rb +0 -97
  50. data/examples/v201502/campaign_management/get_all_disapproved_ads_with_awql.rb +0 -89
  51. data/examples/v201502/campaign_management/get_campaigns_by_label.rb +0 -108
  52. data/examples/v201502/campaign_management/promote_experiment.rb +0 -81
  53. data/examples/v201502/campaign_management/set_ad_parameters.rb +0 -118
  54. data/examples/v201502/campaign_management/set_criterion_bid_modifier.rb +0 -104
  55. data/examples/v201502/campaign_management/validate_text_ad.rb +0 -110
  56. data/examples/v201502/error_handling/handle_partial_failures.rb +0 -130
  57. data/examples/v201502/error_handling/handle_policy_violation_error.rb +0 -141
  58. data/examples/v201502/extensions/add_google_my_business_location_extensions.rb +0 -179
  59. data/examples/v201502/extensions/add_site_links.rb +0 -164
  60. data/examples/v201502/extensions/add_site_links_using_feeds.rb +0 -271
  61. data/examples/v201502/migration/migrate_to_extension_settings.rb +0 -386
  62. data/examples/v201502/migration/upgrade_ad_url.rb +0 -93
  63. data/examples/v201502/misc/create_ad_words_session_without_properties_file.rb +0 -92
  64. data/examples/v201502/misc/get_all_images_and_videos.rb +0 -104
  65. data/examples/v201502/misc/setup_oauth2.rb +0 -84
  66. data/examples/v201502/misc/upload_image.rb +0 -93
  67. data/examples/v201502/misc/use_oauth2_jwt.rb +0 -93
  68. data/examples/v201502/optimization/estimate_keyword_traffic.rb +0 -146
  69. data/examples/v201502/optimization/get_keyword_bid_simulations.rb +0 -95
  70. data/examples/v201502/optimization/get_keyword_ideas.rb +0 -126
  71. data/examples/v201502/remarketing/add_audience.rb +0 -118
  72. data/examples/v201502/remarketing/add_conversion_tracker.rb +0 -100
  73. data/examples/v201502/remarketing/add_rule_based_user_lists.rb +0 -167
  74. data/examples/v201502/reporting/download_criteria_report.rb +0 -85
  75. data/examples/v201502/reporting/download_criteria_report_with_awql.rb +0 -84
  76. data/examples/v201502/reporting/get_report_fields.rb +0 -75
  77. data/examples/v201502/reporting/parallel_report_download.rb +0 -166
  78. data/examples/v201502/shopping_campaigns/add_product_partition_tree.rb +0 -267
  79. data/examples/v201502/shopping_campaigns/add_product_scope.rb +0 -129
  80. data/examples/v201502/shopping_campaigns/add_shopping_campaign.rb +0 -129
  81. data/examples/v201502/shopping_campaigns/get_product_category_taxonomy.rb +0 -115
  82. data/examples/v201502/targeting/add_campaign_targeting_criteria.rb +0 -169
  83. data/examples/v201502/targeting/add_demographic_targeting_criteria.rb +0 -112
  84. data/examples/v201502/targeting/get_campaign_targeting_criteria.rb +0 -106
  85. data/examples/v201502/targeting/get_targetable_languages_and_carriers.rb +0 -89
  86. data/examples/v201502/targeting/lookup_location.rb +0 -108
  87. data/lib/adwords_api/v201502/account_label_service.rb +0 -46
  88. data/lib/adwords_api/v201502/account_label_service_registry.rb +0 -46
  89. data/lib/adwords_api/v201502/ad_customizer_feed_service.rb +0 -46
  90. data/lib/adwords_api/v201502/ad_customizer_feed_service_registry.rb +0 -46
  91. data/lib/adwords_api/v201502/ad_group_ad_service.rb +0 -70
  92. data/lib/adwords_api/v201502/ad_group_ad_service_registry.rb +0 -46
  93. data/lib/adwords_api/v201502/ad_group_bid_modifier_service.rb +0 -54
  94. data/lib/adwords_api/v201502/ad_group_bid_modifier_service_registry.rb +0 -46
  95. data/lib/adwords_api/v201502/ad_group_criterion_service.rb +0 -62
  96. data/lib/adwords_api/v201502/ad_group_criterion_service_registry.rb +0 -46
  97. data/lib/adwords_api/v201502/ad_group_extension_setting_service.rb +0 -54
  98. data/lib/adwords_api/v201502/ad_group_extension_setting_service_registry.rb +0 -46
  99. data/lib/adwords_api/v201502/ad_group_feed_service.rb +0 -54
  100. data/lib/adwords_api/v201502/ad_group_feed_service_registry.rb +0 -46
  101. data/lib/adwords_api/v201502/ad_group_service.rb +0 -62
  102. data/lib/adwords_api/v201502/ad_group_service_registry.rb +0 -46
  103. data/lib/adwords_api/v201502/ad_param_service.rb +0 -46
  104. data/lib/adwords_api/v201502/ad_param_service_registry.rb +0 -46
  105. data/lib/adwords_api/v201502/adwords_user_list_service.rb +0 -46
  106. data/lib/adwords_api/v201502/adwords_user_list_service_registry.rb +0 -46
  107. data/lib/adwords_api/v201502/bidding_strategy_service.rb +0 -54
  108. data/lib/adwords_api/v201502/bidding_strategy_service_registry.rb +0 -46
  109. data/lib/adwords_api/v201502/budget_order_service.rb +0 -54
  110. data/lib/adwords_api/v201502/budget_order_service_registry.rb +0 -46
  111. data/lib/adwords_api/v201502/budget_service.rb +0 -54
  112. data/lib/adwords_api/v201502/budget_service_registry.rb +0 -46
  113. data/lib/adwords_api/v201502/campaign_criterion_service.rb +0 -54
  114. data/lib/adwords_api/v201502/campaign_criterion_service_registry.rb +0 -46
  115. data/lib/adwords_api/v201502/campaign_extension_setting_service.rb +0 -54
  116. data/lib/adwords_api/v201502/campaign_extension_setting_service_registry.rb +0 -46
  117. data/lib/adwords_api/v201502/campaign_feed_service.rb +0 -54
  118. data/lib/adwords_api/v201502/campaign_feed_service_registry.rb +0 -46
  119. data/lib/adwords_api/v201502/campaign_service.rb +0 -62
  120. data/lib/adwords_api/v201502/campaign_service_registry.rb +0 -46
  121. data/lib/adwords_api/v201502/campaign_shared_set_service.rb +0 -46
  122. data/lib/adwords_api/v201502/campaign_shared_set_service_registry.rb +0 -46
  123. data/lib/adwords_api/v201502/constant_data_service.rb +0 -102
  124. data/lib/adwords_api/v201502/constant_data_service_registry.rb +0 -46
  125. data/lib/adwords_api/v201502/conversion_tracker_service.rb +0 -54
  126. data/lib/adwords_api/v201502/conversion_tracker_service_registry.rb +0 -46
  127. data/lib/adwords_api/v201502/customer_extension_setting_service.rb +0 -54
  128. data/lib/adwords_api/v201502/customer_extension_setting_service_registry.rb +0 -46
  129. data/lib/adwords_api/v201502/customer_feed_service.rb +0 -54
  130. data/lib/adwords_api/v201502/customer_feed_service_registry.rb +0 -46
  131. data/lib/adwords_api/v201502/customer_service.rb +0 -46
  132. data/lib/adwords_api/v201502/customer_service_registry.rb +0 -46
  133. data/lib/adwords_api/v201502/customer_sync_service.rb +0 -38
  134. data/lib/adwords_api/v201502/customer_sync_service_registry.rb +0 -47
  135. data/lib/adwords_api/v201502/data_service.rb +0 -78
  136. data/lib/adwords_api/v201502/data_service_registry.rb +0 -46
  137. data/lib/adwords_api/v201502/experiment_service.rb +0 -46
  138. data/lib/adwords_api/v201502/experiment_service_registry.rb +0 -46
  139. data/lib/adwords_api/v201502/feed_item_service.rb +0 -54
  140. data/lib/adwords_api/v201502/feed_item_service_registry.rb +0 -46
  141. data/lib/adwords_api/v201502/feed_mapping_service.rb +0 -54
  142. data/lib/adwords_api/v201502/feed_mapping_service_registry.rb +0 -46
  143. data/lib/adwords_api/v201502/feed_service.rb +0 -54
  144. data/lib/adwords_api/v201502/feed_service_registry.rb +0 -46
  145. data/lib/adwords_api/v201502/geo_location_service.rb +0 -38
  146. data/lib/adwords_api/v201502/geo_location_service_registry.rb +0 -46
  147. data/lib/adwords_api/v201502/label_service.rb +0 -54
  148. data/lib/adwords_api/v201502/label_service_registry.rb +0 -46
  149. data/lib/adwords_api/v201502/location_criterion_service.rb +0 -46
  150. data/lib/adwords_api/v201502/location_criterion_service_registry.rb +0 -46
  151. data/lib/adwords_api/v201502/managed_customer_service.rb +0 -78
  152. data/lib/adwords_api/v201502/managed_customer_service_registry.rb +0 -46
  153. data/lib/adwords_api/v201502/media_service.rb +0 -54
  154. data/lib/adwords_api/v201502/media_service_registry.rb +0 -46
  155. data/lib/adwords_api/v201502/mutate_job_service.rb +0 -54
  156. data/lib/adwords_api/v201502/mutate_job_service_registry.rb +0 -46
  157. data/lib/adwords_api/v201502/offline_conversion_feed_service.rb +0 -38
  158. data/lib/adwords_api/v201502/offline_conversion_feed_service_registry.rb +0 -46
  159. data/lib/adwords_api/v201502/report_definition_service.rb +0 -38
  160. data/lib/adwords_api/v201502/report_definition_service_registry.rb +0 -46
  161. data/lib/adwords_api/v201502/shared_criterion_service.rb +0 -46
  162. data/lib/adwords_api/v201502/shared_criterion_service_registry.rb +0 -46
  163. data/lib/adwords_api/v201502/shared_set_service.rb +0 -46
  164. data/lib/adwords_api/v201502/shared_set_service_registry.rb +0 -46
  165. data/lib/adwords_api/v201502/targeting_idea_service.rb +0 -38
  166. data/lib/adwords_api/v201502/targeting_idea_service_registry.rb +0 -46
  167. data/lib/adwords_api/v201502/traffic_estimator_service.rb +0 -38
  168. data/lib/adwords_api/v201502/traffic_estimator_service_registry.rb +0 -46
  169. data/test/templates/v201502/basic_operations_get_campaigns.def +0 -116
  170. 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