google-adwords-api 0.15.1 → 0.15.2

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 (166) hide show
  1. checksums.yaml +8 -8
  2. data/ChangeLog +4 -0
  3. data/examples/v201502/extensions/add_google_my_business_location_extensions.rb +4 -4
  4. data/examples/v201506/account_management/create_account.rb +92 -0
  5. data/examples/v201506/account_management/get_account_changes.rb +143 -0
  6. data/examples/v201506/account_management/get_account_hierarchy.rb +98 -0
  7. data/examples/v201506/advanced_operations/add_ad_customizers.rb +189 -0
  8. data/examples/v201506/advanced_operations/add_ad_group_bid_modifier.rb +105 -0
  9. data/examples/v201506/advanced_operations/add_click_to_download_ad.rb +137 -0
  10. data/examples/v201506/advanced_operations/add_text_ad_with_upgraded_urls.rb +138 -0
  11. data/examples/v201506/advanced_operations/create_and_attach_shared_keyword_set.rb +137 -0
  12. data/examples/v201506/advanced_operations/find_and_remove_criteria_from_shared_set.rb +171 -0
  13. data/examples/v201506/advanced_operations/get_ad_group_bid_modifiers.rb +106 -0
  14. data/examples/v201506/advanced_operations/upload_offline_conversions.rb +117 -0
  15. data/examples/v201506/advanced_operations/use_shared_bidding_strategy.rb +152 -0
  16. data/examples/v201506/basic_operations/add_ad_groups.rb +144 -0
  17. data/examples/v201506/basic_operations/add_campaigns.rb +143 -0
  18. data/examples/v201506/basic_operations/add_keywords.rb +118 -0
  19. data/examples/v201506/basic_operations/add_text_ads.rb +113 -0
  20. data/examples/v201506/basic_operations/get_ad_groups.rb +106 -0
  21. data/examples/v201506/basic_operations/get_campaigns.rb +101 -0
  22. data/examples/v201506/basic_operations/get_campaigns_with_awql.rb +93 -0
  23. data/examples/v201506/basic_operations/get_keywords.rb +112 -0
  24. data/examples/v201506/basic_operations/get_text_ads.rb +114 -0
  25. data/examples/v201506/basic_operations/pause_ad.rb +92 -0
  26. data/examples/v201506/basic_operations/remove_ad.rb +93 -0
  27. data/examples/v201506/basic_operations/remove_ad_group.rb +89 -0
  28. data/examples/v201506/basic_operations/remove_campaign.rb +91 -0
  29. data/examples/v201506/basic_operations/remove_keyword.rb +98 -0
  30. data/examples/v201506/basic_operations/update_ad_group.rb +89 -0
  31. data/examples/v201506/basic_operations/update_campaign.rb +90 -0
  32. data/examples/v201506/basic_operations/update_keyword.rb +110 -0
  33. data/examples/v201506/campaign_management/add_campaign_labels.rb +86 -0
  34. data/examples/v201506/campaign_management/add_experiment.rb +166 -0
  35. data/examples/v201506/campaign_management/add_keywords_in_bulk.rb +158 -0
  36. data/examples/v201506/campaign_management/get_all_disapproved_ads.rb +101 -0
  37. data/examples/v201506/campaign_management/get_all_disapproved_ads_with_awql.rb +93 -0
  38. data/examples/v201506/campaign_management/get_campaigns_by_label.rb +112 -0
  39. data/examples/v201506/campaign_management/promote_experiment.rb +85 -0
  40. data/examples/v201506/campaign_management/set_ad_parameters.rb +122 -0
  41. data/examples/v201506/campaign_management/set_criterion_bid_modifier.rb +108 -0
  42. data/examples/v201506/campaign_management/validate_text_ad.rb +114 -0
  43. data/examples/v201506/error_handling/handle_partial_failures.rb +134 -0
  44. data/examples/v201506/error_handling/handle_policy_violation_error.rb +145 -0
  45. data/examples/v201506/extensions/add_google_my_business_location_extensions.rb +190 -0
  46. data/examples/v201506/extensions/add_site_links.rb +168 -0
  47. data/examples/v201506/extensions/add_site_links_using_feeds.rb +276 -0
  48. data/examples/v201506/migration/migrate_to_extension_settings.rb +392 -0
  49. data/examples/v201506/migration/upgrade_ad_url.rb +97 -0
  50. data/examples/v201506/misc/create_ad_words_session_without_properties_file.rb +94 -0
  51. data/examples/v201506/misc/get_all_images_and_videos.rb +108 -0
  52. data/examples/v201506/misc/setup_oauth2.rb +88 -0
  53. data/examples/v201506/misc/upload_image.rb +97 -0
  54. data/examples/v201506/misc/use_oauth2_jwt.rb +97 -0
  55. data/examples/v201506/optimization/estimate_keyword_traffic.rb +150 -0
  56. data/examples/v201506/optimization/get_keyword_bid_simulations.rb +99 -0
  57. data/examples/v201506/optimization/get_keyword_ideas.rb +130 -0
  58. data/examples/v201506/remarketing/add_audience.rb +122 -0
  59. data/examples/v201506/remarketing/add_conversion_tracker.rb +104 -0
  60. data/examples/v201506/remarketing/add_rule_based_user_lists.rb +171 -0
  61. data/examples/v201506/reporting/download_criteria_report.rb +94 -0
  62. data/examples/v201506/reporting/download_criteria_report_with_awql.rb +95 -0
  63. data/examples/v201506/reporting/get_report_fields.rb +79 -0
  64. data/examples/v201506/reporting/parallel_report_download.rb +168 -0
  65. data/examples/v201506/shopping_campaigns/add_product_partition_tree.rb +269 -0
  66. data/examples/v201506/shopping_campaigns/add_product_scope.rb +133 -0
  67. data/examples/v201506/shopping_campaigns/add_shopping_campaign.rb +133 -0
  68. data/examples/v201506/shopping_campaigns/get_product_category_taxonomy.rb +117 -0
  69. data/examples/v201506/targeting/add_campaign_targeting_criteria.rb +184 -0
  70. data/examples/v201506/targeting/add_demographic_targeting_criteria.rb +116 -0
  71. data/examples/v201506/targeting/get_campaign_targeting_criteria.rb +110 -0
  72. data/examples/v201506/targeting/get_targetable_languages_and_carriers.rb +94 -0
  73. data/examples/v201506/targeting/lookup_location.rb +112 -0
  74. data/lib/adwords_api.rb +9 -0
  75. data/lib/adwords_api/api_config.rb +90 -4
  76. data/lib/adwords_api/report_header_handler.rb +5 -0
  77. data/lib/adwords_api/v201506/account_label_service.rb +38 -0
  78. data/lib/adwords_api/v201506/account_label_service_registry.rb +46 -0
  79. data/lib/adwords_api/v201506/ad_customizer_feed_service.rb +38 -0
  80. data/lib/adwords_api/v201506/ad_customizer_feed_service_registry.rb +46 -0
  81. data/lib/adwords_api/v201506/ad_group_ad_service.rb +50 -0
  82. data/lib/adwords_api/v201506/ad_group_ad_service_registry.rb +46 -0
  83. data/lib/adwords_api/v201506/ad_group_bid_modifier_service.rb +42 -0
  84. data/lib/adwords_api/v201506/ad_group_bid_modifier_service_registry.rb +46 -0
  85. data/lib/adwords_api/v201506/ad_group_criterion_service.rb +46 -0
  86. data/lib/adwords_api/v201506/ad_group_criterion_service_registry.rb +46 -0
  87. data/lib/adwords_api/v201506/ad_group_extension_setting_service.rb +42 -0
  88. data/lib/adwords_api/v201506/ad_group_extension_setting_service_registry.rb +46 -0
  89. data/lib/adwords_api/v201506/ad_group_feed_service.rb +42 -0
  90. data/lib/adwords_api/v201506/ad_group_feed_service_registry.rb +46 -0
  91. data/lib/adwords_api/v201506/ad_group_service.rb +46 -0
  92. data/lib/adwords_api/v201506/ad_group_service_registry.rb +46 -0
  93. data/lib/adwords_api/v201506/ad_param_service.rb +38 -0
  94. data/lib/adwords_api/v201506/ad_param_service_registry.rb +46 -0
  95. data/lib/adwords_api/v201506/adwords_user_list_service.rb +38 -0
  96. data/lib/adwords_api/v201506/adwords_user_list_service_registry.rb +46 -0
  97. data/lib/adwords_api/v201506/bidding_strategy_service.rb +42 -0
  98. data/lib/adwords_api/v201506/bidding_strategy_service_registry.rb +46 -0
  99. data/lib/adwords_api/v201506/budget_order_service.rb +42 -0
  100. data/lib/adwords_api/v201506/budget_order_service_registry.rb +46 -0
  101. data/lib/adwords_api/v201506/budget_service.rb +42 -0
  102. data/lib/adwords_api/v201506/budget_service_registry.rb +46 -0
  103. data/lib/adwords_api/v201506/campaign_criterion_service.rb +42 -0
  104. data/lib/adwords_api/v201506/campaign_criterion_service_registry.rb +46 -0
  105. data/lib/adwords_api/v201506/campaign_extension_setting_service.rb +42 -0
  106. data/lib/adwords_api/v201506/campaign_extension_setting_service_registry.rb +46 -0
  107. data/lib/adwords_api/v201506/campaign_feed_service.rb +42 -0
  108. data/lib/adwords_api/v201506/campaign_feed_service_registry.rb +46 -0
  109. data/lib/adwords_api/v201506/campaign_service.rb +46 -0
  110. data/lib/adwords_api/v201506/campaign_service_registry.rb +46 -0
  111. data/lib/adwords_api/v201506/campaign_shared_set_service.rb +42 -0
  112. data/lib/adwords_api/v201506/campaign_shared_set_service_registry.rb +46 -0
  113. data/lib/adwords_api/v201506/constant_data_service.rb +66 -0
  114. data/lib/adwords_api/v201506/constant_data_service_registry.rb +46 -0
  115. data/lib/adwords_api/v201506/conversion_tracker_service.rb +42 -0
  116. data/lib/adwords_api/v201506/conversion_tracker_service_registry.rb +46 -0
  117. data/lib/adwords_api/v201506/customer_extension_setting_service.rb +42 -0
  118. data/lib/adwords_api/v201506/customer_extension_setting_service_registry.rb +46 -0
  119. data/lib/adwords_api/v201506/customer_feed_service.rb +42 -0
  120. data/lib/adwords_api/v201506/customer_feed_service_registry.rb +46 -0
  121. data/lib/adwords_api/v201506/customer_service.rb +38 -0
  122. data/lib/adwords_api/v201506/customer_service_registry.rb +46 -0
  123. data/lib/adwords_api/v201506/customer_sync_service.rb +34 -0
  124. data/lib/adwords_api/v201506/customer_sync_service_registry.rb +47 -0
  125. data/lib/adwords_api/v201506/data_service.rb +54 -0
  126. data/lib/adwords_api/v201506/data_service_registry.rb +46 -0
  127. data/lib/adwords_api/v201506/experiment_service.rb +38 -0
  128. data/lib/adwords_api/v201506/experiment_service_registry.rb +46 -0
  129. data/lib/adwords_api/v201506/feed_item_service.rb +42 -0
  130. data/lib/adwords_api/v201506/feed_item_service_registry.rb +46 -0
  131. data/lib/adwords_api/v201506/feed_mapping_service.rb +42 -0
  132. data/lib/adwords_api/v201506/feed_mapping_service_registry.rb +46 -0
  133. data/lib/adwords_api/v201506/feed_service.rb +42 -0
  134. data/lib/adwords_api/v201506/feed_service_registry.rb +46 -0
  135. data/lib/adwords_api/v201506/geo_location_service.rb +34 -0
  136. data/lib/adwords_api/v201506/geo_location_service_registry.rb +46 -0
  137. data/lib/adwords_api/v201506/label_service.rb +42 -0
  138. data/lib/adwords_api/v201506/label_service_registry.rb +46 -0
  139. data/lib/adwords_api/v201506/location_criterion_service.rb +38 -0
  140. data/lib/adwords_api/v201506/location_criterion_service_registry.rb +46 -0
  141. data/lib/adwords_api/v201506/managed_customer_service.rb +54 -0
  142. data/lib/adwords_api/v201506/managed_customer_service_registry.rb +46 -0
  143. data/lib/adwords_api/v201506/media_service.rb +42 -0
  144. data/lib/adwords_api/v201506/media_service_registry.rb +46 -0
  145. data/lib/adwords_api/v201506/mutate_job_service.rb +42 -0
  146. data/lib/adwords_api/v201506/mutate_job_service_registry.rb +46 -0
  147. data/lib/adwords_api/v201506/offline_conversion_feed_service.rb +34 -0
  148. data/lib/adwords_api/v201506/offline_conversion_feed_service_registry.rb +46 -0
  149. data/lib/adwords_api/v201506/report_definition_service.rb +34 -0
  150. data/lib/adwords_api/v201506/report_definition_service_registry.rb +46 -0
  151. data/lib/adwords_api/v201506/shared_criterion_service.rb +42 -0
  152. data/lib/adwords_api/v201506/shared_criterion_service_registry.rb +46 -0
  153. data/lib/adwords_api/v201506/shared_set_service.rb +42 -0
  154. data/lib/adwords_api/v201506/shared_set_service_registry.rb +46 -0
  155. data/lib/adwords_api/v201506/targeting_idea_service.rb +34 -0
  156. data/lib/adwords_api/v201506/targeting_idea_service_registry.rb +46 -0
  157. data/lib/adwords_api/v201506/traffic_estimator_service.rb +34 -0
  158. data/lib/adwords_api/v201506/traffic_estimator_service_registry.rb +46 -0
  159. data/lib/adwords_api/version.rb +1 -1
  160. data/test/adwords_api/test_adwords_api.rb +1 -1
  161. data/test/adwords_api/test_api_config.rb +8 -8
  162. data/test/adwords_api/test_choices.rb +2 -2
  163. data/test/adwords_api/test_report_utils.rb +1 -1
  164. data/test/templates/v201506/basic_operations_get_campaigns.def +116 -0
  165. data/test/templates/v201506/misc_use_oauth2_jwt.def +131 -0
  166. metadata +156 -2
@@ -0,0 +1,122 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.sgomes@gmail.com (Sérgio Gomes)
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 create a user list (a.k.a. Audience) and shows
22
+ # its associated conversion tracker code snippet.
23
+ #
24
+ # Tags: UserListService.mutate, ConversionTrackerService.get
25
+
26
+ require 'adwords_api'
27
+
28
+ def add_audience()
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
+ user_list_srv = adwords.service(:AdwordsUserListService, API_VERSION)
38
+ conv_tracker_srv = adwords.service(:ConversionTrackerService, API_VERSION)
39
+
40
+ # Prepare for adding remarketing user list.
41
+ name = "Mars cruise customers #%d" % (Time.new.to_f * 1000).to_i
42
+ operation = {
43
+ :operator => 'ADD',
44
+ :operand => {
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 => 'BasicUserList',
49
+ :name => name,
50
+ :description => 'A list of mars cruise customers in the last year',
51
+ :membership_life_span => 365,
52
+ :conversion_types => [{:name => name}],
53
+ # Optional field.
54
+ :status => 'OPEN'
55
+ }
56
+ }
57
+
58
+ # Add user list.
59
+ response = user_list_srv.mutate([operation])
60
+ if response and response[:value]
61
+ user_list = response[:value].first
62
+
63
+ # Get conversion snippets.
64
+ if user_list and user_list[:conversion_types]
65
+ conversion_ids = user_list[:conversion_types][:id]
66
+ selector = {
67
+ # We're actually interested in the 'Snippet' field, which is returned
68
+ # automatically.
69
+ :fields => ['Id'],
70
+ :predicates => [
71
+ {:field => 'Id', :operator => 'IN', :values => [conversion_ids]}
72
+ ]
73
+ }
74
+ conv_tracker_response = conv_tracker_srv.get(selector)
75
+ if conv_tracker_response and conv_tracker_response[:entries]
76
+ conversions = conv_tracker_response[:entries]
77
+ end
78
+ end
79
+ puts "User list with name '%s' and ID %d was added." %
80
+ [user_list[:name], user_list[:id]]
81
+ # Display user list associated conversion code snippets.
82
+ if conversions
83
+ conversions.each do |conversion|
84
+ puts "Conversion type code snipped associated to the list:\n\t\t%s\n" %
85
+ conversion[:snippet]
86
+ end
87
+ end
88
+ else
89
+ puts 'No user lists were added.'
90
+ end
91
+ end
92
+
93
+ if __FILE__ == $0
94
+ API_VERSION = :v201506
95
+
96
+ begin
97
+ add_audience()
98
+
99
+ # Authorization error.
100
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
101
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
102
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
103
+ "to retrieve and store OAuth2 tokens."
104
+ puts "See this wiki page for more details:\n\n " +
105
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
106
+
107
+ # HTTP errors.
108
+ rescue AdsCommon::Errors::HttpError => e
109
+ puts "HTTP Error: %s" % e
110
+
111
+ # API errors.
112
+ rescue AdwordsApi::Errors::ApiException => e
113
+ puts "Message: %s" % e.message
114
+ puts 'Errors:'
115
+ e.errors.each_with_index do |error, index|
116
+ puts "\tError [%d]:" % (index + 1)
117
+ error.each do |field, value|
118
+ puts "\t\t%s: %s" % [field, value]
119
+ end
120
+ end
121
+ end
122
+ end
@@ -0,0 +1,104 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.sgomes@gmail.com (Sérgio Gomes)
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 add an AdWords conversion tracker.
22
+ #
23
+ # Tags: ConversionTrackerService.mutate
24
+
25
+ require 'adwords_api'
26
+
27
+ def add_conversion_tracker()
28
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
29
+ # when called without parameters.
30
+ adwords = AdwordsApi::Api.new
31
+
32
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
33
+ # the configuration file or provide your own logger:
34
+ # adwords.logger = Logger.new('adwords_xml.log')
35
+
36
+ conv_tracker_srv = adwords.service(:ConversionTrackerService, API_VERSION)
37
+
38
+ # Prepare for adding conversion.
39
+ operation = {
40
+ :operator => 'ADD',
41
+ :operand => {
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 => 'AdWordsConversionTracker',
46
+ :name => "Earth to Mars Cruises Conversion #%d" %
47
+ (Time.new.to_f * 1000).to_i,
48
+ :category => 'DEFAULT',
49
+ :markup_language => 'HTML',
50
+ :text_format => 'HIDDEN',
51
+ # Optional fields:
52
+ :status => 'ENABLED',
53
+ :viewthrough_lookback_window => 15,
54
+ :is_product_ads_chargeable => true,
55
+ :product_ads_chargeable_conversion_window => 15,
56
+ :conversion_page_language => 'en',
57
+ :background_color => '#0000FF',
58
+ :default_revenue_value => 23.41,
59
+ :always_use_default_revenue_value => true
60
+ }
61
+ }
62
+
63
+ # Add conversion.
64
+ response = conv_tracker_srv.mutate([operation])
65
+ if response and response[:value]
66
+ conversion = response[:value].first
67
+ puts ("Conversion with ID %d, name '%s', status '%s' and category '%s'" +
68
+ " was added.") % [conversion[:id], conversion[:name],
69
+ conversion[:status], conversion[:category]]
70
+ else
71
+ puts 'No conversions were added.'
72
+ end
73
+ end
74
+
75
+ if __FILE__ == $0
76
+ API_VERSION = :v201506
77
+
78
+ begin
79
+ add_conversion_tracker()
80
+
81
+ # Authorization error.
82
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
83
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
84
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
85
+ "to retrieve and store OAuth2 tokens."
86
+ puts "See this wiki page for more details:\n\n " +
87
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
88
+
89
+ # HTTP errors.
90
+ rescue AdsCommon::Errors::HttpError => e
91
+ puts "HTTP Error: %s" % e
92
+
93
+ # API errors.
94
+ rescue AdwordsApi::Errors::ApiException => e
95
+ puts "Message: %s" % e.message
96
+ puts 'Errors:'
97
+ e.errors.each_with_index do |error, index|
98
+ puts "\tError [%d]:" % (index + 1)
99
+ error.each do |field, value|
100
+ puts "\t\t%s: %s" % [field, value]
101
+ end
102
+ end
103
+ end
104
+ end
@@ -0,0 +1,171 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.mcloonan@gmail.com (Michael Cloonan)
5
+ #
6
+ # Copyright:: Copyright 2014, 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 two rule-based remarketing user lists: one with no site
22
+ # visit data restrictions, and another that will only include users who visit
23
+ # your site in the next six months.
24
+ #
25
+ # Tags: AdwordsUserListService.mutate
26
+
27
+ require 'adwords_api'
28
+
29
+ def add_rule_based_user_lists()
30
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
31
+ # when called without parameters.
32
+ adwords = AdwordsApi::Api.new
33
+
34
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
35
+ # the configuration file or provide your own logger:
36
+ # adwords.logger = Logger.new('adwords_xml.log')
37
+
38
+ user_list_srv = adwords.service(:AdwordsUserListService, API_VERSION)
39
+
40
+ # First rule item group - users who visited the checkout page and had more
41
+ # than one item in their shopping cart.
42
+ cart_rule_item = {
43
+ :xsi_type => 'StringRuleItem',
44
+ :key => {
45
+ :name => 'ecomm_pagetype'
46
+ },
47
+ :op => 'EQUALS',
48
+ :value => 'checkout'
49
+ }
50
+
51
+ cart_size_rule_item = {
52
+ :xsi_type => 'NumberRuleItem',
53
+ :key => {
54
+ :name => 'cartsize'
55
+ },
56
+ :op => 'GREATER_THAN',
57
+ :value => 1.0
58
+ }
59
+
60
+ # Combine the two rule items into a RuleItemGroup so AdWords will AND
61
+ # their rules together.
62
+ checkout_multiple_item_group = {
63
+ :items => [cart_rule_item, cart_size_rule_item]
64
+ }
65
+
66
+ # Second rule item group - users who checked out after October 31st
67
+ # and before January 1st.
68
+ start_date_rule_item = {
69
+ :xsi_type => 'DateRuleItem',
70
+ :key => {
71
+ :name => 'checkoutdate'
72
+ },
73
+ :op => 'AFTER',
74
+ :value => '20141031'
75
+ }
76
+
77
+ end_date_rule_item = {
78
+ :xsi_type => 'DateRuleItem',
79
+ :key => {
80
+ :name => 'checkoutdate'
81
+ },
82
+ :op => 'BEFORE',
83
+ :value => '20150101'
84
+ }
85
+
86
+ # Combine the date rule items into a RuleItemGroup.
87
+ checked_out_nov_dec_item_group = {
88
+ :items => [start_date_rule_item, end_date_rule_item]
89
+ }
90
+
91
+ # Combine the rule item groups into a Rule so AdWords will OR the
92
+ # groups together.
93
+ rule = {
94
+ :groups => [checkout_multiple_item_group, checked_out_nov_dec_item_group]
95
+ }
96
+
97
+ # Create the user list with no restrictions on site visit date.
98
+ expression_user_list = {
99
+ :xsi_type => 'ExpressionRuleUserList',
100
+ :name => 'Users who checked out in November or December OR ' +
101
+ 'visited the checkout page with more than one item in their cart',
102
+ :description => 'Expression based user list',
103
+ :rule => rule
104
+ }
105
+
106
+ # Create the user list restricted to users who visit your site within the
107
+ # specified timeframe.
108
+ date_user_list = {
109
+ :xsi_type => 'DateSpecificRuleUserList',
110
+ :name => 'Date rule user list created at ' + Time.now.to_s,
111
+ :description => 'Users who visited the site between 20141031 and ' +
112
+ '20150331 and checked out in November or December OR visited the ' +
113
+ 'checkout page with more than one item in their cart',
114
+ # We re-use the rule here. To avoid side effects, we need a deep copy.
115
+ :rule => Marshal.load(Marshal.dump(rule)),
116
+ # Set the start and end dates of the user list.
117
+ :start_date => '20141031',
118
+ :end_date => '20150331'
119
+ }
120
+
121
+ # Create operations to add the user lists.
122
+ operations = [expression_user_list, date_user_list].map do |user_list|
123
+ {
124
+ :operand => user_list,
125
+ :operator => 'ADD'
126
+ }
127
+ end
128
+
129
+ # Submit the operations.
130
+ response = user_list_srv.mutate(operations)
131
+
132
+ # Display the results.
133
+ response[:value].each do |user_list|
134
+ puts ("User list added with ID %d, name '%s', status '%s', " +
135
+ "list type '%s', accountUserListStatus '%s', description '%s'.") %
136
+ [user_list[:id], user_list[:name], user_list[:status],
137
+ user_list[:list_type], user_list[:account_user_list_status],
138
+ user_list[:description]]
139
+ end
140
+ end
141
+
142
+ if __FILE__ == $0
143
+ API_VERSION = :v201506
144
+
145
+ begin
146
+ add_rule_based_user_lists()
147
+
148
+ # Authorization error.
149
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
150
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
151
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
152
+ "to retrieve and store OAuth2 tokens."
153
+ puts "See this wiki page for more details:\n\n " +
154
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
155
+
156
+ # HTTP errors.
157
+ rescue AdsCommon::Errors::HttpError => e
158
+ puts "HTTP Error: %s" % e
159
+
160
+ # API errors.
161
+ rescue AdwordsApi::Errors::ApiException => e
162
+ puts "Message: %s" % e.message
163
+ puts 'Errors:'
164
+ e.errors.each_with_index do |error, index|
165
+ puts "\tError [%d]:" % (index + 1)
166
+ error.each do |field, value|
167
+ puts "\t\t%s: %s" % [field, value]
168
+ end
169
+ end
170
+ end
171
+ end
@@ -0,0 +1,94 @@
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 gets and downloads an Ad Hoc report from a XML report definition.
22
+
23
+ require 'adwords_api'
24
+
25
+ def download_criteria_report(file_name)
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
+ # Get report utilities for the version.
35
+ report_utils = adwords.report_utils(API_VERSION)
36
+
37
+ # Define report definition. You can also pass your own XML text as a string.
38
+ report_definition = {
39
+ :selector => {
40
+ :fields => ['CampaignId', 'AdGroupId', 'Id', 'Criteria', 'CriteriaType',
41
+ 'FinalUrls', 'Impressions', 'Clicks', 'Cost'],
42
+ # Predicates are optional.
43
+ :predicates => {
44
+ :field => 'Status',
45
+ :operator => 'IN',
46
+ :values => ['ENABLED', 'PAUSED']
47
+ }
48
+ },
49
+ :report_name => 'Last 7 days CRITERIA_PERFORMANCE_REPORT',
50
+ :report_type => 'CRITERIA_PERFORMANCE_REPORT',
51
+ :download_format => 'CSV',
52
+ :date_range_type => 'LAST_7_DAYS',
53
+ }
54
+
55
+ # Optional: Set the configuration of the API instance to suppress header,
56
+ # column name, or summary rows in the report output. You can also configure
57
+ # this in your adwords_api.yml configuration file.
58
+ adwords.skip_report_header = false
59
+ adwords.skip_column_header = false
60
+ adwords.skip_report_summary = false
61
+ # Enable to allow rows with zero impressions to show.
62
+ adwords.include_zero_impressions = false
63
+
64
+ # Download report, using "download_report_as_file" utility method.
65
+ # To retrieve the report as return value, use "download_report" method.
66
+ report_utils.download_report_as_file(report_definition, file_name)
67
+ puts "Report was downloaded to '%s'." % file_name
68
+ end
69
+
70
+ if __FILE__ == $0
71
+ API_VERSION = :v201506
72
+
73
+ begin
74
+ # File name to write report to.
75
+ file_name = 'INSERT_OUTPUT_FILE_NAME_HERE'
76
+ download_criteria_report(file_name)
77
+
78
+ # Authorization error.
79
+ rescue AdsCommon::Errors::OAuth2VerificationRequired => e
80
+ puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
81
+ "OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
82
+ "to retrieve and store OAuth2 tokens."
83
+ puts "See this wiki page for more details:\n\n " +
84
+ 'http://code.google.com/p/google-api-ads-ruby/wiki/OAuth2'
85
+
86
+ # HTTP errors.
87
+ rescue AdsCommon::Errors::HttpError => e
88
+ puts "HTTP Error: %s" % e
89
+
90
+ # API errors.
91
+ rescue AdwordsApi::Errors::ReportError => e
92
+ puts "Reporting Error: %s" % e.message
93
+ end
94
+ end