google-adwords-api 0.8.2 → 0.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (150) hide show
  1. data/ChangeLog +6 -0
  2. data/README +3 -3
  3. data/examples/{v201206/basic_operations/delete_ad_group.rb → v201209/adwords_for_video/add_video_campaign.rb} +41 -40
  4. data/examples/{v201206/basic_operations/pause_ad.rb → v201209/adwords_for_video/find_videos.rb} +33 -25
  5. data/examples/{v201206/basic_operations/get_keywords.rb → v201209/adwords_for_video/get_keyword_criteria.rb} +24 -27
  6. data/examples/{v201206/basic_operations/get_campaigns_with_awql.rb → v201209/adwords_for_video/get_targeting_groups.rb} +26 -18
  7. data/examples/{v201206/basic_operations/get_ad_groups.rb → v201209/adwords_for_video/get_video_campaign_criteria.rb} +22 -21
  8. data/examples/v201209/adwords_for_video/get_video_campaign_stats.rb +126 -0
  9. data/examples/{v201206/basic_operations/get_campaigns.rb → v201209/adwords_for_video/get_video_campaigns.rb} +16 -15
  10. data/examples/v201302/advanced_operations/create_and_attach_shared_keyword_set.rb +139 -0
  11. data/examples/v201302/advanced_operations/find_and_remove_criteria_from_shared_set.rb +173 -0
  12. data/lib/adwords_api/api_config.rb +17 -59
  13. data/lib/adwords_api/report_utils.rb +3 -19
  14. data/lib/adwords_api/{v201206/ad_param_service.rb → v201209/video_ad_service.rb} +8 -8
  15. data/lib/adwords_api/v201209/video_ad_service_registry.rb +46 -0
  16. data/lib/adwords_api/{v201206/campaign_ad_extension_service.rb → v201209/video_campaign_criterion_service.rb} +8 -8
  17. data/lib/adwords_api/v201209/video_campaign_criterion_service_registry.rb +47 -0
  18. data/lib/adwords_api/{v201206/bulk_mutate_job_service.rb → v201209/video_campaign_service.rb} +8 -8
  19. data/lib/adwords_api/v201209/video_campaign_service_registry.rb +46 -0
  20. data/lib/adwords_api/v201209/video_service.rb +42 -0
  21. data/lib/adwords_api/v201209/video_service_registry.rb +46 -0
  22. data/lib/adwords_api/{v201206/ad_group_ad_service.rb → v201209/video_targeting_group_criterion_service.rb} +8 -12
  23. data/lib/adwords_api/v201209/video_targeting_group_criterion_service_registry.rb +46 -0
  24. data/lib/adwords_api/{v201206/ad_extension_override_service.rb → v201209/video_targeting_group_service.rb} +8 -8
  25. data/lib/adwords_api/v201209/video_targeting_group_service_registry.rb +46 -0
  26. data/lib/adwords_api/v201302/ad_group_feed_service.rb +1 -1
  27. data/lib/adwords_api/v201302/ad_group_feed_service_registry.rb +2 -2
  28. data/lib/adwords_api/v201302/campaign_feed_service.rb +1 -1
  29. data/lib/adwords_api/v201302/campaign_feed_service_registry.rb +2 -2
  30. data/lib/adwords_api/v201302/feed_item_service.rb +1 -1
  31. data/lib/adwords_api/v201302/feed_item_service_registry.rb +3 -4
  32. data/lib/adwords_api/v201302/feed_service.rb +1 -1
  33. data/lib/adwords_api/v201302/feed_service_registry.rb +4 -5
  34. data/lib/adwords_api/{v201206/user_list_service.rb → v201302/shared_set_service.rb} +9 -9
  35. data/lib/adwords_api/v201302/shared_set_service_registry.rb +47 -0
  36. data/lib/adwords_api/version.rb +1 -1
  37. data/test/adwords_api/test_report_utils.rb +0 -89
  38. data/test/examples/v201302/test_advanced_operations.rb +10 -0
  39. data/test/templates/v201209/basic_operations_get_campaigns.def +1 -1
  40. data/test/templates/v201302/basic_operations_get_campaigns.def +1 -1
  41. data/test/templates/v201302/misc_use_oauth2_jwt.def +131 -0
  42. data/test/test_utils.rb +6 -2
  43. metadata +26 -121
  44. data/examples/v201206/account_management/create_account.rb +0 -87
  45. data/examples/v201206/account_management/get_account_alerts.rb +0 -114
  46. data/examples/v201206/account_management/get_account_changes.rb +0 -137
  47. data/examples/v201206/account_management/get_account_hierarchy.rb +0 -95
  48. data/examples/v201206/account_management/get_client_customer_id.rb +0 -88
  49. data/examples/v201206/account_management/get_client_unit_usage.rb +0 -90
  50. data/examples/v201206/basic_operations/add_ad_groups.rb +0 -136
  51. data/examples/v201206/basic_operations/add_campaigns.rb +0 -151
  52. data/examples/v201206/basic_operations/add_keywords.rb +0 -108
  53. data/examples/v201206/basic_operations/add_text_ads.rb +0 -105
  54. data/examples/v201206/basic_operations/delete_ad.rb +0 -85
  55. data/examples/v201206/basic_operations/delete_campaign.rb +0 -103
  56. data/examples/v201206/basic_operations/delete_keyword.rb +0 -90
  57. data/examples/v201206/basic_operations/get_text_ads.rb +0 -106
  58. data/examples/v201206/basic_operations/update_ad_group.rb +0 -81
  59. data/examples/v201206/basic_operations/update_campaign.rb +0 -84
  60. data/examples/v201206/basic_operations/update_keyword.rb +0 -99
  61. data/examples/v201206/campaign_management/add_experiment.rb +0 -158
  62. data/examples/v201206/campaign_management/add_keywords_in_bulk.rb +0 -150
  63. data/examples/v201206/campaign_management/add_location_extension.rb +0 -117
  64. data/examples/v201206/campaign_management/add_location_extension_override.rb +0 -83
  65. data/examples/v201206/campaign_management/get_all_disapproved_ads.rb +0 -93
  66. data/examples/v201206/campaign_management/get_all_disapproved_ads_with_awql.rb +0 -84
  67. data/examples/v201206/campaign_management/promote_experiment.rb +0 -77
  68. data/examples/v201206/campaign_management/set_ad_parameters.rb +0 -114
  69. data/examples/v201206/campaign_management/validate_text_ad.rb +0 -106
  70. data/examples/v201206/error_handling/handle_captcha_challenge.rb +0 -93
  71. data/examples/v201206/error_handling/handle_partial_failures.rb +0 -126
  72. data/examples/v201206/error_handling/handle_policy_violation_error.rb +0 -137
  73. data/examples/v201206/error_handling/handle_two_factor_authorization_error.rb +0 -88
  74. data/examples/v201206/misc/get_all_images_and_videos.rb +0 -100
  75. data/examples/v201206/misc/upload_image.rb +0 -89
  76. data/examples/v201206/misc/use_oauth2.rb +0 -97
  77. data/examples/v201206/optimization/estimate_keyword_traffic.rb +0 -129
  78. data/examples/v201206/optimization/get_keyword_bid_simulations.rb +0 -92
  79. data/examples/v201206/optimization/get_keyword_ideas.rb +0 -114
  80. data/examples/v201206/optimization/get_placement_ideas.rb +0 -104
  81. data/examples/v201206/remarketing/add_audience.rb +0 -115
  82. data/examples/v201206/remarketing/add_conversion_tracker.rb +0 -97
  83. data/examples/v201206/reporting/download_criteria_report.rb +0 -79
  84. data/examples/v201206/reporting/download_criteria_report_with_awql.rb +0 -78
  85. data/examples/v201206/reporting/get_campaign_stats.rb +0 -105
  86. data/examples/v201206/reporting/get_report_fields.rb +0 -71
  87. data/examples/v201206/reporting/parallel_report_download.rb +0 -162
  88. data/examples/v201206/targeting/add_campaign_targeting_criteria.rb +0 -118
  89. data/examples/v201206/targeting/get_campaign_targeting_criteria.rb +0 -102
  90. data/examples/v201206/targeting/get_targetable_languages_and_carriers.rb +0 -86
  91. data/examples/v201206/targeting/lookup_location.rb +0 -104
  92. data/lib/adwords_api/v201206/ad_extension_override_service_registry.rb +0 -46
  93. data/lib/adwords_api/v201206/ad_group_ad_service_registry.rb +0 -46
  94. data/lib/adwords_api/v201206/ad_group_criterion_service.rb +0 -42
  95. data/lib/adwords_api/v201206/ad_group_criterion_service_registry.rb +0 -46
  96. data/lib/adwords_api/v201206/ad_group_service.rb +0 -42
  97. data/lib/adwords_api/v201206/ad_group_service_registry.rb +0 -46
  98. data/lib/adwords_api/v201206/ad_param_service_registry.rb +0 -46
  99. data/lib/adwords_api/v201206/alert_service.rb +0 -34
  100. data/lib/adwords_api/v201206/alert_service_registry.rb +0 -46
  101. data/lib/adwords_api/v201206/budget_order_service.rb +0 -42
  102. data/lib/adwords_api/v201206/budget_order_service_registry.rb +0 -46
  103. data/lib/adwords_api/v201206/bulk_mutate_job_service_registry.rb +0 -46
  104. data/lib/adwords_api/v201206/campaign_ad_extension_service_registry.rb +0 -46
  105. data/lib/adwords_api/v201206/campaign_criterion_service.rb +0 -42
  106. data/lib/adwords_api/v201206/campaign_criterion_service_registry.rb +0 -46
  107. data/lib/adwords_api/v201206/campaign_service.rb +0 -42
  108. data/lib/adwords_api/v201206/campaign_service_registry.rb +0 -46
  109. data/lib/adwords_api/v201206/constant_data_service.rb +0 -62
  110. data/lib/adwords_api/v201206/constant_data_service_registry.rb +0 -46
  111. data/lib/adwords_api/v201206/conversion_tracker_service.rb +0 -38
  112. data/lib/adwords_api/v201206/conversion_tracker_service_registry.rb +0 -46
  113. data/lib/adwords_api/v201206/customer_service.rb +0 -34
  114. data/lib/adwords_api/v201206/customer_service_registry.rb +0 -46
  115. data/lib/adwords_api/v201206/customer_sync_service.rb +0 -34
  116. data/lib/adwords_api/v201206/customer_sync_service_registry.rb +0 -47
  117. data/lib/adwords_api/v201206/data_service.rb +0 -38
  118. data/lib/adwords_api/v201206/data_service_registry.rb +0 -46
  119. data/lib/adwords_api/v201206/experiment_service.rb +0 -38
  120. data/lib/adwords_api/v201206/experiment_service_registry.rb +0 -46
  121. data/lib/adwords_api/v201206/geo_location_service.rb +0 -34
  122. data/lib/adwords_api/v201206/geo_location_service_registry.rb +0 -46
  123. data/lib/adwords_api/v201206/info_service.rb +0 -34
  124. data/lib/adwords_api/v201206/info_service_registry.rb +0 -46
  125. data/lib/adwords_api/v201206/location_criterion_service.rb +0 -34
  126. data/lib/adwords_api/v201206/location_criterion_service_registry.rb +0 -46
  127. data/lib/adwords_api/v201206/managed_customer_service.rb +0 -38
  128. data/lib/adwords_api/v201206/managed_customer_service_registry.rb +0 -46
  129. data/lib/adwords_api/v201206/media_service.rb +0 -38
  130. data/lib/adwords_api/v201206/media_service_registry.rb +0 -46
  131. data/lib/adwords_api/v201206/mutate_job_service.rb +0 -42
  132. data/lib/adwords_api/v201206/mutate_job_service_registry.rb +0 -46
  133. data/lib/adwords_api/v201206/report_definition_service.rb +0 -34
  134. data/lib/adwords_api/v201206/report_definition_service_registry.rb +0 -46
  135. data/lib/adwords_api/v201206/targeting_idea_service.rb +0 -38
  136. data/lib/adwords_api/v201206/targeting_idea_service_registry.rb +0 -46
  137. data/lib/adwords_api/v201206/traffic_estimator_service.rb +0 -34
  138. data/lib/adwords_api/v201206/traffic_estimator_service_registry.rb +0 -46
  139. data/lib/adwords_api/v201206/user_list_service_registry.rb +0 -46
  140. data/test/examples/v201206/test_account_management.rb +0 -60
  141. data/test/examples/v201206/test_basic_operations.rb +0 -177
  142. data/test/examples/v201206/test_campaign_management.rb +0 -124
  143. data/test/examples/v201206/test_error_handling.rb +0 -63
  144. data/test/examples/v201206/test_misc.rb +0 -39
  145. data/test/examples/v201206/test_optimization.rb +0 -63
  146. data/test/examples/v201206/test_remarketing.rb +0 -39
  147. data/test/examples/v201206/test_reporting.rb +0 -84
  148. data/test/examples/v201206/test_targeting.rb +0 -60
  149. data/test/examples/v201206/utils.rb +0 -244
  150. data/test/suite_exampletests_v201206.rb +0 -37
@@ -0,0 +1,126 @@
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 retrieve stats for a video campaign.
22
+ #
23
+ # Note: AdWords for Video API is a Beta feature.
24
+ #
25
+ # Tags: VideoCampaignService.get
26
+
27
+ require 'adwords_api'
28
+ require 'date'
29
+
30
+ def get_campaign_stats(campaign_id)
31
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
32
+ # when called without parameters.
33
+ adwords = AdwordsApi::Api.new
34
+
35
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
36
+ # the configuration file or provide your own logger:
37
+ # adwords.logger = Logger.new('adwords_xml.log')
38
+
39
+ video_campaign_srv = adwords.service(:VideoCampaignService, API_VERSION)
40
+
41
+ # Preparing dates to get stats for this year.
42
+ today = Date.today
43
+ min_date_time = today.strftime("%Y0101")
44
+ max_date_time = today.strftime("%Y%m%d")
45
+
46
+ # Get stats for the campaign for given dates.
47
+ selector = {
48
+ :ids => [campaign_id],
49
+ :stats_selector => {
50
+ :date_range => {:min => min_date_time, :max => max_date_time},
51
+ :segmentation_dimensions => ['DATE_MONTH'],
52
+ :metrics => ['VIEWS', 'COST', 'AVERAGE_CPV'],
53
+ :summary_types => ['ALL'],
54
+ :segmented_summary_type => 'ALL'
55
+ },
56
+ :paging => {
57
+ :start_index => 0,
58
+ :number_results => PAGE_SIZE
59
+ }
60
+ }
61
+
62
+ page = video_campaign_srv.get(selector)
63
+ if page[:entries]
64
+ campaign = page[:entries].first
65
+ puts "Campaign ID %d, name '%s' and status '%s'" %
66
+ [campaign[:id], campaign[:name], campaign[:status]]
67
+ if campaign[:stats]
68
+ puts "\tCampaign stats:"
69
+ puts "\t\t" + format_stats(campaign[:stats])
70
+ end
71
+ if campaign[:segmented_stats]
72
+ campaign[:segmented_stats].each do |stats|
73
+ segment_key_str = stats[:segment_key][:date_key][:date]
74
+ puts "\tCampaign segmented stat for month of %s" % segment_key_str
75
+ puts "\t\t" + format_stats(stats)
76
+ end
77
+ end
78
+ end
79
+ if page[:summary_stats]
80
+ page[:summary_stats].each do |stats|
81
+ puts "\tSummary of type %s" % stats[:summary_type]
82
+ puts "\t\t" + format_stats(stats)
83
+ end
84
+ end
85
+ end
86
+
87
+ def format_stats(stats)
88
+ return ("Views: %s, Cost: %s, Avg. CPC: %s, Avg. CPV: %s, " +
89
+ "Avg. CPM: %s, 25%%: %s, 50%%: %s, 75%%: %s, 100%%: %s") % [
90
+ stats[:views].nil? ? '--' : stats[:views],
91
+ stats[:cost].nil? ? '--' : stats[:cost][:micro_amount],
92
+ stats[:average_cpc].nil? ? '--' : stats[:average_cpc][:micro_amount],
93
+ stats[:average_cpv].nil? ? '--' : stats[:average_cpv][:micro_amount],
94
+ stats[:average_cpm].nil? ? '--' : stats[:average_cpm][:micro_amount],
95
+ stats[:quartile25_percents].nil? ? '--' : stats[:quartile25_percents],
96
+ stats[:quartile50_percents].nil? ? '--' : stats[:quartile50_percents],
97
+ stats[:quartile75_percents].nil? ? '--' : stats[:quartile75_percents],
98
+ stats[:quartile100_percents].nil? ? '--' : stats[:quartile100_percents]
99
+ ]
100
+ end
101
+
102
+ if __FILE__ == $0
103
+ API_VERSION = :v201209
104
+ PAGE_SIZE = 500
105
+
106
+ begin
107
+ # Campaign ID to get stats for.
108
+ campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
109
+ get_campaign_stats(campaign_id)
110
+
111
+ # HTTP errors.
112
+ rescue AdsCommon::Errors::HttpError => e
113
+ puts 'HTTP Error: %s' % e
114
+
115
+ # API errors.
116
+ rescue AdwordsApi::Errors::ApiException => e
117
+ puts 'Message: %s' % e.message
118
+ puts 'Errors:'
119
+ e.errors.each_with_index do |error, index|
120
+ puts "\tError [%d]:" % (index + 1)
121
+ error.each do |field, value|
122
+ puts "\t\t%s: %s" % [field, value]
123
+ end
124
+ end
125
+ end
126
+ end
@@ -3,7 +3,7 @@
3
3
  #
4
4
  # Author:: api.dklimkin@gmail.com (Danial Klimkin)
5
5
  #
6
- # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
+ # Copyright:: Copyright 2013, Google Inc. All Rights Reserved.
7
7
  #
8
8
  # License:: Licensed under the Apache License, Version 2.0 (the "License");
9
9
  # you may not use this file except in compliance with the License.
@@ -18,13 +18,17 @@
18
18
  # See the License for the specific language governing permissions and
19
19
  # limitations under the License.
20
20
  #
21
- # This example illustrates how to retrieve all the campaigns for an account.
21
+ # This example illustrates how to retrieve all non-deleted video campaigns for
22
+ # an account.
22
23
  #
23
- # Tags: CampaignService.get
24
+ # Note: AdWords for Video API is a Beta feature.
25
+ #
26
+ # Tags: VideoCampaignService.get
24
27
 
25
28
  require 'adwords_api'
29
+ require 'date'
26
30
 
27
- def get_campaigns()
31
+ def get_video_campaigns()
28
32
  # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
29
33
  # when called without parameters.
30
34
  adwords = AdwordsApi::Api.new
@@ -33,14 +37,11 @@ def get_campaigns()
33
37
  # the configuration file or provide your own logger:
34
38
  # adwords.logger = Logger.new('adwords_xml.log')
35
39
 
36
- campaign_srv = adwords.service(:CampaignService, API_VERSION)
40
+ video_campaign_srv = adwords.service(:VideoCampaignService, API_VERSION)
37
41
 
38
- # Get all the campaigns for this account.
42
+ # Get all active and paused campaigns for this account.
39
43
  selector = {
40
- :fields => ['Id', 'Name', 'Status'],
41
- :ordering => [
42
- {:field => 'Name', :sort_order => 'ASCENDING'}
43
- ],
44
+ :campaign_statuses => ['ACTIVE', 'PAUSED'],
44
45
  :paging => {
45
46
  :start_index => 0,
46
47
  :number_results => PAGE_SIZE
@@ -51,7 +52,7 @@ def get_campaigns()
51
52
  offset, page = 0, {}
52
53
 
53
54
  begin
54
- page = campaign_srv.get(selector)
55
+ page = video_campaign_srv.get(selector)
55
56
  if page[:entries]
56
57
  page[:entries].each do |campaign|
57
58
  puts "Campaign ID %d, name '%s' and status '%s'" %
@@ -69,19 +70,19 @@ def get_campaigns()
69
70
  end
70
71
 
71
72
  if __FILE__ == $0
72
- API_VERSION = :v201206
73
+ API_VERSION = :v201209
73
74
  PAGE_SIZE = 500
74
75
 
75
76
  begin
76
- get_campaigns()
77
+ get_video_campaigns()
77
78
 
78
79
  # HTTP errors.
79
80
  rescue AdsCommon::Errors::HttpError => e
80
- puts "HTTP Error: %s" % e
81
+ puts 'HTTP Error: %s' % e
81
82
 
82
83
  # API errors.
83
84
  rescue AdwordsApi::Errors::ApiException => e
84
- puts "Message: %s" % e.message
85
+ puts 'Message: %s' % e.message
85
86
  puts 'Errors:'
86
87
  e.errors.each_with_index do |error, index|
87
88
  puts "\tError [%d]:" % (index + 1)
@@ -0,0 +1,139 @@
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 creates a shared list of negative broad match keywords, it then
22
+ # attaches them to a campaign.
23
+ #
24
+ # Note: Shared sets is a Beta feature.
25
+ #
26
+ # Tags: SharedSetService.mutate, CampaignSharedSetService.mutate
27
+
28
+ require 'adwords_api'
29
+ require 'date'
30
+
31
+ def create_and_attach_shared_keyword_set(campaign_id)
32
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
33
+ # when called without parameters.
34
+ adwords = AdwordsApi::Api.new
35
+
36
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
37
+ # the configuration file or provide your own logger:
38
+ # adwords.logger = Logger.new('adwords_xml.log')
39
+
40
+ shared_set_srv = adwords.service(:SharedSetService, API_VERSION)
41
+ shared_criterion_srv = adwords.service(:SharedCriterionService, API_VERSION)
42
+ campaign_shared_set_srv =
43
+ adwords.service(:CampaignSharedSetService, API_VERSION)
44
+
45
+ # Keywords to create a shared set of.
46
+ keywords = ['mars cruise', 'mars hotels']
47
+
48
+ # Create shared negative keyword set.
49
+ shared_set = {
50
+ :name => 'API Negative keyword list - %d' % (Time.new.to_f * 1000).to_i,
51
+ :type => 'NEGATIVE_KEYWORDS'
52
+ }
53
+
54
+ # Add shared set.
55
+ response = shared_set_srv.mutate([
56
+ {:operator => 'ADD', :operand => shared_set}
57
+ ])
58
+
59
+ if response and response[:value]
60
+ shared_set = response[:value].first
61
+ shared_set_id = shared_set[:shared_set_id]
62
+ puts "Shared set with ID %d and name '%s' was successfully added." %
63
+ [shared_set_id, shared_set[:name]]
64
+ else
65
+ raise StandardError, 'No shared set was added'
66
+ end
67
+
68
+ # Add negative keywords to shared set.
69
+ shared_criteria = keywords.map do |keyword|
70
+ {
71
+ :criterion => {
72
+ :xsi_type => 'Keyword',
73
+ :text => keyword,
74
+ :match_type => 'BROAD'
75
+ },
76
+ :negative => true,
77
+ :shared_set_id => shared_set_id
78
+ }
79
+ end
80
+
81
+ operations = shared_criteria.map do |criterion|
82
+ {:operator => 'ADD', :operand => criterion}
83
+ end
84
+
85
+ response = shared_criterion_srv.mutate(operations)
86
+ if response and response[:value]
87
+ response[:value].each do |shared_criterion|
88
+ puts "Added shared criterion ID %d '%s' to shared set with ID %d." %
89
+ [shared_criterion[:criterion][:id],
90
+ shared_criterion[:criterion][:text],
91
+ shared_criterion[:shared_set_id]]
92
+ end
93
+ else
94
+ raise StandardError, 'No shared keyword was added'
95
+ end
96
+
97
+ # Attach the articles to the campaign.
98
+ campaign_set = {
99
+ :campaign_id => campaign_id,
100
+ :shared_set_id => shared_set_id
101
+ }
102
+
103
+ response = campaign_shared_set_srv.mutate([
104
+ {:operator => 'ADD', :operand => campaign_set}
105
+ ])
106
+ if response and response[:value]
107
+ campaign_shared_set = response[:value].first
108
+ puts 'Shared set ID %d was attached to campaign ID %d' %
109
+ [campaign_shared_set[:shared_set_id], campaign_shared_set[:campaign_id]]
110
+ else
111
+ raise StandardError, 'No campaign shared set was added'
112
+ end
113
+ end
114
+
115
+ if __FILE__ == $0
116
+ API_VERSION = :v201302
117
+
118
+ begin
119
+ # Campaign ID to attach shared keyword set to.
120
+ campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
121
+
122
+ create_and_attach_shared_keyword_set(campaign_id)
123
+
124
+ # HTTP errors.
125
+ rescue AdsCommon::Errors::HttpError => e
126
+ puts "HTTP Error: %s" % e
127
+
128
+ # API errors.
129
+ rescue AdwordsApi::Errors::ApiException => e
130
+ puts "Message: %s" % e.message
131
+ puts 'Errors:'
132
+ e.errors.each_with_index do |error, index|
133
+ puts "\tError [%d]:" % (index + 1)
134
+ error.each do |field, value|
135
+ puts "\t\t%s: %s" % [field, value]
136
+ end
137
+ end
138
+ end
139
+ end
@@ -0,0 +1,173 @@
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 demonstrates how to find shared sets, shared set criterions and
22
+ # how to remove them.
23
+ #
24
+ # Note: Shared sets is a Beta feature.
25
+ #
26
+ # Tags: CampaignSharedSetService.get
27
+ # Tags: SharedCriterionService.get, SharedCriterionService.mutate
28
+
29
+ require 'adwords_api'
30
+
31
+ def find_and_remove_criteria_from_shared_set(campaign_id)
32
+ # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
33
+ # when called without parameters.
34
+ adwords = AdwordsApi::Api.new
35
+
36
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
37
+ # the configuration file or provide your own logger:
38
+ # adwords.logger = Logger.new('adwords_xml.log')
39
+
40
+ campaign_shared_set_srv =
41
+ adwords.service(:CampaignSharedSetService, API_VERSION)
42
+ shared_criterion_srv = adwords.service(:SharedCriterionService, API_VERSION)
43
+
44
+ shared_set_ids = []
45
+ criterion_ids = []
46
+
47
+ # First, retrieve all shared sets associated with the campaign.
48
+
49
+ # Create selector for shared sets to:
50
+ # - filter by campaign ID,
51
+ # - filter by shared set type.
52
+ selector = {
53
+ :fields => ['SharedSetId', 'CampaignId', 'SharedSetName', 'SharedSetType',
54
+ 'Status'],
55
+ :predicates => [
56
+ {:field => 'CampaignId', :operator => 'EQUALS', :values => [campaign_id]},
57
+ {:field => 'SharedSetType', :operator => 'IN', :values =>
58
+ ['NEGATIVE_KEYWORDS', 'NEGATIVE_PLACEMENTS']}
59
+ ],
60
+ :paging => {
61
+ :start_index => 0,
62
+ :number_results => PAGE_SIZE
63
+ }
64
+ }
65
+
66
+ # Set initial values.
67
+ offset, page = 0, {}
68
+
69
+ begin
70
+ page = campaign_shared_set_srv.get(selector)
71
+ if page[:entries]
72
+ page[:entries].each do |shared_set|
73
+ puts "Campaign shared set ID %d and name '%s'" %
74
+ [shared_set[:shared_set_id], shared_set[:shared_set_name]]
75
+ shared_set_ids << shared_set[:shared_set_id]
76
+ end
77
+ # Increment values to request the next page.
78
+ offset += PAGE_SIZE
79
+ selector[:paging][:start_index] = offset
80
+ end
81
+ end while page[:total_num_entries] > offset
82
+
83
+ # Next, Retrieve criterion IDs for all found shared sets.
84
+ selector = {
85
+ :fields => ['SharedSetId', 'Id', 'KeywordText', 'KeywordMatchType',
86
+ 'PlacementUrl'],
87
+ :predicates => [
88
+ {:field => 'SharedSetId', :operator => 'IN', :values => shared_set_ids}
89
+ ],
90
+ :paging => {
91
+ :start_index => 0,
92
+ :number_results => PAGE_SIZE
93
+ }
94
+ }
95
+
96
+ # Set initial values.
97
+ offset, page = 0, {}
98
+
99
+ begin
100
+ page = shared_criterion_srv.get(selector)
101
+ if page[:entries]
102
+ page[:entries].each do |shared_criterion|
103
+ if shared_criterion[:criterion][:type] == 'KEYWORD'
104
+ puts "Shared negative keyword with ID %d and text '%s' was found." %
105
+ [shared_criterion[:criterion][:id],
106
+ shared_criterion[:criterion][:text]]
107
+ elsif shared_criterion[:criterion][:type] == 'PLACEMENT'
108
+ puts "Shared negative placement with ID %d and url '%s' was found." %
109
+ [shared_criterion[:criterion][:id],
110
+ shared_criterion[:criterion][:url]]
111
+ else
112
+ puts 'Shared criterion with ID %d was found.' %
113
+ [shared_criterion[:criterion][:id]]
114
+ end
115
+ criterion_ids << {
116
+ :shared_set_id => shared_criterion[:shared_set_id],
117
+ :criterion_id => shared_criterion[:criterion][:id]
118
+ }
119
+ end
120
+ # Increment values to request the next page.
121
+ offset += PAGE_SIZE
122
+ selector[:paging][:start_index] = offset
123
+ end
124
+ end while page[:total_num_entries] > offset
125
+
126
+ # Finally, remove the criteria.
127
+ operations = criterion_ids.map do |criterion|
128
+ {
129
+ :operator => 'REMOVE',
130
+ :operand => {
131
+ :criterion => {:id => criterion[:criterion_id]},
132
+ :shared_set_id => criterion[:shared_set_id]
133
+ }
134
+ }
135
+ end
136
+
137
+ response = shared_criterion_srv.mutate(operations)
138
+ if response and response[:value]
139
+ response[:value].each do |criterion|
140
+ puts "Criterion ID %d was successfully removed from shared set ID %d." %
141
+ [criterion[:criterion][:id], criterion[:shared_set_id]]
142
+ end
143
+ else
144
+ puts 'No shared criteria were removed.'
145
+ end
146
+ end
147
+
148
+ if __FILE__ == $0
149
+ API_VERSION = :v201302
150
+ PAGE_SIZE = 500
151
+
152
+ begin
153
+ # ID of a campaign to remove shared criteria from.
154
+ campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
155
+
156
+ find_and_remove_criteria_from_shared_set(campaign_id)
157
+
158
+ # HTTP errors.
159
+ rescue AdsCommon::Errors::HttpError => e
160
+ puts "HTTP Error: %s" % e
161
+
162
+ # API errors.
163
+ rescue AdwordsApi::Errors::ApiException => e
164
+ puts "Message: %s" % e.message
165
+ puts 'Errors:'
166
+ e.errors.each_with_index do |error, index|
167
+ puts "\tError [%d]:" % (index + 1)
168
+ error.each do |field, value|
169
+ puts "\t\t%s: %s" % [field, value]
170
+ end
171
+ end
172
+ end
173
+ end