google-adwords-api 0.9.2 → 0.9.3

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 (211) hide show
  1. data/ChangeLog +5 -0
  2. data/README +3 -3
  3. data/examples/v201302/account_management/create_account.rb +8 -0
  4. data/examples/v201302/account_management/get_account_alerts.rb +8 -0
  5. data/examples/v201302/account_management/get_account_changes.rb +8 -0
  6. data/examples/v201302/account_management/get_account_hierarchy.rb +8 -0
  7. data/examples/v201302/advanced_operations/add_ad_group_bid_modifier.rb +8 -0
  8. data/examples/v201302/advanced_operations/add_click_to_download_ad.rb +8 -0
  9. data/examples/v201302/advanced_operations/add_site_links.rb +8 -0
  10. data/examples/v201302/advanced_operations/create_and_attach_shared_keyword_set.rb +8 -0
  11. data/examples/v201302/advanced_operations/find_and_remove_criteria_from_shared_set.rb +8 -0
  12. data/examples/v201302/advanced_operations/get_ad_group_bid_modifiers.rb +8 -0
  13. data/examples/v201302/basic_operations/add_ad_groups.rb +8 -0
  14. data/examples/v201302/basic_operations/add_campaigns.rb +8 -0
  15. data/examples/v201302/basic_operations/add_keywords.rb +8 -0
  16. data/examples/v201302/basic_operations/add_text_ads.rb +8 -0
  17. data/examples/v201302/basic_operations/delete_ad.rb +8 -0
  18. data/examples/v201302/basic_operations/delete_ad_group.rb +8 -0
  19. data/examples/v201302/basic_operations/delete_campaign.rb +8 -0
  20. data/examples/v201302/basic_operations/delete_keyword.rb +8 -0
  21. data/examples/v201302/basic_operations/get_ad_groups.rb +8 -0
  22. data/examples/v201302/basic_operations/get_campaigns.rb +8 -0
  23. data/examples/v201302/basic_operations/get_campaigns_with_awql.rb +8 -0
  24. data/examples/v201302/basic_operations/get_keywords.rb +8 -0
  25. data/examples/v201302/basic_operations/get_text_ads.rb +8 -0
  26. data/examples/v201302/basic_operations/pause_ad.rb +8 -0
  27. data/examples/v201302/basic_operations/update_ad_group.rb +8 -0
  28. data/examples/v201302/basic_operations/update_campaign.rb +8 -0
  29. data/examples/v201302/basic_operations/update_keyword.rb +8 -0
  30. data/examples/v201302/campaign_management/add_experiment.rb +8 -0
  31. data/examples/v201302/campaign_management/add_keywords_in_bulk.rb +8 -0
  32. data/examples/v201302/campaign_management/add_location_extension.rb +8 -0
  33. data/examples/v201302/campaign_management/add_location_extension_override.rb +8 -0
  34. data/examples/v201302/campaign_management/get_all_disapproved_ads.rb +8 -0
  35. data/examples/v201302/campaign_management/get_all_disapproved_ads_with_awql.rb +8 -0
  36. data/examples/v201302/campaign_management/promote_experiment.rb +8 -0
  37. data/examples/v201302/campaign_management/set_ad_parameters.rb +8 -0
  38. data/examples/v201302/campaign_management/set_criterion_bid_modifier.rb +8 -0
  39. data/examples/v201302/campaign_management/validate_text_ad.rb +8 -0
  40. data/examples/v201302/error_handling/handle_partial_failures.rb +8 -0
  41. data/examples/v201302/error_handling/handle_policy_violation_error.rb +8 -0
  42. data/examples/v201302/migration/set_campaign_enhanced.rb +8 -0
  43. data/examples/v201302/migration/upgrade_legacy_sitelinks.rb +8 -0
  44. data/examples/v201302/misc/get_all_images_and_videos.rb +8 -0
  45. data/examples/v201302/misc/{use_oauth2.rb → setup_oauth2.rb} +16 -25
  46. data/examples/v201302/misc/upload_image.rb +8 -0
  47. data/examples/v201302/optimization/estimate_keyword_traffic.rb +8 -0
  48. data/examples/v201302/optimization/get_keyword_bid_simulations.rb +8 -0
  49. data/examples/v201302/optimization/get_keyword_ideas.rb +8 -0
  50. data/examples/v201302/optimization/get_placement_ideas.rb +8 -0
  51. data/examples/v201302/remarketing/add_audience.rb +8 -0
  52. data/examples/v201302/remarketing/add_conversion_tracker.rb +8 -0
  53. data/examples/v201302/reporting/download_criteria_report.rb +8 -0
  54. data/examples/v201302/reporting/download_criteria_report_with_awql.rb +8 -0
  55. data/examples/v201302/reporting/get_campaign_stats.rb +8 -0
  56. data/examples/v201302/reporting/get_report_fields.rb +8 -0
  57. data/examples/v201302/reporting/parallel_report_download.rb +8 -0
  58. data/examples/v201302/targeting/add_campaign_targeting_criteria.rb +8 -0
  59. data/examples/v201302/targeting/add_demographic_targeting_criteria.rb +8 -0
  60. data/examples/v201302/targeting/get_campaign_targeting_criteria.rb +8 -0
  61. data/examples/v201302/targeting/get_targetable_languages_and_carriers.rb +8 -0
  62. data/examples/v201302/targeting/lookup_location.rb +8 -0
  63. data/examples/v201306/account_management/create_account.rb +95 -0
  64. data/examples/v201306/account_management/get_account_alerts.rb +122 -0
  65. data/examples/v201306/account_management/get_account_changes.rb +145 -0
  66. data/examples/v201306/account_management/get_account_hierarchy.rb +103 -0
  67. data/examples/v201306/advanced_operations/add_ad_group_bid_modifier.rb +105 -0
  68. data/examples/v201306/advanced_operations/add_click_to_download_ad.rb +137 -0
  69. data/examples/v201306/advanced_operations/add_site_links.rb +244 -0
  70. data/examples/v201306/advanced_operations/create_and_attach_shared_keyword_set.rb +147 -0
  71. data/examples/v201306/advanced_operations/find_and_remove_criteria_from_shared_set.rb +181 -0
  72. data/examples/v201306/advanced_operations/get_ad_group_bid_modifiers.rb +106 -0
  73. data/examples/v201306/basic_operations/add_ad_groups.rb +143 -0
  74. data/examples/v201306/basic_operations/add_campaigns.rb +162 -0
  75. data/examples/v201306/basic_operations/add_keywords.rb +116 -0
  76. data/examples/v201306/basic_operations/add_text_ads.rb +113 -0
  77. data/examples/v201306/basic_operations/delete_ad.rb +93 -0
  78. data/examples/v201306/basic_operations/delete_ad_group.rb +110 -0
  79. data/examples/v201306/basic_operations/delete_campaign.rb +111 -0
  80. data/examples/v201306/basic_operations/delete_keyword.rb +98 -0
  81. data/examples/v201306/basic_operations/get_ad_groups.rb +106 -0
  82. data/examples/v201306/basic_operations/get_campaigns.rb +101 -0
  83. data/examples/v201306/basic_operations/get_campaigns_with_awql.rb +93 -0
  84. data/examples/v201306/basic_operations/get_keywords.rb +112 -0
  85. data/examples/v201306/basic_operations/get_text_ads.rb +114 -0
  86. data/examples/v201306/basic_operations/pause_ad.rb +92 -0
  87. data/examples/v201306/basic_operations/update_ad_group.rb +89 -0
  88. data/examples/v201306/basic_operations/update_campaign.rb +90 -0
  89. data/examples/v201306/basic_operations/update_keyword.rb +110 -0
  90. data/examples/v201306/campaign_management/add_experiment.rb +166 -0
  91. data/examples/v201306/campaign_management/add_keywords_in_bulk.rb +158 -0
  92. data/examples/v201306/campaign_management/add_location_extension.rb +125 -0
  93. data/examples/v201306/campaign_management/add_location_extension_override.rb +91 -0
  94. data/examples/v201306/campaign_management/get_all_disapproved_ads.rb +101 -0
  95. data/examples/v201306/campaign_management/get_all_disapproved_ads_with_awql.rb +92 -0
  96. data/examples/v201306/campaign_management/promote_experiment.rb +85 -0
  97. data/examples/v201306/campaign_management/set_ad_parameters.rb +122 -0
  98. data/examples/v201306/campaign_management/set_criterion_bid_modifier.rb +110 -0
  99. data/examples/v201306/campaign_management/validate_text_ad.rb +114 -0
  100. data/examples/v201306/error_handling/handle_captcha_challenge.rb +93 -0
  101. data/examples/v201306/error_handling/handle_partial_failures.rb +134 -0
  102. data/examples/v201306/error_handling/handle_policy_violation_error.rb +145 -0
  103. data/examples/v201306/error_handling/handle_two_factor_authorization_error.rb +88 -0
  104. data/examples/v201306/migration/upgrade_legacy_sitelinks.rb +313 -0
  105. data/examples/v201306/misc/get_all_images_and_videos.rb +108 -0
  106. data/examples/v201306/misc/setup_oauth2.rb +88 -0
  107. data/examples/v201306/misc/upload_image.rb +97 -0
  108. data/examples/v201306/misc/use_oauth2_jwt.rb +93 -0
  109. data/examples/v201306/optimization/estimate_keyword_traffic.rb +137 -0
  110. data/examples/v201306/optimization/get_keyword_bid_simulations.rb +100 -0
  111. data/examples/v201306/optimization/get_keyword_ideas.rb +130 -0
  112. data/examples/v201306/optimization/get_placement_ideas.rb +112 -0
  113. data/examples/v201306/remarketing/add_audience.rb +123 -0
  114. data/examples/v201306/remarketing/add_conversion_tracker.rb +104 -0
  115. data/examples/v201306/reporting/download_criteria_report.rb +87 -0
  116. data/examples/v201306/reporting/download_criteria_report_with_awql.rb +86 -0
  117. data/examples/v201306/reporting/get_campaign_stats.rb +113 -0
  118. data/examples/v201306/reporting/get_report_fields.rb +79 -0
  119. data/examples/v201306/reporting/parallel_report_download.rb +171 -0
  120. data/examples/v201306/targeting/add_campaign_targeting_criteria.rb +123 -0
  121. data/examples/v201306/targeting/add_demographic_targeting_criteria.rb +116 -0
  122. data/examples/v201306/targeting/get_campaign_targeting_criteria.rb +110 -0
  123. data/examples/v201306/targeting/get_targetable_languages_and_carriers.rb +94 -0
  124. data/examples/v201306/targeting/lookup_location.rb +112 -0
  125. data/lib/adwords_api/api_config.rb +80 -4
  126. data/lib/adwords_api/v201306/ad_extension_override_service.rb +38 -0
  127. data/lib/adwords_api/v201306/ad_extension_override_service_registry.rb +46 -0
  128. data/lib/adwords_api/v201306/ad_group_ad_service.rb +42 -0
  129. data/lib/adwords_api/v201306/ad_group_ad_service_registry.rb +46 -0
  130. data/lib/adwords_api/v201306/ad_group_bid_modifier_service.rb +38 -0
  131. data/lib/adwords_api/v201306/ad_group_bid_modifier_service_registry.rb +46 -0
  132. data/lib/adwords_api/v201306/ad_group_criterion_service.rb +42 -0
  133. data/lib/adwords_api/v201306/ad_group_criterion_service_registry.rb +46 -0
  134. data/lib/adwords_api/v201306/ad_group_feed_service.rb +38 -0
  135. data/lib/adwords_api/v201306/ad_group_feed_service_registry.rb +46 -0
  136. data/lib/adwords_api/v201306/ad_group_service.rb +42 -0
  137. data/lib/adwords_api/v201306/ad_group_service_registry.rb +46 -0
  138. data/lib/adwords_api/v201306/ad_param_service.rb +38 -0
  139. data/lib/adwords_api/v201306/ad_param_service_registry.rb +46 -0
  140. data/lib/adwords_api/v201306/adwords_user_list_service.rb +38 -0
  141. data/lib/adwords_api/v201306/adwords_user_list_service_registry.rb +46 -0
  142. data/lib/adwords_api/v201306/alert_service.rb +34 -0
  143. data/lib/adwords_api/v201306/alert_service_registry.rb +46 -0
  144. data/lib/adwords_api/v201306/bidding_strategy_service.rb +38 -0
  145. data/lib/adwords_api/v201306/bidding_strategy_service_registry.rb +46 -0
  146. data/lib/adwords_api/v201306/budget_order_service.rb +42 -0
  147. data/lib/adwords_api/v201306/budget_order_service_registry.rb +46 -0
  148. data/lib/adwords_api/v201306/budget_service.rb +38 -0
  149. data/lib/adwords_api/v201306/budget_service_registry.rb +46 -0
  150. data/lib/adwords_api/v201306/campaign_ad_extension_service.rb +38 -0
  151. data/lib/adwords_api/v201306/campaign_ad_extension_service_registry.rb +46 -0
  152. data/lib/adwords_api/v201306/campaign_criterion_service.rb +42 -0
  153. data/lib/adwords_api/v201306/campaign_criterion_service_registry.rb +46 -0
  154. data/lib/adwords_api/v201306/campaign_feed_service.rb +38 -0
  155. data/lib/adwords_api/v201306/campaign_feed_service_registry.rb +46 -0
  156. data/lib/adwords_api/v201306/campaign_service.rb +42 -0
  157. data/lib/adwords_api/v201306/campaign_service_registry.rb +46 -0
  158. data/lib/adwords_api/v201306/campaign_shared_set_service.rb +38 -0
  159. data/lib/adwords_api/v201306/campaign_shared_set_service_registry.rb +47 -0
  160. data/lib/adwords_api/v201306/constant_data_service.rb +62 -0
  161. data/lib/adwords_api/v201306/constant_data_service_registry.rb +46 -0
  162. data/lib/adwords_api/v201306/conversion_tracker_service.rb +38 -0
  163. data/lib/adwords_api/v201306/conversion_tracker_service_registry.rb +46 -0
  164. data/lib/adwords_api/v201306/customer_service.rb +34 -0
  165. data/lib/adwords_api/v201306/customer_service_registry.rb +46 -0
  166. data/lib/adwords_api/v201306/customer_sync_service.rb +34 -0
  167. data/lib/adwords_api/v201306/customer_sync_service_registry.rb +47 -0
  168. data/lib/adwords_api/v201306/data_service.rb +38 -0
  169. data/lib/adwords_api/v201306/data_service_registry.rb +46 -0
  170. data/lib/adwords_api/v201306/experiment_service.rb +38 -0
  171. data/lib/adwords_api/v201306/experiment_service_registry.rb +46 -0
  172. data/lib/adwords_api/v201306/feed_item_service.rb +38 -0
  173. data/lib/adwords_api/v201306/feed_item_service_registry.rb +46 -0
  174. data/lib/adwords_api/v201306/feed_mapping_service.rb +38 -0
  175. data/lib/adwords_api/v201306/feed_mapping_service_registry.rb +46 -0
  176. data/lib/adwords_api/v201306/feed_service.rb +38 -0
  177. data/lib/adwords_api/v201306/feed_service_registry.rb +46 -0
  178. data/lib/adwords_api/v201306/geo_location_service.rb +34 -0
  179. data/lib/adwords_api/v201306/geo_location_service_registry.rb +46 -0
  180. data/lib/adwords_api/v201306/location_criterion_service.rb +34 -0
  181. data/lib/adwords_api/v201306/location_criterion_service_registry.rb +46 -0
  182. data/lib/adwords_api/v201306/managed_customer_service.rb +50 -0
  183. data/lib/adwords_api/v201306/managed_customer_service_registry.rb +46 -0
  184. data/lib/adwords_api/v201306/media_service.rb +38 -0
  185. data/lib/adwords_api/v201306/media_service_registry.rb +46 -0
  186. data/lib/adwords_api/v201306/mutate_job_service.rb +42 -0
  187. data/lib/adwords_api/v201306/mutate_job_service_registry.rb +46 -0
  188. data/lib/adwords_api/v201306/report_definition_service.rb +34 -0
  189. data/lib/adwords_api/v201306/report_definition_service_registry.rb +46 -0
  190. data/lib/adwords_api/v201306/shared_criterion_service.rb +38 -0
  191. data/lib/adwords_api/v201306/shared_criterion_service_registry.rb +47 -0
  192. data/lib/adwords_api/v201306/shared_set_service.rb +38 -0
  193. data/lib/adwords_api/v201306/shared_set_service_registry.rb +47 -0
  194. data/lib/adwords_api/v201306/targeting_idea_service.rb +38 -0
  195. data/lib/adwords_api/v201306/targeting_idea_service_registry.rb +46 -0
  196. data/lib/adwords_api/v201306/traffic_estimator_service.rb +34 -0
  197. data/lib/adwords_api/v201306/traffic_estimator_service_registry.rb +46 -0
  198. data/lib/adwords_api/version.rb +1 -1
  199. data/test/adwords_api/test_adwords_api.rb +1 -1
  200. data/test/adwords_api/test_api_config.rb +8 -8
  201. data/test/adwords_api/test_report_utils.rb +1 -1
  202. data/test/bugs/test_issue_00000031.rb +2 -2
  203. data/test/bugs/test_issue_00000063.rb +6 -6
  204. data/test/suite_exampletests_v201302.rb +1 -1
  205. data/test/suite_exampletests_v201306.rb +37 -0
  206. data/test/templates/v201209/basic_operations_get_campaigns.def +1 -1
  207. data/test/templates/v201302/basic_operations_get_campaigns.def +1 -1
  208. data/test/templates/v201302/misc_use_oauth2_jwt.def +1 -1
  209. data/test/templates/v201306/basic_operations_get_campaigns.def +114 -0
  210. data/test/templates/v201306/misc_use_oauth2_jwt.def +131 -0
  211. metadata +142 -5
@@ -0,0 +1,103 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
5
+ #
6
+ # Copyright:: Copyright 2011, 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 illustrates how to retrieve the account hierarchy under an
22
+ # account.
23
+ #
24
+ # Note: This code example uses MCC-level calls and won't work with Test
25
+ # Accounts, see: https://developers.google.com/adwords/api/docs/test-accounts
26
+ #
27
+ # Tags: ManagedCustomerService.get
28
+
29
+ require 'adwords_api'
30
+ require 'adwords_api/utils'
31
+
32
+ def get_account_hierarchy()
33
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
34
+ # when called without parameters.
35
+ adwords = AdwordsApi::Api.new
36
+
37
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
38
+ # the configuration file or provide your own logger:
39
+ # adwords.logger = Logger.new('adwords_xml.log')
40
+
41
+ managed_customer_srv = adwords.service(:ManagedCustomerService, API_VERSION)
42
+
43
+ # Get the account hierarchy for this account.
44
+ selector = {
45
+ :fields => ['Login', 'CustomerId', 'Name']
46
+ }
47
+
48
+ # Run the request at the MCC level.
49
+ graph = adwords.use_mcc() {managed_customer_srv.get(selector)}
50
+
51
+ if graph and graph[:entries]
52
+ puts 'Accounts under this hierarchy: %d' % graph[:total_num_entries]
53
+ graph[:entries].each_with_index do |account, index|
54
+ puts "%d) Customer ID: %s" %
55
+ [index + 1, AdwordsApi::Utils.format_id(account[:customer_id])]
56
+ puts "\tLogin email: %s" % account[:login]
57
+ puts "\tName: %s" % account[:name]
58
+ end
59
+
60
+ # Display the links.
61
+ if graph[:links]
62
+ puts 'Hierarchy links:'
63
+ graph[:links].each do |link|
64
+ puts "\tThere is a link from %s to %s" %
65
+ [AdwordsApi::Utils.format_id(link[:manager_customer_id]),
66
+ AdwordsApi::Utils.format_id(link[:client_customer_id])]
67
+ end
68
+ end
69
+ else
70
+ puts 'No accounts were found.'
71
+ end
72
+ end
73
+
74
+ if __FILE__ == $0
75
+ API_VERSION = :v201306
76
+
77
+ begin
78
+ get_account_hierarchy()
79
+
80
+ # Authorization error.
81
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
82
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
83
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
84
+ "to retrieve and store OAuth2 tokens."
85
+ puts "See this wiki page for more details:\n\n " +
86
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
87
+
88
+ # HTTP errors.
89
+ rescue AdsCommon::Errors::HttpError => e
90
+ puts "HTTP Error: %s" % e
91
+
92
+ # API errors.
93
+ rescue AdwordsApi::Errors::ApiException => e
94
+ puts "Message: %s" % e.message
95
+ puts 'Errors:'
96
+ e.errors.each_with_index do |error, index|
97
+ puts "\tError [%d]:" % (index + 1)
98
+ error.each do |field, value|
99
+ puts "\t\t%s: %s" % [field, value]
100
+ end
101
+ end
102
+ end
103
+ end
@@ -0,0 +1,105 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
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 illustrates how to add an ad group level mobile bid modifier
22
+ # override for a campaign.
23
+ #
24
+ # Tags: AdGroupBidModifierService.mutate
25
+
26
+ require 'adwords_api'
27
+
28
+ def add_ad_group_bid_modifier(ad_group_id, bid_modifier)
29
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
30
+ # when called without parameters.
31
+ adwords = AdwordsApi::Api.new
32
+
33
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
34
+ # the configuration file or provide your own logger:
35
+ # adwords.logger = Logger.new('adwords_xml.log')
36
+
37
+ bid_modifier_srv = adwords.service(:AdGroupBidModifierService, API_VERSION)
38
+
39
+ # Mobile criterion ID.
40
+ criterion_id = 30001
41
+
42
+ # Prepare to add an ad group level override.
43
+ operation = {
44
+ # Use 'ADD' to add a new modifier and 'SET' to update an existing one. A
45
+ # modifier can be removed with the 'REMOVE' operator.
46
+ :operator => 'ADD',
47
+ :operand => {
48
+ :ad_group_id => adgroup_id,
49
+ :criterion => {
50
+ :xsi_type => 'Platform',
51
+ :id => criterion_id
52
+ },
53
+ :bid_modifier => bid_modifier
54
+ }
55
+ }
56
+
57
+ # Add ad group level mobile bid modifier.
58
+ response = bid_modifier_srv.mutate([operation])
59
+ if response and response[:value]
60
+ modifier = response[:value].first
61
+ value = modifier[:bid_modifier] || 'unset'
62
+ puts ('Campaign ID %d, AdGroup ID %d, Criterion ID %d was updated with ' +
63
+ 'ad group level modifier: %s') %
64
+ [modifier[:campaign_id], modifier[:ad_group_id],
65
+ modifier[:criterion][:id], value]
66
+ else
67
+ puts 'No modifiers were added.'
68
+ end
69
+ end
70
+
71
+ if __FILE__ == $0
72
+ API_VERSION = :v201306
73
+
74
+ begin
75
+ # ID of an ad group to add an override for.
76
+ ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
77
+ # Bid modifier to override with.
78
+ bid_modifier = 1.5
79
+
80
+ add_ad_group_bid_modifier(ad_group_id, bid_modifier)
81
+
82
+ # Authorization error.
83
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
84
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
85
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
86
+ "to retrieve and store OAuth2 tokens."
87
+ puts "See this wiki page for more details:\n\n " +
88
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
89
+
90
+ # HTTP errors.
91
+ rescue AdsCommon::Errors::HttpError => e
92
+ puts "HTTP Error: %s" % e
93
+
94
+ # API errors.
95
+ rescue AdwordsApi::Errors::ApiException => e
96
+ puts "Message: %s" % e.message
97
+ puts 'Errors:'
98
+ e.errors.each_with_index do |error, index|
99
+ puts "\tError [%d]:" % (index + 1)
100
+ error.each do |field, value|
101
+ puts "\t\t%s: %s" % [field, value]
102
+ end
103
+ end
104
+ end
105
+ end
@@ -0,0 +1,137 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
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 code example creates a click-to-download ad, also known as an app
22
+ # promotion ad to a given ad group. To list ad groups, run get_ad_groups.rb.
23
+ #
24
+ # Tags: AdGroupAdService.mutate
25
+
26
+ require 'adwords_api'
27
+
28
+ def add_click_to_download_ad(ad_group_id)
29
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
30
+ # when called without parameters.
31
+ adwords = AdwordsApi::Api.new
32
+
33
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
34
+ # the configuration file or provide your own logger:
35
+ # adwords.logger = Logger.new('adwords_xml.log')
36
+
37
+ ad_group_ad_srv = adwords.service(:AdGroupAdService, API_VERSION)
38
+
39
+ # Create the template elements for the ad. You can refer to
40
+ # https://developers.google.com/adwords/api/docs/appendix/templateads
41
+ # for the list of available template fields.
42
+ ad_data = {
43
+ :unique_name => 'adData',
44
+ :fields => [
45
+ {
46
+ :name => 'headline',
47
+ :field_text => 'Enjoy your drive in Mars',
48
+ :type => 'TEXT'
49
+ },
50
+ {
51
+ :name => 'description1',
52
+ :field_text => 'Realistic physics simulation',
53
+ :type => 'TEXT'
54
+ },
55
+ {
56
+ :name => 'description2',
57
+ :field_text => 'Race against players online',
58
+ :type => 'TEXT'
59
+ },
60
+ {
61
+ :name => 'appId',
62
+ :field_text => 'com.example.demogame',
63
+ :type => 'TEXT'
64
+ },
65
+ {
66
+ :name => 'appStore',
67
+ :field_text => '2',
68
+ :type => 'ENUM'
69
+ }
70
+ ]
71
+ }
72
+
73
+ # Create click to download ad.
74
+ click_to_download_app_ad = {
75
+ :xsi_type => 'TemplateAd',
76
+ :name => 'Ad for demo game',
77
+ :template_id => 353,
78
+ :url =>
79
+ 'http://play.google.com/store/apps/details?id=com.example.demogame',
80
+ :display_url => 'play.google.com',
81
+ :template_elements => [ad_data]
82
+ }
83
+
84
+ # Create ad group ad.
85
+ ad_group_ad = {
86
+ :ad_group_id => ad_group_id,
87
+ :ad => click_to_download_app_ad,
88
+ # Optional.
89
+ :status => 'PAUSED'
90
+ }
91
+
92
+ # Add ad.
93
+ response = ad_group_ad_srv.mutate([
94
+ {:operator => 'ADD', :operand => ad_group_ad}
95
+ ])
96
+ if response and response[:value]
97
+ response[:value].each do |ad|
98
+ puts "Added new click-to-download ad to ad group ID %d with url '%s'." %
99
+ [ad[:ad][:id], ad[:ad][:url]]
100
+ end
101
+ else
102
+ raise StandardError, 'No ads were added.'
103
+ end
104
+ end
105
+
106
+ if __FILE__ == $0
107
+ API_VERSION = :v201306
108
+
109
+ begin
110
+ # Ad group ID to add text ads to.
111
+ ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
112
+ add_click_to_download_ad(ad_group_id)
113
+
114
+ # Authorization error.
115
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
116
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
117
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
118
+ "to retrieve and store OAuth2 tokens."
119
+ puts "See this wiki page for more details:\n\n " +
120
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
121
+
122
+ # HTTP errors.
123
+ rescue AdsCommon::Errors::HttpError => e
124
+ puts "HTTP Error: %s" % e
125
+
126
+ # API errors.
127
+ rescue AdwordsApi::Errors::ApiException => e
128
+ puts "Message: %s" % e.message
129
+ puts 'Errors:'
130
+ e.errors.each_with_index do |error, index|
131
+ puts "\tError [%d]:" % (index + 1)
132
+ error.each do |field, value|
133
+ puts "\t\t%s: %s" % [field, value]
134
+ end
135
+ end
136
+ end
137
+ end
@@ -0,0 +1,244 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
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 adds a sitelinks feed and associates it with a campaign.
22
+ #
23
+ # Tags: CampaignFeedService.mutate, FeedItemService.mutate
24
+ # Tags: FeedMappingService.mutate, FeedService.mutate
25
+
26
+ require 'adwords_api'
27
+
28
+ def add_site_links(campaign_id)
29
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
30
+ # when called without parameters.
31
+ adwords = AdwordsApi::Api.new
32
+
33
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
34
+ # the configuration file or provide your own logger:
35
+ # adwords.logger = Logger.new('adwords_xml.log')
36
+
37
+ feed_srv = adwords.service(:FeedService, API_VERSION)
38
+ feed_item_srv = adwords.service(:FeedItemService, API_VERSION)
39
+ feed_mapping_srv = adwords.service(:FeedMappingService, API_VERSION)
40
+ campaign_feed_srv = adwords.service(:CampaignFeedService, API_VERSION)
41
+
42
+ sitelinks_data = {}
43
+
44
+ # Create site links feed first.
45
+ site_links_feed = {
46
+ :name => 'Feed For Site Links',
47
+ :attributes => [
48
+ {:type => 'STRING', :name => 'Link Text'},
49
+ {:type => 'URL', :name => 'Link URL'}
50
+ ]
51
+ }
52
+
53
+ response = feed_srv.mutate([
54
+ {:operator => 'ADD', :operand => site_links_feed}
55
+ ])
56
+ if response and response[:value]
57
+ feed = response[:value].first
58
+ # Attribute of type STRING.
59
+ link_text_feed_attribute_id = feed[:attributes][0][:id]
60
+ # Attribute of type URL.
61
+ link_url_feed_attribute_id = feed[:attributes][1][:id]
62
+ puts "Feed with name '%s' and ID %d was added with" %
63
+ [feed[:name], feed[:id]]
64
+ puts "\tText attribute ID %d and URL attribute ID %d." %
65
+ [link_text_feed_attribute_id, link_url_feed_attribute_id]
66
+ sitelinks_data[:feed_id] = feed[:id]
67
+ sitelinks_data[:link_text_feed_id] = link_text_feed_attribute_id
68
+ sitelinks_data[:link_url_feed_id] = link_url_feed_attribute_id
69
+ else
70
+ raise new StandardError, 'No feeds were added.'
71
+ end
72
+
73
+ # Create site links feed items.
74
+ items_data = [
75
+ {:text => 'Home', :url => 'http://www.example.com'},
76
+ {:text => 'Stores', :url => 'http://www.example.com/stores'},
77
+ {:text => 'On Sale', :url => 'http://www.example.com/sale'},
78
+ {:text => 'Support', :url => 'http://www.example.com/support'},
79
+ {:text => 'Products', :url => 'http://www.example.com/products'},
80
+ {:text => 'About', :url => 'http://www.example.com/about'}
81
+ ]
82
+
83
+ feed_items = items_data.map do |item|
84
+ {
85
+ :feed_id => sitelinks_data[:feed_id],
86
+ :attribute_values => [
87
+ {
88
+ :feed_attribute_id => sitelinks_data[:link_text_feed_id],
89
+ :string_value => item[:text]
90
+ },
91
+ {
92
+ :feed_attribute_id => sitelinks_data[:link_url_feed_id],
93
+ :string_value => item[:url]
94
+ }
95
+ ]
96
+ }
97
+ end
98
+
99
+ feed_items_operations = feed_items.map do |item|
100
+ {:operator => 'ADD', :operand => item}
101
+ end
102
+
103
+ response = feed_item_srv.mutate(feed_items_operations)
104
+ if response and response[:value]
105
+ sitelinks_data[:feed_item_ids] = []
106
+ response[:value].each do |feed_item|
107
+ puts 'Feed item with ID %d was added.' % feed_item[:feed_item_id]
108
+ sitelinks_data[:feed_item_ids] << feed_item[:feed_item_id]
109
+ end
110
+ else
111
+ raise new StandardError, 'No feed items were added.'
112
+ end
113
+
114
+ # Create site links feed mapping.
115
+ feed_mapping = {
116
+ :placeholder_type => PLACEHOLDER_SITELINKS,
117
+ :feed_id => sitelinks_data[:feed_id],
118
+ :attribute_field_mappings => [
119
+ {
120
+ :feed_attribute_id => sitelinks_data[:link_text_feed_id],
121
+ :field_id => PLACEHOLDER_FIELD_SITELINK_LINK_TEXT
122
+ },
123
+ {
124
+ :feed_attribute_id => sitelinks_data[:link_url_feed_id],
125
+ :field_id => PLACEHOLDER_FIELD_SITELINK_LINK_URL
126
+ }
127
+ ]
128
+ }
129
+
130
+ response = feed_mapping_srv.mutate([
131
+ {:operator => 'ADD', :operand => feed_mapping}
132
+ ])
133
+ if response and response[:value]
134
+ feed_mapping = response[:value].first
135
+ puts ('Feed mapping with ID %d and placeholder type %d was saved for feed' +
136
+ ' with ID %d.') % [
137
+ feed_mapping[:feed_mapping_id],
138
+ feed_mapping[:placeholder_type],
139
+ feed_mapping[:feed_id]
140
+ ]
141
+ else
142
+ raise new StandardError, 'No feed mappings were added.'
143
+ end
144
+
145
+ # Create site links campaign feed.
146
+ operands = sitelinks_data[:feed_item_ids].map do |feed_item_id|
147
+ {
148
+ :xsi_type => 'ConstantOperand',
149
+ :type => 'LONG',
150
+ :long_value => feed_item_id
151
+ }
152
+ end
153
+
154
+ feed_item_function = {
155
+ :operator => 'IN',
156
+ :lhs_operand => [
157
+ {:xsi_type => 'RequestContextOperand', :context_type => 'FEED_ITEM_ID'}
158
+ ],
159
+ :rhs_operand => operands
160
+ }
161
+
162
+ # Optional: to target to a platform, define a function and 'AND' it with the
163
+ # feed item ID link:
164
+ platform_function = {
165
+ :operator => 'EQUALS',
166
+ :lhs_operand => [
167
+ {:xsi_type => 'RequestContextOperand', :context_type => 'DEVICE_PLATFORM'}
168
+ ],
169
+ :rhs_operand => [
170
+ {
171
+ :xsi_type => 'ConstantOperand',
172
+ :type => 'STRING',
173
+ :string_value => 'Mobile'
174
+ }
175
+ ]
176
+ }
177
+ combined_function = {
178
+ :operator => 'AND',
179
+ :lhs_operand => [
180
+ {:xsi_type => 'FunctionOperand', :value => feed_item_function},
181
+ {:xsi_type => 'FunctionOperand', :value => platform_function}
182
+ ]
183
+ }
184
+
185
+ campaign_feed = {
186
+ :feed_id => sitelinks_data[:feed_id],
187
+ :campaign_id => campaign_id,
188
+ :matching_function => combined_function,
189
+ # Specifying placeholder types on the CampaignFeed allows the same feed
190
+ # to be used for different placeholders in different Campaigns.
191
+ :placeholder_types => [PLACEHOLDER_SITELINKS]
192
+ }
193
+
194
+ response = campaign_feed_srv.mutate([
195
+ {:operator => 'ADD', :operand => campaign_feed}
196
+ ])
197
+ if response and response[:value]
198
+ campaign_feed = response[:value].first
199
+ puts 'Campaign with ID %d was associated with feed with ID %d.' %
200
+ [campaign_feed[:campaign_id], campaign_feed[:feed_id]]
201
+ else
202
+ raise new StandardError, 'No campaign feeds were added.'
203
+ end
204
+ end
205
+
206
+ if __FILE__ == $0
207
+ API_VERSION = :v201306
208
+
209
+ # See the Placeholder reference page for a list of all the placeholder types
210
+ # and fields, see:
211
+ # https://developers.google.com/adwords/api/docs/appendix/placeholders
212
+ PLACEHOLDER_SITELINKS = 1
213
+ PLACEHOLDER_FIELD_SITELINK_LINK_TEXT = 1
214
+ PLACEHOLDER_FIELD_SITELINK_LINK_URL = 2
215
+
216
+ begin
217
+ # Campaign ID to add site link to. Campaign must be enhanced.
218
+ campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
219
+ add_site_links(campaign_id)
220
+
221
+ # Authorization error.
222
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
223
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
224
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
225
+ "to retrieve and store OAuth2 tokens."
226
+ puts "See this wiki page for more details:\n\n " +
227
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
228
+
229
+ # HTTP errors.
230
+ rescue AdsCommon::Errors::HttpError => e
231
+ puts "HTTP Error: %s" % e
232
+
233
+ # API errors.
234
+ rescue AdwordsApi::Errors::ApiException => e
235
+ puts "Message: %s" % e.message
236
+ puts 'Errors:'
237
+ e.errors.each_with_index do |error, index|
238
+ puts "\tError [%d]:" % (index + 1)
239
+ error.each do |field, value|
240
+ puts "\t\t%s: %s" % [field, value]
241
+ end
242
+ end
243
+ end
244
+ end