google-adwords-api 0.14.1 → 0.14.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (184) hide show
  1. checksums.yaml +8 -8
  2. data/ChangeLog +3 -0
  3. data/examples/v201406/optimization/estimate_keyword_traffic.rb +30 -12
  4. data/examples/v201409/basic_operations/add_keywords.rb +3 -1
  5. data/examples/v201409/{advanced_operations → extensions}/add_google_my_business_location_extensions.rb +1 -1
  6. data/examples/v201409/extensions/add_site_links.rb +167 -0
  7. data/examples/v201409/{advanced_operations/add_site_links.rb → extensions/add_site_links_using_feeds.rb} +0 -0
  8. data/examples/v201409/migration/migrate_to_extension_settings.rb +365 -0
  9. data/examples/v201409/optimization/estimate_keyword_traffic.rb +30 -13
  10. data/examples/v201502/account_management/create_account.rb +92 -0
  11. data/examples/v201502/account_management/get_account_changes.rb +143 -0
  12. data/examples/v201502/account_management/get_account_hierarchy.rb +98 -0
  13. data/examples/v201502/advanced_operations/add_ad_customizer.rb +277 -0
  14. data/examples/v201502/advanced_operations/add_ad_group_bid_modifier.rb +105 -0
  15. data/examples/v201502/advanced_operations/add_click_to_download_ad.rb +137 -0
  16. data/examples/v201502/advanced_operations/add_text_ad_with_upgraded_urls.rb +137 -0
  17. data/examples/v201502/advanced_operations/create_and_attach_shared_keyword_set.rb +137 -0
  18. data/examples/v201502/advanced_operations/find_and_remove_criteria_from_shared_set.rb +171 -0
  19. data/examples/v201502/advanced_operations/get_ad_group_bid_modifiers.rb +106 -0
  20. data/examples/v201502/advanced_operations/upload_offline_conversions.rb +117 -0
  21. data/examples/v201502/advanced_operations/use_shared_bidding_strategy.rb +152 -0
  22. data/examples/v201502/basic_operations/add_ad_groups.rb +144 -0
  23. data/examples/v201502/basic_operations/add_campaigns.rb +143 -0
  24. data/examples/v201502/basic_operations/add_keywords.rb +118 -0
  25. data/examples/v201502/basic_operations/add_text_ads.rb +113 -0
  26. data/examples/v201502/basic_operations/get_ad_groups.rb +106 -0
  27. data/examples/v201502/basic_operations/get_campaigns.rb +101 -0
  28. data/examples/v201502/basic_operations/get_campaigns_with_awql.rb +93 -0
  29. data/examples/v201502/basic_operations/get_keywords.rb +112 -0
  30. data/examples/v201502/basic_operations/get_text_ads.rb +114 -0
  31. data/examples/v201502/basic_operations/pause_ad.rb +92 -0
  32. data/examples/v201502/basic_operations/remove_ad.rb +93 -0
  33. data/examples/v201502/basic_operations/remove_ad_group.rb +89 -0
  34. data/examples/v201502/basic_operations/remove_campaign.rb +91 -0
  35. data/examples/v201502/basic_operations/remove_keyword.rb +98 -0
  36. data/examples/v201502/basic_operations/update_ad_group.rb +89 -0
  37. data/examples/v201502/basic_operations/update_campaign.rb +90 -0
  38. data/examples/v201502/basic_operations/update_keyword.rb +110 -0
  39. data/examples/v201502/campaign_management/add_campaign_labels.rb +86 -0
  40. data/examples/v201502/campaign_management/add_experiment.rb +166 -0
  41. data/examples/v201502/campaign_management/add_keywords_in_bulk.rb +158 -0
  42. data/examples/v201502/campaign_management/add_location_extension.rb +125 -0
  43. data/examples/v201502/campaign_management/get_all_disapproved_ads.rb +101 -0
  44. data/examples/v201502/campaign_management/get_all_disapproved_ads_with_awql.rb +93 -0
  45. data/examples/v201502/campaign_management/get_campaigns_by_label.rb +112 -0
  46. data/examples/v201502/campaign_management/promote_experiment.rb +85 -0
  47. data/examples/v201502/campaign_management/set_ad_parameters.rb +122 -0
  48. data/examples/v201502/campaign_management/set_criterion_bid_modifier.rb +108 -0
  49. data/examples/v201502/campaign_management/validate_text_ad.rb +114 -0
  50. data/examples/v201502/error_handling/handle_captcha_challenge.rb +93 -0
  51. data/examples/v201502/error_handling/handle_partial_failures.rb +134 -0
  52. data/examples/v201502/error_handling/handle_policy_violation_error.rb +145 -0
  53. data/examples/v201502/error_handling/handle_two_factor_authorization_error.rb +88 -0
  54. data/examples/v201502/extensions/add_google_my_business_location_extensions.rb +183 -0
  55. data/examples/v201502/extensions/add_site_links.rb +167 -0
  56. data/examples/v201502/extensions/add_site_links_using_feeds.rb +306 -0
  57. data/examples/v201502/migration/migrate_to_extension_settings.rb +365 -0
  58. data/examples/v201502/migration/upgrade_ad_url.rb +97 -0
  59. data/examples/v201502/misc/create_ad_words_session_without_properties_file.rb +94 -0
  60. data/examples/v201502/misc/get_all_images_and_videos.rb +108 -0
  61. data/examples/v201502/misc/setup_oauth2.rb +88 -0
  62. data/examples/v201502/misc/upload_image.rb +97 -0
  63. data/examples/v201502/misc/use_oauth2_jwt.rb +97 -0
  64. data/examples/v201502/optimization/estimate_keyword_traffic.rb +155 -0
  65. data/examples/v201502/optimization/get_keyword_bid_simulations.rb +99 -0
  66. data/examples/v201502/optimization/get_keyword_ideas.rb +130 -0
  67. data/examples/v201502/remarketing/add_audience.rb +122 -0
  68. data/examples/v201502/remarketing/add_conversion_tracker.rb +105 -0
  69. data/examples/v201502/remarketing/add_rule_based_user_lists.rb +171 -0
  70. data/examples/v201502/reporting/download_criteria_report.rb +87 -0
  71. data/examples/v201502/reporting/download_criteria_report_with_awql.rb +86 -0
  72. data/examples/v201502/reporting/get_report_fields.rb +79 -0
  73. data/examples/v201502/reporting/parallel_report_download.rb +168 -0
  74. data/examples/v201502/shopping_campaigns/add_product_partition_tree.rb +269 -0
  75. data/examples/v201502/shopping_campaigns/add_product_scope.rb +133 -0
  76. data/examples/v201502/shopping_campaigns/add_shopping_campaign.rb +133 -0
  77. data/examples/v201502/shopping_campaigns/get_product_category_taxonomy.rb +117 -0
  78. data/examples/v201502/targeting/add_campaign_targeting_criteria.rb +173 -0
  79. data/examples/v201502/targeting/add_demographic_targeting_criteria.rb +116 -0
  80. data/examples/v201502/targeting/get_campaign_targeting_criteria.rb +110 -0
  81. data/examples/v201502/targeting/get_targetable_languages_and_carriers.rb +94 -0
  82. data/examples/v201502/targeting/lookup_location.rb +112 -0
  83. data/lib/adwords_api/api_config.rb +98 -4
  84. data/lib/adwords_api/v201409/ad_customizer_feed_service.rb +38 -0
  85. data/lib/adwords_api/v201409/ad_customizer_feed_service_registry.rb +46 -0
  86. data/lib/adwords_api/v201409/ad_group_extension_setting_service.rb +42 -0
  87. data/lib/adwords_api/v201409/ad_group_extension_setting_service_registry.rb +46 -0
  88. data/lib/adwords_api/v201409/campaign_extension_setting_service.rb +42 -0
  89. data/lib/adwords_api/v201409/campaign_extension_setting_service_registry.rb +46 -0
  90. data/lib/adwords_api/v201409/customer_extension_setting_service.rb +42 -0
  91. data/lib/adwords_api/v201409/customer_extension_setting_service_registry.rb +46 -0
  92. data/lib/adwords_api/v201502/account_label_service.rb +38 -0
  93. data/lib/adwords_api/v201502/account_label_service_registry.rb +46 -0
  94. data/lib/adwords_api/v201502/ad_customizer_feed_service.rb +38 -0
  95. data/lib/adwords_api/v201502/ad_customizer_feed_service_registry.rb +46 -0
  96. data/lib/adwords_api/v201502/ad_group_ad_service.rb +50 -0
  97. data/lib/adwords_api/v201502/ad_group_ad_service_registry.rb +46 -0
  98. data/lib/adwords_api/v201502/ad_group_bid_modifier_service.rb +42 -0
  99. data/lib/adwords_api/v201502/ad_group_bid_modifier_service_registry.rb +46 -0
  100. data/lib/adwords_api/v201502/ad_group_criterion_service.rb +46 -0
  101. data/lib/adwords_api/v201502/ad_group_criterion_service_registry.rb +46 -0
  102. data/lib/adwords_api/v201502/ad_group_extension_setting_service.rb +42 -0
  103. data/lib/adwords_api/v201502/ad_group_extension_setting_service_registry.rb +46 -0
  104. data/lib/adwords_api/v201502/ad_group_feed_service.rb +42 -0
  105. data/lib/adwords_api/v201502/ad_group_feed_service_registry.rb +46 -0
  106. data/lib/adwords_api/v201502/ad_group_service.rb +46 -0
  107. data/lib/adwords_api/v201502/ad_group_service_registry.rb +46 -0
  108. data/lib/adwords_api/v201502/ad_param_service.rb +38 -0
  109. data/lib/adwords_api/v201502/ad_param_service_registry.rb +46 -0
  110. data/lib/adwords_api/v201502/adwords_user_list_service.rb +38 -0
  111. data/lib/adwords_api/v201502/adwords_user_list_service_registry.rb +46 -0
  112. data/lib/adwords_api/v201502/bidding_strategy_service.rb +42 -0
  113. data/lib/adwords_api/v201502/bidding_strategy_service_registry.rb +46 -0
  114. data/lib/adwords_api/v201502/budget_order_service.rb +42 -0
  115. data/lib/adwords_api/v201502/budget_order_service_registry.rb +46 -0
  116. data/lib/adwords_api/v201502/budget_service.rb +42 -0
  117. data/lib/adwords_api/v201502/budget_service_registry.rb +46 -0
  118. data/lib/adwords_api/v201502/campaign_criterion_service.rb +42 -0
  119. data/lib/adwords_api/v201502/campaign_criterion_service_registry.rb +46 -0
  120. data/lib/adwords_api/v201502/campaign_extension_setting_service.rb +42 -0
  121. data/lib/adwords_api/v201502/campaign_extension_setting_service_registry.rb +46 -0
  122. data/lib/adwords_api/v201502/campaign_feed_service.rb +42 -0
  123. data/lib/adwords_api/v201502/campaign_feed_service_registry.rb +46 -0
  124. data/lib/adwords_api/v201502/campaign_service.rb +46 -0
  125. data/lib/adwords_api/v201502/campaign_service_registry.rb +46 -0
  126. data/lib/adwords_api/v201502/campaign_shared_set_service.rb +38 -0
  127. data/lib/adwords_api/v201502/campaign_shared_set_service_registry.rb +46 -0
  128. data/lib/adwords_api/v201502/constant_data_service.rb +66 -0
  129. data/lib/adwords_api/v201502/constant_data_service_registry.rb +46 -0
  130. data/lib/adwords_api/v201502/conversion_tracker_service.rb +42 -0
  131. data/lib/adwords_api/v201502/conversion_tracker_service_registry.rb +46 -0
  132. data/lib/adwords_api/v201502/customer_extension_setting_service.rb +42 -0
  133. data/lib/adwords_api/v201502/customer_extension_setting_service_registry.rb +46 -0
  134. data/lib/adwords_api/v201502/customer_feed_service.rb +42 -0
  135. data/lib/adwords_api/v201502/customer_feed_service_registry.rb +46 -0
  136. data/lib/adwords_api/v201502/customer_service.rb +38 -0
  137. data/lib/adwords_api/v201502/customer_service_registry.rb +46 -0
  138. data/lib/adwords_api/v201502/customer_sync_service.rb +34 -0
  139. data/lib/adwords_api/v201502/customer_sync_service_registry.rb +47 -0
  140. data/lib/adwords_api/v201502/data_service.rb +54 -0
  141. data/lib/adwords_api/v201502/data_service_registry.rb +46 -0
  142. data/lib/adwords_api/v201502/experiment_service.rb +38 -0
  143. data/lib/adwords_api/v201502/experiment_service_registry.rb +46 -0
  144. data/lib/adwords_api/v201502/feed_item_service.rb +42 -0
  145. data/lib/adwords_api/v201502/feed_item_service_registry.rb +46 -0
  146. data/lib/adwords_api/v201502/feed_mapping_service.rb +42 -0
  147. data/lib/adwords_api/v201502/feed_mapping_service_registry.rb +46 -0
  148. data/lib/adwords_api/v201502/feed_service.rb +42 -0
  149. data/lib/adwords_api/v201502/feed_service_registry.rb +46 -0
  150. data/lib/adwords_api/v201502/geo_location_service.rb +34 -0
  151. data/lib/adwords_api/v201502/geo_location_service_registry.rb +46 -0
  152. data/lib/adwords_api/v201502/label_service.rb +42 -0
  153. data/lib/adwords_api/v201502/label_service_registry.rb +46 -0
  154. data/lib/adwords_api/v201502/location_criterion_service.rb +38 -0
  155. data/lib/adwords_api/v201502/location_criterion_service_registry.rb +46 -0
  156. data/lib/adwords_api/v201502/managed_customer_service.rb +54 -0
  157. data/lib/adwords_api/v201502/managed_customer_service_registry.rb +46 -0
  158. data/lib/adwords_api/v201502/media_service.rb +42 -0
  159. data/lib/adwords_api/v201502/media_service_registry.rb +46 -0
  160. data/lib/adwords_api/v201502/mutate_job_service.rb +42 -0
  161. data/lib/adwords_api/v201502/mutate_job_service_registry.rb +46 -0
  162. data/lib/adwords_api/v201502/offline_conversion_feed_service.rb +34 -0
  163. data/lib/adwords_api/v201502/offline_conversion_feed_service_registry.rb +46 -0
  164. data/lib/adwords_api/v201502/report_definition_service.rb +34 -0
  165. data/lib/adwords_api/v201502/report_definition_service_registry.rb +46 -0
  166. data/lib/adwords_api/v201502/shared_criterion_service.rb +38 -0
  167. data/lib/adwords_api/v201502/shared_criterion_service_registry.rb +46 -0
  168. data/lib/adwords_api/v201502/shared_set_service.rb +38 -0
  169. data/lib/adwords_api/v201502/shared_set_service_registry.rb +46 -0
  170. data/lib/adwords_api/v201502/targeting_idea_service.rb +34 -0
  171. data/lib/adwords_api/v201502/targeting_idea_service_registry.rb +46 -0
  172. data/lib/adwords_api/v201502/traffic_estimator_service.rb +34 -0
  173. data/lib/adwords_api/v201502/traffic_estimator_service_registry.rb +46 -0
  174. data/lib/adwords_api/version.rb +1 -1
  175. data/test/adwords_api/test_adwords_api.rb +1 -12
  176. data/test/templates/v201406/basic_operations_get_campaigns.def +1 -1
  177. data/test/templates/v201406/misc_use_oauth2_jwt.def +1 -1
  178. data/test/templates/v201409/basic_operations_get_campaigns.def +1 -1
  179. data/test/templates/v201409/misc_use_oauth2_jwt.def +1 -1
  180. data/test/templates/v201502/basic_operations_get_campaigns.def +114 -0
  181. data/test/templates/v201502/misc_use_oauth2_jwt.def +131 -0
  182. metadata +173 -8
  183. data/examples/v201406/advanced_operations/update_site_links.rb +0 -194
  184. data/examples/v201409/advanced_operations/update_site_links.rb +0 -194
@@ -1,194 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # Encoding: utf-8
3
- #
4
- # Author:: api.mcloonan@gmail.com (Michael Cloonan)
5
- #
6
- # Copyright:: Copyright 2013, Google Inc. All Rights Reserved.
7
- #
8
- # License:: Licensed under the Apache License, Version 2.0 (the "License");
9
- # you may not use this file except in compliance with the License.
10
- # You may obtain a copy of the License at
11
- #
12
- # http://www.apache.org/licenses/LICENSE-2.0
13
- #
14
- # Unless required by applicable law or agreed to in writing, software
15
- # distributed under the License is distributed on an "AS IS" BASIS,
16
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
17
- # implied.
18
- # See the License for the specific language governing permissions and
19
- # limitations under the License.
20
- #
21
- # This example updates an existing sitelinks feed as follows:
22
- # * Adds FeedItemAttributes for line 1 and line 2 descriptions to the Feed
23
- # * Populates the new FeedItemAttributes on FeedItems in the Feed
24
- # * Replaces the Feed's existing FeedMapping with one that contains the new
25
- # set of FeedItemAttributes
26
- #
27
- # The end result of this is that any campaign or ad group whose CampaignFeed
28
- # or AdGroupFeed points to the Feed's ID will now serve line 1 and line 2
29
- # descriptions in its sitelinks.
30
- #
31
- # Tags: FeedItemService.mutate
32
- # Tags: FeedMappingService.mutate, FeedService.mutate
33
-
34
- require 'adwords_api'
35
-
36
- def update_site_links(feed_id, feed_item_descriptions)
37
- # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
38
- # when called without parameters.
39
- adwords = AdwordsApi::Api.new
40
-
41
- # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
42
- # the configuration file or provide your own logger:
43
- # adwords.logger = Logger.new('adwords_xml.log')
44
-
45
- feed_srv = adwords.service(:FeedService, API_VERSION)
46
- feed_item_srv = adwords.service(:FeedItemService, API_VERSION)
47
- feed_mapping_srv = adwords.service(:FeedMappingService, API_VERSION)
48
-
49
- feed_selector = {
50
- :fields => ['Id', 'Attributes'],
51
- :predicates => [
52
- {:field => 'Id', :operator => 'EQUALS', :values => [feed_id]}
53
- ]
54
- }
55
-
56
- feed = feed_srv.get(feed_selector)[:entries][0]
57
-
58
- # Add new line1 and line2 feed attributes.
59
- next_attribute_index = feed[:attributes].length()
60
-
61
- feed[:attributes] = [
62
- {:type => 'STRING', :name => 'Line 1 Description'},
63
- {:type => 'STRING', :name => 'Line 2 Description'}
64
- ]
65
-
66
- mutated_feed_result = feed_srv.mutate([
67
- {:operator => 'SET', :operand => feed}
68
- ])
69
-
70
- mutated_feed = mutated_feed_result[:value][0]
71
- line_1_attribute = mutated_feed[:attributes][next_attribute_index]
72
- line_2_attribute = mutated_feed[:attributes][next_attribute_index + 1]
73
-
74
- # Update feed items.
75
- feed_item_ids = feed_item_descriptions.keys
76
- item_selector = {
77
- :fields => ['FeedId', 'FeedItemId', 'AttributeValues'],
78
- :predicates => [
79
- {:field => 'FeedId', :operator => 'EQUALS', :values => [feed_id]},
80
- {:field => 'FeedItemId', :operator => 'IN', :values => feed_item_ids}
81
- ]
82
- }
83
-
84
- feed_items = feed_item_srv.get(item_selector)[:entries]
85
-
86
- item_operations = feed_items.map do |feed_item|
87
- feed_item[:attribute_values] = [
88
- {
89
- :feed_attribute_id => line_1_attribute[:id],
90
- :string_value => feed_item_descriptions[feed_item[:feed_item_id]][0]
91
- },
92
- {
93
- :feed_attribute_id => line_2_attribute[:id],
94
- :string_value => feed_item_descriptions[feed_item[:feed_item_id]][1]
95
- }
96
- ]
97
-
98
- {:operator => 'SET', :operand => feed_item}
99
- end
100
- items_update_result = feed_item_srv.mutate(item_operations)
101
- puts 'Updated %d items' % items_update_result[:value].length
102
-
103
- # Update feed mapping.
104
- mapping_selector = {
105
- :fields => [
106
- 'FeedId',
107
- 'FeedMappingId',
108
- 'PlaceholderType',
109
- 'AttributeFieldMappings'
110
- ],
111
- :predicates => [
112
- {:field => 'FeedId', :operator => 'EQUALS', :values => [feed_id]}
113
- ]
114
- }
115
- feed_mapping_results = feed_mapping_srv.get(mapping_selector)
116
- feed_mapping = feed_mapping_results[:entries][0]
117
-
118
- # Feed mappings are immutable, so we have to delete it and re-add
119
- # it with modifications.
120
- feed_mapping_srv.mutate([
121
- {:operator => 'REMOVE', :operand => feed_mapping}
122
- ])[:value][0]
123
-
124
- feed_mapping[:attribute_field_mappings].push(
125
- {
126
- :feed_attribute_id => line_1_attribute[:id],
127
- :field_id => PLACEHOLDER_FIELD_LINE_1_TEXT
128
- },
129
- {
130
- :feed_attribute_id => line_2_attribute[:id],
131
- :field_id => PLACEHOLDER_FIELD_LINE_2_TEXT
132
- }
133
- )
134
- mapping_update_result = feed_mapping_srv.mutate([
135
- {:operator => 'ADD', :operand => feed_mapping}
136
- ])
137
-
138
- mutated_mapping = mapping_update_result[:value][0]
139
- puts 'Updated field mappings for feedId %d and feedMappingId %d to:' %
140
- [mutated_mapping[:feed_id], mutated_mapping[:feed_mapping_id]]
141
- mutated_mapping[:attribute_field_mappings].each do |field_mapping|
142
- puts "\tfeedAttributeId %d --> fieldId %d" %
143
- [field_mapping[:feed_attribute_id], field_mapping[:field_id]]
144
- end
145
- end
146
-
147
- if __FILE__ == $0
148
- API_VERSION = :v201406
149
-
150
- # See the Placeholder reference page for a list of all the placeholder types
151
- # and fields:
152
- # https://developers.google.com/adwords/api/docs/appendix/placeholders
153
- PLACEHOLDER_FIELD_LINE_1_TEXT = 3
154
- PLACEHOLDER_FIELD_LINE_2_TEXT = 4
155
-
156
- begin
157
- feed_id = 'INSERT_FEED_ID_HERE'.to_i
158
- feed_item_descriptions = {
159
- 'INSERT_FEED_ITEM_A_ID_HERE'.to_i => [
160
- 'INSERT_FEED_ITEM_A_LINE1_DESC_HERE',
161
- 'INSERT_FEED_ITEM_A_LINE2_DESC_HERE'
162
- ],
163
- 'INSERT_FEED_ITEM_B_ID_HERE'.to_i => [
164
- 'INSERT_FEED_ITEM_B_LINE1_DESC_HERE',
165
- 'INSERT_FEED_ITEM_B_LINE2_DESC_HERE'
166
- ]
167
- }
168
-
169
- update_site_links(feed_id, feed_item_descriptions)
170
-
171
- # Authorization error.
172
- rescue AdsCommon::Errors::OAuth2VerificationRequired => e
173
- puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
174
- "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
175
- "to retrieve and store OAuth2 tokens."
176
- puts "See this wiki page for more details:\n\n " +
177
- 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
178
-
179
- # HTTP errors.
180
- rescue AdsCommon::Errors::HttpError => e
181
- puts "HTTP Error: %s" % e
182
-
183
- # API errors.
184
- rescue AdwordsApi::Errors::ApiException => e
185
- puts "Message: %s" % e.message
186
- puts 'Errors:'
187
- e.errors.each_with_index do |error, index|
188
- puts "\tError [%d]:" % (index + 1)
189
- error.each do |field, value|
190
- puts "\t\t%s: %s" % [field, value]
191
- end
192
- end
193
- end
194
- end
@@ -1,194 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # Encoding: utf-8
3
- #
4
- # Author:: api.mcloonan@gmail.com (Michael Cloonan)
5
- #
6
- # Copyright:: Copyright 2013, Google Inc. All Rights Reserved.
7
- #
8
- # License:: Licensed under the Apache License, Version 2.0 (the "License");
9
- # you may not use this file except in compliance with the License.
10
- # You may obtain a copy of the License at
11
- #
12
- # http://www.apache.org/licenses/LICENSE-2.0
13
- #
14
- # Unless required by applicable law or agreed to in writing, software
15
- # distributed under the License is distributed on an "AS IS" BASIS,
16
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
17
- # implied.
18
- # See the License for the specific language governing permissions and
19
- # limitations under the License.
20
- #
21
- # This example updates an existing sitelinks feed as follows:
22
- # * Adds FeedItemAttributes for line 1 and line 2 descriptions to the Feed
23
- # * Populates the new FeedItemAttributes on FeedItems in the Feed
24
- # * Replaces the Feed's existing FeedMapping with one that contains the new
25
- # set of FeedItemAttributes
26
- #
27
- # The end result of this is that any campaign or ad group whose CampaignFeed
28
- # or AdGroupFeed points to the Feed's ID will now serve line 1 and line 2
29
- # descriptions in its sitelinks.
30
- #
31
- # Tags: FeedItemService.mutate
32
- # Tags: FeedMappingService.mutate, FeedService.mutate
33
-
34
- require 'adwords_api'
35
-
36
- def update_site_links(feed_id, feed_item_descriptions)
37
- # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
38
- # when called without parameters.
39
- adwords = AdwordsApi::Api.new
40
-
41
- # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
42
- # the configuration file or provide your own logger:
43
- # adwords.logger = Logger.new('adwords_xml.log')
44
-
45
- feed_srv = adwords.service(:FeedService, API_VERSION)
46
- feed_item_srv = adwords.service(:FeedItemService, API_VERSION)
47
- feed_mapping_srv = adwords.service(:FeedMappingService, API_VERSION)
48
-
49
- feed_selector = {
50
- :fields => ['Id', 'Attributes'],
51
- :predicates => [
52
- {:field => 'Id', :operator => 'EQUALS', :values => [feed_id]}
53
- ]
54
- }
55
-
56
- feed = feed_srv.get(feed_selector)[:entries][0]
57
-
58
- # Add new line1 and line2 feed attributes.
59
- next_attribute_index = feed[:attributes].length()
60
-
61
- feed[:attributes] = [
62
- {:type => 'STRING', :name => 'Line 1 Description'},
63
- {:type => 'STRING', :name => 'Line 2 Description'}
64
- ]
65
-
66
- mutated_feed_result = feed_srv.mutate([
67
- {:operator => 'SET', :operand => feed}
68
- ])
69
-
70
- mutated_feed = mutated_feed_result[:value][0]
71
- line_1_attribute = mutated_feed[:attributes][next_attribute_index]
72
- line_2_attribute = mutated_feed[:attributes][next_attribute_index + 1]
73
-
74
- # Update feed items.
75
- feed_item_ids = feed_item_descriptions.keys
76
- item_selector = {
77
- :fields => ['FeedId', 'FeedItemId', 'AttributeValues'],
78
- :predicates => [
79
- {:field => 'FeedId', :operator => 'EQUALS', :values => [feed_id]},
80
- {:field => 'FeedItemId', :operator => 'IN', :values => feed_item_ids}
81
- ]
82
- }
83
-
84
- feed_items = feed_item_srv.get(item_selector)[:entries]
85
-
86
- item_operations = feed_items.map do |feed_item|
87
- feed_item[:attribute_values] = [
88
- {
89
- :feed_attribute_id => line_1_attribute[:id],
90
- :string_value => feed_item_descriptions[feed_item[:feed_item_id]][0]
91
- },
92
- {
93
- :feed_attribute_id => line_2_attribute[:id],
94
- :string_value => feed_item_descriptions[feed_item[:feed_item_id]][1]
95
- }
96
- ]
97
-
98
- {:operator => 'SET', :operand => feed_item}
99
- end
100
- items_update_result = feed_item_srv.mutate(item_operations)
101
- puts 'Updated %d items' % items_update_result[:value].length
102
-
103
- # Update feed mapping.
104
- mapping_selector = {
105
- :fields => [
106
- 'FeedId',
107
- 'FeedMappingId',
108
- 'PlaceholderType',
109
- 'AttributeFieldMappings'
110
- ],
111
- :predicates => [
112
- {:field => 'FeedId', :operator => 'EQUALS', :values => [feed_id]}
113
- ]
114
- }
115
- feed_mapping_results = feed_mapping_srv.get(mapping_selector)
116
- feed_mapping = feed_mapping_results[:entries][0]
117
-
118
- # Feed mappings are immutable, so we have to delete it and re-add
119
- # it with modifications.
120
- feed_mapping_srv.mutate([
121
- {:operator => 'REMOVE', :operand => feed_mapping}
122
- ])[:value][0]
123
-
124
- feed_mapping[:attribute_field_mappings].push(
125
- {
126
- :feed_attribute_id => line_1_attribute[:id],
127
- :field_id => PLACEHOLDER_FIELD_LINE_1_TEXT
128
- },
129
- {
130
- :feed_attribute_id => line_2_attribute[:id],
131
- :field_id => PLACEHOLDER_FIELD_LINE_2_TEXT
132
- }
133
- )
134
- mapping_update_result = feed_mapping_srv.mutate([
135
- {:operator => 'ADD', :operand => feed_mapping}
136
- ])
137
-
138
- mutated_mapping = mapping_update_result[:value][0]
139
- puts 'Updated field mappings for feedId %d and feedMappingId %d to:' %
140
- [mutated_mapping[:feed_id], mutated_mapping[:feed_mapping_id]]
141
- mutated_mapping[:attribute_field_mappings].each do |field_mapping|
142
- puts "\tfeedAttributeId %d --> fieldId %d" %
143
- [field_mapping[:feed_attribute_id], field_mapping[:field_id]]
144
- end
145
- end
146
-
147
- if __FILE__ == $0
148
- API_VERSION = :v201409
149
-
150
- # See the Placeholder reference page for a list of all the placeholder types
151
- # and fields:
152
- # https://developers.google.com/adwords/api/docs/appendix/placeholders
153
- PLACEHOLDER_FIELD_LINE_1_TEXT = 3
154
- PLACEHOLDER_FIELD_LINE_2_TEXT = 4
155
-
156
- begin
157
- feed_id = 'INSERT_FEED_ID_HERE'.to_i
158
- feed_item_descriptions = {
159
- 'INSERT_FEED_ITEM_A_ID_HERE'.to_i => [
160
- 'INSERT_FEED_ITEM_A_LINE1_DESC_HERE',
161
- 'INSERT_FEED_ITEM_A_LINE2_DESC_HERE'
162
- ],
163
- 'INSERT_FEED_ITEM_B_ID_HERE'.to_i => [
164
- 'INSERT_FEED_ITEM_B_LINE1_DESC_HERE',
165
- 'INSERT_FEED_ITEM_B_LINE2_DESC_HERE'
166
- ]
167
- }
168
-
169
- update_site_links(feed_id, feed_item_descriptions)
170
-
171
- # Authorization error.
172
- rescue AdsCommon::Errors::OAuth2VerificationRequired => e
173
- puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
174
- "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
175
- "to retrieve and store OAuth2 tokens."
176
- puts "See this wiki page for more details:\n\n " +
177
- 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
178
-
179
- # HTTP errors.
180
- rescue AdsCommon::Errors::HttpError => e
181
- puts "HTTP Error: %s" % e
182
-
183
- # API errors.
184
- rescue AdwordsApi::Errors::ApiException => e
185
- puts "Message: %s" % e.message
186
- puts 'Errors:'
187
- e.errors.each_with_index do |error, index|
188
- puts "\tError [%d]:" % (index + 1)
189
- error.each do |field, value|
190
- puts "\t\t%s: %s" % [field, value]
191
- end
192
- end
193
- end
194
- end