google-adx-buyer-api 0.4.0 → 0.4.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (185) hide show
  1. data/ChangeLog +4 -0
  2. data/README +39 -25
  3. data/examples/v201109/account_management/get_account_changes.rb +137 -0
  4. data/examples/{v201008 → v201109/basic_operations}/add_ad_group.rb +18 -28
  5. data/examples/{v201003 → v201109/basic_operations}/add_campaign.rb +28 -30
  6. data/examples/{v201008/add_ad_group_criteria.rb → v201109/basic_operations/add_placements.rb} +45 -46
  7. data/examples/v201109/basic_operations/add_thirdparty_redirect_ad.rb +105 -0
  8. data/examples/{v201008 → v201109/basic_operations}/delete_ad.rb +21 -35
  9. data/examples/{v201101 → v201109/basic_operations}/delete_ad_group.rb +18 -28
  10. data/examples/v201109/{delete_campaign.rb → basic_operations/delete_campaign.rb} +18 -28
  11. data/examples/{v201008/delete_ad_group_criterion.rb → v201109/basic_operations/delete_placement.rb} +24 -33
  12. data/examples/{v201101/get_all_ad_groups.rb → v201109/basic_operations/get_ad_groups.rb} +21 -35
  13. data/examples/{v201101/get_all_campaigns.rb → v201109/basic_operations/get_campaigns.rb} +14 -23
  14. data/examples/{v201008/get_all_ad_group_criteria.rb → v201109/basic_operations/get_placements.rb} +37 -36
  15. data/examples/v201109/{get_all_ads.rb → basic_operations/get_thirdparty_redirect_ads.rb} +37 -36
  16. data/examples/v201109/{get_client_customer_id.rb → basic_operations/pause_ad.rb} +27 -33
  17. data/examples/{v201003 → v201109/basic_operations}/update_ad_group.rb +18 -32
  18. data/examples/{v201101 → v201109/basic_operations}/update_campaign.rb +19 -33
  19. data/examples/{v201003/delete_ad_group_criterion.rb → v201109/basic_operations/update_placement.rb} +35 -36
  20. data/examples/v201109/{perform_mutate_job.rb → campaign_management/add_placements_in_bulk.rb} +11 -11
  21. data/examples/v201109/{get_all_disapproved_ads.rb → campaign_management/get_all_disapproved_ads.rb} +18 -28
  22. data/examples/v201109/error_handling/handle_captcha_challenge.rb +93 -0
  23. data/examples/v201109/error_handling/handle_partial_failures.rb +117 -0
  24. data/examples/v201109/error_handling/handle_policy_violation_error.rb +138 -0
  25. data/examples/v201109/error_handling/handle_two_factor_authorization_error.rb +87 -0
  26. data/examples/v201109/misc/get_all_images_and_videos.rb +101 -0
  27. data/examples/{v201101 → v201109/misc}/upload_image.rb +23 -33
  28. data/examples/v201109/{get_all_campaigns.rb → misc/use_oauth.rb} +42 -31
  29. data/examples/{v201003/get_related_placements.rb → v201109/optimization/get_placement_ideas.rb} +32 -37
  30. data/examples/{v201008/add_user_list.rb → v201109/remarketing/add_audience.rb} +49 -34
  31. data/examples/v201109/{add_conversion.rb → remarketing/add_conversion_tracker.rb} +31 -35
  32. data/examples/v201109/{download_adhoc_report.rb → reporting/download_criteria_report.rb} +24 -24
  33. data/examples/{v201008/download_report.rb → v201109/reporting/download_defined_report.rb} +20 -29
  34. data/examples/v201109/reporting/get_campaign_stats.rb +105 -0
  35. data/examples/{v201008/get_all_report_definitions.rb → v201109/reporting/get_defined_reports.rb} +18 -27
  36. data/examples/v201109/{get_all_carriers.rb → reporting/get_report_fields.rb} +18 -19
  37. data/examples/v201109/reporting/parallel_report_download.rb +159 -0
  38. data/examples/v201109/{add_campaign_targeting_criteria.rb → targeting/add_campaign_targeting_criteria.rb} +27 -19
  39. data/examples/v201109/targeting/get_campaign_targeting_criteria.rb +104 -0
  40. data/examples/v201109/{get_all_languages.rb → targeting/get_targetable_languages_and_carriers.rb} +18 -9
  41. data/examples/v201109/{get_location_criteria.rb → targeting/lookup_location.rb} +7 -7
  42. metadata +59 -191
  43. data/Rakefile +0 -50
  44. data/examples/v201003/add_ad_group.rb +0 -98
  45. data/examples/v201003/add_ad_group_criteria.rb +0 -100
  46. data/examples/v201003/add_ads.rb +0 -110
  47. data/examples/v201003/add_negative_campaign_criterion.rb +0 -95
  48. data/examples/v201003/add_placement_performance_report_definition.rb +0 -108
  49. data/examples/v201003/check_campaigns.rb +0 -132
  50. data/examples/v201003/delete_ad.rb +0 -94
  51. data/examples/v201003/delete_ad_group.rb +0 -86
  52. data/examples/v201003/delete_campaign.rb +0 -87
  53. data/examples/v201003/download_report.rb +0 -76
  54. data/examples/v201003/get_all_active_ad_group_criteria.rb +0 -93
  55. data/examples/v201003/get_all_ad_group_criteria.rb +0 -91
  56. data/examples/v201003/get_all_ad_groups.rb +0 -88
  57. data/examples/v201003/get_all_ads.rb +0 -91
  58. data/examples/v201003/get_all_campaign_targets.rb +0 -83
  59. data/examples/v201003/get_all_campaigns.rb +0 -83
  60. data/examples/v201003/get_all_disapproved_ads.rb +0 -94
  61. data/examples/v201003/get_all_images.rb +0 -88
  62. data/examples/v201003/get_all_paused_campaigns.rb +0 -86
  63. data/examples/v201003/get_all_report_definitions.rb +0 -84
  64. data/examples/v201003/get_criterion_bid_landscape.rb +0 -105
  65. data/examples/v201003/get_geo_location_info.rb +0 -108
  66. data/examples/v201003/get_report_fields.rb +0 -81
  67. data/examples/v201003/perform_bulk_mutate_job.rb +0 -222
  68. data/examples/v201003/set_campaign_targets.rb +0 -124
  69. data/examples/v201003/update_ad.rb +0 -95
  70. data/examples/v201003/update_ad_group_criterion.rb +0 -108
  71. data/examples/v201003/update_campaign.rb +0 -92
  72. data/examples/v201003/upload_image.rb +0 -97
  73. data/examples/v201008/add_ads.rb +0 -110
  74. data/examples/v201008/add_campaign.rb +0 -101
  75. data/examples/v201008/add_negative_campaign_criterion.rb +0 -95
  76. data/examples/v201008/add_placement_performance_report_definition.rb +0 -108
  77. data/examples/v201008/check_campaigns.rb +0 -132
  78. data/examples/v201008/delete_ad_group.rb +0 -86
  79. data/examples/v201008/delete_bulk_mutate_job.rb +0 -96
  80. data/examples/v201008/delete_campaign.rb +0 -87
  81. data/examples/v201008/delete_user_list.rb +0 -87
  82. data/examples/v201008/get_all_account_changes.rb +0 -144
  83. data/examples/v201008/get_all_active_ad_group_criteria.rb +0 -93
  84. data/examples/v201008/get_all_ad_groups.rb +0 -88
  85. data/examples/v201008/get_all_ads.rb +0 -91
  86. data/examples/v201008/get_all_campaign_targets.rb +0 -83
  87. data/examples/v201008/get_all_campaigns.rb +0 -83
  88. data/examples/v201008/get_all_disapproved_ads.rb +0 -94
  89. data/examples/v201008/get_all_images.rb +0 -88
  90. data/examples/v201008/get_all_paused_campaigns.rb +0 -86
  91. data/examples/v201008/get_all_user_lists.rb +0 -84
  92. data/examples/v201008/get_bulk_mutate_job.rb +0 -106
  93. data/examples/v201008/get_campaign_alerts.rb +0 -103
  94. data/examples/v201008/get_criterion_bid_landscape.rb +0 -105
  95. data/examples/v201008/get_geo_location_info.rb +0 -108
  96. data/examples/v201008/get_related_placements.rb +0 -114
  97. data/examples/v201008/get_report_fields.rb +0 -81
  98. data/examples/v201008/perform_bulk_mutate_job.rb +0 -222
  99. data/examples/v201008/set_campaign_targets.rb +0 -124
  100. data/examples/v201008/update_ad.rb +0 -95
  101. data/examples/v201008/update_ad_group.rb +0 -90
  102. data/examples/v201008/update_ad_group_criterion.rb +0 -108
  103. data/examples/v201008/update_campaign.rb +0 -93
  104. data/examples/v201008/update_user_list.rb +0 -91
  105. data/examples/v201008/upload_image.rb +0 -97
  106. data/examples/v201101/add_ad_group.rb +0 -98
  107. data/examples/v201101/add_ad_group_criteria.rb +0 -100
  108. data/examples/v201101/add_ads.rb +0 -110
  109. data/examples/v201101/add_campaign.rb +0 -108
  110. data/examples/v201101/add_conversion.rb +0 -97
  111. data/examples/v201101/add_negative_campaign_criterion.rb +0 -95
  112. data/examples/v201101/add_placement_performance_report_definition.rb +0 -108
  113. data/examples/v201101/add_rtb_campaign.rb +0 -113
  114. data/examples/v201101/add_user_list.rb +0 -122
  115. data/examples/v201101/check_campaigns.rb +0 -132
  116. data/examples/v201101/delete_ad.rb +0 -94
  117. data/examples/v201101/delete_ad_group_criterion.rb +0 -95
  118. data/examples/v201101/delete_bulk_mutate_job.rb +0 -96
  119. data/examples/v201101/delete_campaign.rb +0 -87
  120. data/examples/v201101/delete_user_list.rb +0 -87
  121. data/examples/v201101/download_report.rb +0 -76
  122. data/examples/v201101/get_ad_group_bid_landscape.rb +0 -103
  123. data/examples/v201101/get_all_account_changes.rb +0 -146
  124. data/examples/v201101/get_all_active_ad_group_criteria.rb +0 -106
  125. data/examples/v201101/get_all_ad_group_criteria.rb +0 -97
  126. data/examples/v201101/get_all_ads.rb +0 -99
  127. data/examples/v201101/get_all_campaign_targets.rb +0 -83
  128. data/examples/v201101/get_all_conversions.rb +0 -88
  129. data/examples/v201101/get_all_disapproved_ads.rb +0 -102
  130. data/examples/v201101/get_all_images.rb +0 -90
  131. data/examples/v201101/get_all_paused_campaigns.rb +0 -92
  132. data/examples/v201101/get_all_report_definitions.rb +0 -84
  133. data/examples/v201101/get_all_user_lists.rb +0 -87
  134. data/examples/v201101/get_bulk_mutate_job.rb +0 -106
  135. data/examples/v201101/get_campaign_alerts.rb +0 -103
  136. data/examples/v201101/get_criterion_bid_landscape.rb +0 -102
  137. data/examples/v201101/get_geo_location_info.rb +0 -108
  138. data/examples/v201101/get_related_placements.rb +0 -114
  139. data/examples/v201101/get_report_fields.rb +0 -81
  140. data/examples/v201101/perform_bulk_mutate_job.rb +0 -222
  141. data/examples/v201101/set_campaign_targets.rb +0 -111
  142. data/examples/v201101/update_ad.rb +0 -95
  143. data/examples/v201101/update_ad_group.rb +0 -90
  144. data/examples/v201101/update_ad_group_criterion.rb +0 -108
  145. data/examples/v201101/update_conversion.rb +0 -96
  146. data/examples/v201101/update_user_list.rb +0 -91
  147. data/examples/v201109/add_ad_group.rb +0 -98
  148. data/examples/v201109/add_ad_group_criteria.rb +0 -100
  149. data/examples/v201109/add_ads.rb +0 -110
  150. data/examples/v201109/add_campaign.rb +0 -108
  151. data/examples/v201109/add_negative_campaign_criterion.rb +0 -95
  152. data/examples/v201109/add_rtb_campaign.rb +0 -113
  153. data/examples/v201109/add_user_list.rb +0 -122
  154. data/examples/v201109/check_campaigns.rb +0 -132
  155. data/examples/v201109/delete_ad.rb +0 -94
  156. data/examples/v201109/delete_ad_group.rb +0 -86
  157. data/examples/v201109/delete_ad_group_criterion.rb +0 -95
  158. data/examples/v201109/delete_bulk_mutate_job.rb +0 -96
  159. data/examples/v201109/delete_user_list.rb +0 -87
  160. data/examples/v201109/download_report.rb +0 -76
  161. data/examples/v201109/get_ad_group_bid_landscape.rb +0 -103
  162. data/examples/v201109/get_all_account_changes.rb +0 -146
  163. data/examples/v201109/get_all_active_ad_group_criteria.rb +0 -106
  164. data/examples/v201109/get_all_ad_group_criteria.rb +0 -98
  165. data/examples/v201109/get_all_ad_groups.rb +0 -94
  166. data/examples/v201109/get_all_campaign_targets.rb +0 -83
  167. data/examples/v201109/get_all_conversions.rb +0 -88
  168. data/examples/v201109/get_all_images.rb +0 -90
  169. data/examples/v201109/get_all_paused_campaigns.rb +0 -92
  170. data/examples/v201109/get_all_report_definitions.rb +0 -84
  171. data/examples/v201109/get_all_user_lists.rb +0 -87
  172. data/examples/v201109/get_bulk_mutate_job.rb +0 -106
  173. data/examples/v201109/get_campaign_alerts.rb +0 -103
  174. data/examples/v201109/get_criterion_bid_landscape.rb +0 -102
  175. data/examples/v201109/get_geo_location_info.rb +0 -108
  176. data/examples/v201109/get_related_placements.rb +0 -114
  177. data/examples/v201109/get_report_fields.rb +0 -81
  178. data/examples/v201109/perform_bulk_mutate_job.rb +0 -222
  179. data/examples/v201109/update_ad.rb +0 -95
  180. data/examples/v201109/update_ad_group.rb +0 -90
  181. data/examples/v201109/update_ad_group_criterion.rb +0 -108
  182. data/examples/v201109/update_campaign.rb +0 -93
  183. data/examples/v201109/update_conversion.rb +0 -96
  184. data/examples/v201109/update_user_list.rb +0 -91
  185. data/examples/v201109/upload_image.rb +0 -97
@@ -1,4 +1,5 @@
1
- #!/usr/bin/ruby
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
2
3
  #
3
4
  # Author:: api.sgomes@gmail.com (Sérgio Gomes)
4
5
  #
@@ -22,13 +23,9 @@
22
23
  #
23
24
  # Tags: AdGroupService.get
24
25
 
25
- require 'rubygems'
26
- gem 'google-adwords-api'
27
26
  require 'adwords_api'
28
27
 
29
- API_VERSION = :v201101
30
-
31
- def get_all_ad_groups()
28
+ def get_all_ad_groups(campaign_id)
32
29
  # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
33
30
  # when called without parameters.
34
31
  adwords = AdwordsApi::Api.new
@@ -39,8 +36,6 @@ def get_all_ad_groups()
39
36
 
40
37
  ad_group_srv = adwords.service(:AdGroupService, API_VERSION)
41
38
 
42
- campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
43
-
44
39
  # Get all the ad groups for this campaign.
45
40
  selector = {
46
41
  :fields => ['Id', 'Name'],
@@ -52,42 +47,33 @@ def get_all_ad_groups()
52
47
  }]
53
48
  }
54
49
  response = ad_group_srv.get(selector)
55
- if response and response[:entries]
56
- ad_groups = response[:entries]
57
- puts "Campaign ##{campaign_id} has #{ad_groups.length} ad group(s)."
58
- ad_groups.each do |ad_group|
59
- puts " Ad group name is \"#{ad_group[:name]}\" and id is " +
60
- "#{ad_group[:id]}."
61
- end
62
- else
63
- puts "No ad groups found for campaign ##{campaign_id}."
50
+ ad_groups = response[:entries]
51
+ puts "Campaign ID %d has %d ad group(s)." % [campaign_id, ad_groups.length]
52
+ ad_groups.each do |ad_group|
53
+ puts "\tAd group name is '%s' and ID is %d" %
54
+ [ad_group[:name], ad_group[:id]]
64
55
  end
65
56
  end
66
57
 
67
58
  if __FILE__ == $0
59
+ API_VERSION = :v201109
60
+
68
61
  begin
69
- get_all_ad_groups()
62
+ campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
63
+ get_all_ad_groups(campaign_id)
70
64
 
71
- # Connection error. Likely transitory.
72
- rescue Errno::ECONNRESET, SOAP::HTTPStreamError, SocketError => e
73
- puts 'Connection Error: %s' % e
74
- puts 'Source: %s' % e.backtrace.first
65
+ # HTTP errors.
66
+ rescue AdsCommon::Errors::HttpError => e
67
+ puts "HTTP Error: %s" % e
75
68
 
76
- # API Error.
69
+ # API errors.
77
70
  rescue AdwordsApi::Errors::ApiException => e
78
- puts 'API Exception caught.'
79
- puts 'Message: %s' % e.message
80
- puts 'Code: %d' % e.code if e.code
81
- puts 'Trigger: %s' % e.trigger if e.trigger
71
+ puts "Message: %s" % e.message
82
72
  puts 'Errors:'
83
- if e.errors
84
- e.errors.each_with_index do |error, index|
85
- puts ' %d. Error type is %s. Fields:' % [index + 1, error[:xsi_type]]
86
- error.each_pair do |field, value|
87
- if field != :xsi_type
88
- puts ' %s: %s' % [field, value]
89
- end
90
- end
73
+ e.errors.each_with_index do |error, index|
74
+ puts "\tError [%d]:" % (index + 1)
75
+ error.each do |field, value|
76
+ puts "\t\t%s: %s" % [field, value]
91
77
  end
92
78
  end
93
79
  end
@@ -1,4 +1,5 @@
1
- #!/usr/bin/ruby
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
2
3
  #
3
4
  # Author:: api.sgomes@gmail.com (Sérgio Gomes)
4
5
  #
@@ -21,12 +22,8 @@
21
22
  #
22
23
  # Tags: CampaignService.get
23
24
 
24
- require 'rubygems'
25
- gem 'google-adwords-api'
26
25
  require 'adwords_api'
27
26
 
28
- API_VERSION = :v201101
29
-
30
27
  def get_all_campaigns()
31
28
  # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
32
29
  # when called without parameters.
@@ -52,34 +49,28 @@ def get_all_campaigns()
52
49
  "and status is \"#{campaign[:status]}\"."
53
50
  end
54
51
  else
55
- puts "No campaigns were found."
52
+ puts 'No campaigns were found.'
56
53
  end
57
54
  end
58
55
 
59
56
  if __FILE__ == $0
57
+ API_VERSION = :v201109
58
+
60
59
  begin
61
60
  get_all_campaigns()
62
61
 
63
- # Connection error. Likely transitory.
64
- rescue Errno::ECONNRESET, SOAP::HTTPStreamError, SocketError => e
65
- puts 'Connection Error: %s' % e
66
- puts 'Source: %s' % e.backtrace.first
62
+ # HTTP errors.
63
+ rescue AdsCommon::Errors::HttpError => e
64
+ puts "HTTP Error: %s" % e
67
65
 
68
- # API Error.
66
+ # API errors.
69
67
  rescue AdwordsApi::Errors::ApiException => e
70
- puts 'API Exception caught.'
71
- puts 'Message: %s' % e.message
72
- puts 'Code: %d' % e.code if e.code
73
- puts 'Trigger: %s' % e.trigger if e.trigger
68
+ puts "Message: %s" % e.message
74
69
  puts 'Errors:'
75
- if e.errors
76
- e.errors.each_with_index do |error, index|
77
- puts ' %d. Error type is %s. Fields:' % [index + 1, error[:xsi_type]]
78
- error.each_pair do |field, value|
79
- if field != :xsi_type
80
- puts ' %s: %s' % [field, value]
81
- end
82
- end
70
+ e.errors.each_with_index do |error, index|
71
+ puts "\tError [%d]:" % (index + 1)
72
+ error.each do |field, value|
73
+ puts "\t\t%s: %s" % [field, value]
83
74
  end
84
75
  end
85
76
  end
@@ -1,6 +1,7 @@
1
- #!/usr/bin/ruby
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
2
3
  #
3
- # Author:: api.sgomes@gmail.com (Sérgio Gomes)
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
5
  #
5
6
  # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
7
  #
@@ -17,18 +18,14 @@
17
18
  # See the License for the specific language governing permissions and
18
19
  # limitations under the License.
19
20
  #
20
- # This example illustrates how to retrieve all the criteria for an ad group.
21
- # To add criteria to an existing ad group, run add_ad_group_criteria.rb.
21
+ # This example illustrates how to retrieve all the placements for an ad group.
22
+ # To add a placement to an existing ad group, run add_placements.rb.
22
23
  #
23
24
  # Tags: AdGroupCriterionService.get
24
25
 
25
- require 'rubygems'
26
- gem 'google-adwords-api'
27
26
  require 'adwords_api'
28
27
 
29
- API_VERSION = :v201008
30
-
31
- def get_all_ad_group_criteria()
28
+ def get_placements(ad_group_id)
32
29
  # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
33
30
  # when called without parameters.
34
31
  adwords = AdwordsApi::Api.new
@@ -40,51 +37,55 @@ def get_all_ad_group_criteria()
40
37
  ad_group_criterion_srv =
41
38
  adwords.service(:AdGroupCriterionService, API_VERSION)
42
39
 
43
- ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
44
-
45
40
  # Get all the criteria for this ad group.
46
41
  selector = {
47
- :id_filters => [{
48
- :ad_group_id => ad_group_id
49
- }]
42
+ :fields => ['Id', 'PlacementUrl'],
43
+ :ordering => [
44
+ {:field => 'AdGroupId', :sort_order => 'ASCENDING'}
45
+ ],
46
+ :predicates => [
47
+ {:field => 'AdGroupId', :operator => 'IN', :values => [ad_group_id]},
48
+ {
49
+ :field => 'CriteriaType',
50
+ :operator => 'EQUALS',
51
+ :values => ['PLACEMENT']
52
+ }
53
+ ]
50
54
  }
51
55
  response = ad_group_criterion_srv.get(selector)
52
56
  if response and response[:entries]
53
57
  ad_group_criteria = response[:entries]
54
- puts "Ad group ##{ad_group_id} has #{ad_group_criteria.length} criteria."
58
+ puts "Ad group ID %d has %d placements." %
59
+ [ad_group_id, ad_group_criteria.length]
55
60
  ad_group_criteria.each do |ad_group_criterion|
56
- puts " Criterion id is #{ad_group_criterion[:criterion][:id]} and " +
57
- "type is #{ad_group_criterion[:criterion][:xsi_type]}."
61
+ puts "\tPlacement ID is %d and URL is '%s'." %
62
+ [ad_group_criterion[:criterion][:id],
63
+ ad_group_criterion[:criterion][:placement_url]]
58
64
  end
59
65
  else
60
- puts "No criteria found for ad group ##{ad_group_id}."
66
+ puts "No placements found for ad group ID %d" % ad_group_id
61
67
  end
62
68
  end
63
69
 
64
70
  if __FILE__ == $0
71
+ API_VERSION = :v201109
72
+
65
73
  begin
66
- get_all_ad_group_criteria()
74
+ ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
75
+ get_placements(ad_group_id)
67
76
 
68
- # Connection error. Likely transitory.
69
- rescue Errno::ECONNRESET, SOAP::HTTPStreamError, SocketError => e
70
- puts 'Connection Error: %s' % e
71
- puts 'Source: %s' % e.backtrace.first
77
+ # HTTP errors.
78
+ rescue AdsCommon::Errors::HttpError => e
79
+ puts "HTTP Error: %s" % e
72
80
 
73
- # API Error.
81
+ # API errors.
74
82
  rescue AdwordsApi::Errors::ApiException => e
75
- puts 'API Exception caught.'
76
- puts 'Message: %s' % e.message
77
- puts 'Code: %d' % e.code if e.code
78
- puts 'Trigger: %s' % e.trigger if e.trigger
83
+ puts "Message: %s" % e.message
79
84
  puts 'Errors:'
80
- if e.errors
81
- e.errors.each_with_index do |error, index|
82
- puts ' %d. Error type is %s. Fields:' % [index + 1, error[:xsi_type]]
83
- error.each_pair do |field, value|
84
- if field != :xsi_type
85
- puts ' %s: %s' % [field, value]
86
- end
87
- end
85
+ e.errors.each_with_index do |error, index|
86
+ puts "\tError [%d]:" % (index + 1)
87
+ error.each do |field, value|
88
+ puts "\t\t%s: %s" % [field, value]
88
89
  end
89
90
  end
90
91
  end
@@ -1,8 +1,9 @@
1
- #!/usr/bin/ruby
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
2
3
  #
3
- # Author:: api.sgomes@gmail.com (Sérgio Gomes)
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
5
  #
5
- # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
+ # Copyright:: Copyright 2012, Google Inc. All Rights Reserved.
6
7
  #
7
8
  # License:: Licensed under the Apache License, Version 2.0 (the "License");
8
9
  # you may not use this file except in compliance with the License.
@@ -17,18 +18,15 @@
17
18
  # See the License for the specific language governing permissions and
18
19
  # limitations under the License.
19
20
  #
20
- # This example illustrates how to retrieve all the ads for an ad group. To add
21
- # ads to an existing ad group, run add_ads.rb.
21
+ # This example illustrates how to retrieve all third party redirect ads for an
22
+ # ad group. To add third party redirect ad to an existing ad group, run
23
+ # add_thirdparty_redirect_ad.rb.
22
24
  #
23
25
  # Tags: AdGroupAdService.get
24
26
 
25
- require 'rubygems'
26
- gem 'google-adwords-api'
27
27
  require 'adwords_api'
28
28
 
29
- API_VERSION = :v201109
30
-
31
- def get_all_ads()
29
+ def get_all_ads(ad_group_id)
32
30
  # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
33
31
  # when called without parameters.
34
32
  adwords = AdwordsApi::Api.new
@@ -39,11 +37,9 @@ def get_all_ads()
39
37
 
40
38
  ad_group_ad_srv = adwords.service(:AdGroupAdService, API_VERSION)
41
39
 
42
- ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
43
-
44
- # Get all the ads for this ad group.
40
+ # Create selector to get all third party redirect ads for this ad group.
45
41
  selector = {
46
- :fields => ['Id', 'Status'],
42
+ :fields => ['Id', 'Status', 'Url', 'DisplayUrl'],
47
43
  :ordering => [{:field => 'Id', :sort_order => 'ASCENDING'}],
48
44
  # By default, disabled ads aren't returned by the selector. To return them,
49
45
  # include the DISABLED status in a predicate.
@@ -53,46 +49,51 @@ def get_all_ads()
53
49
  :field => 'Status',
54
50
  :operator => 'IN',
55
51
  :values => ['ENABLED', 'PAUSED', 'DISABLED']
52
+ },
53
+ {
54
+ :field => 'AdType',
55
+ :operator => 'EQUALS',
56
+ :values => ['THIRD_PARTY_REDIRECT_AD']
56
57
  }
57
58
  ]
58
59
  }
60
+
61
+ # Request the ads.
59
62
  response = ad_group_ad_srv.get(selector)
60
63
  if response and response[:entries]
61
64
  ads = response[:entries]
62
- puts "Ad group ##{ad_group_id} has #{ads.length} ad(s)."
65
+ puts "Ad group ID %d has %d third party redirect ads." %
66
+ [ad_group_id, ads.length]
63
67
  ads.each do |ad|
64
- puts " Ad id is #{ad[:ad][:id]}, type is #{ad[:ad][:xsi_type]} and " +
65
- "status is \"#{ad[:status]}\"."
68
+ puts "\tAd ID is %d, type is '%s', status is '%s'" %
69
+ [ad[:ad][:id], ad[:ad][:xsi_type], ad[:status]]
70
+ puts "\tURL: %s" % ad[:url]
71
+ puts "\tDisplay URL: %s" % ad[:display_url]
66
72
  end
67
73
  else
68
- puts "No ads found for ad group ##{ad_group_id}."
74
+ puts "No ads found for ad group ID %d." % ad_group_id
69
75
  end
70
76
  end
71
77
 
72
78
  if __FILE__ == $0
79
+ API_VERSION = :v201109
80
+
73
81
  begin
74
- get_all_ads()
82
+ ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
83
+ get_all_ads(ad_group_id)
75
84
 
76
- # Connection error. Likely transitory.
77
- rescue Errno::ECONNRESET, SOAP::HTTPStreamError, SocketError => e
78
- puts 'Connection Error: %s' % e
79
- puts 'Source: %s' % e.backtrace.first
85
+ # HTTP errors.
86
+ rescue AdsCommon::Errors::HttpError => e
87
+ puts "HTTP Error: %s" % e
80
88
 
81
- # API Error.
89
+ # API errors.
82
90
  rescue AdwordsApi::Errors::ApiException => e
83
- puts 'API Exception caught.'
84
- puts 'Message: %s' % e.message
85
- puts 'Code: %d' % e.code if e.code
86
- puts 'Trigger: %s' % e.trigger if e.trigger
91
+ puts "Message: %s" % e.message
87
92
  puts 'Errors:'
88
- if e.errors
89
- e.errors.each_with_index do |error, index|
90
- puts ' %d. Error type is %s. Fields:' % [index + 1, error[:xsi_type]]
91
- error.each_pair do |field, value|
92
- if field != :xsi_type
93
- puts ' %s: %s' % [field, value]
94
- end
95
- end
93
+ e.errors.each_with_index do |error, index|
94
+ puts "\tError [%d]:" % (index + 1)
95
+ error.each do |field, value|
96
+ puts "\t\t%s: %s" % [field, value]
96
97
  end
97
98
  end
98
99
  end
@@ -1,4 +1,5 @@
1
- #!/usr/bin/ruby
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
2
3
  #
3
4
  # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
5
  #
@@ -17,19 +18,14 @@
17
18
  # See the License for the specific language governing permissions and
18
19
  # limitations under the License.
19
20
  #
20
- # This example illustrates how to find a client customer ID for a client email.
21
- # We recommend to use this script as a one off to convert your identifiers to
22
- # IDs and store them for future use.
21
+ # This example illustrates how to pause an ad, setting its status to 'PAUSED'.
22
+ # To create ads, run add_thirdparty_redirect_ad.rb.
23
23
  #
24
- # Tags: InfoService.get
24
+ # Tags: AdGroupAdService.mutate
25
25
 
26
- require 'rubygems'
27
26
  require 'adwords_api'
28
- require 'adwords_api/utils'
29
27
 
30
- API_VERSION = :v201109
31
-
32
- def get_client_customer_id()
28
+ def pause_ad(ad_group_id, ad_id)
33
29
  # AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
34
30
  # when called without parameters.
35
31
  adwords = AdwordsApi::Api.new
@@ -38,36 +34,34 @@ def get_client_customer_id()
38
34
  # the configuration file or provide your own logger:
39
35
  # adwords.logger = Logger.new('adwords_xml.log')
40
36
 
41
- info_srv = adwords.service(:InfoService, API_VERSION)
42
-
43
- # Email address to find ID for.
44
- client_email = 'INSERT_EMAIL_ADDRESS_HERE'
37
+ ad_group_ad_srv = adwords.service(:AdGroupAdService, API_VERSION)
45
38
 
46
- today = Time.new.strftime('%Y%m%d')
47
-
48
- selector = {
49
- :client_emails => [client_email],
50
- :api_usage_type => 'UNIT_COUNT_FOR_CLIENTS',
51
- :include_sub_accounts => true,
52
- :date_range => {:min => today, :max => today}
39
+ # Prepare for updating ad.
40
+ operation = {
41
+ :operator => 'SET',
42
+ :operand => {
43
+ :ad_group_id => ad_group_id,
44
+ :status => 'PAUSED',
45
+ :ad => {
46
+ :id => ad_id
47
+ }
48
+ }
53
49
  }
54
50
 
55
- # Get the information for client email address.
56
- info = adwords.use_mcc() {info_srv.get(selector)}
57
-
58
- if info and info[:api_usage_records]
59
- api_usage_records = info[:api_usage_records]
60
- api_usage_records.each do |record|
61
- puts "Found record with client email '%s' and ID %s." %
62
- [record[:client_email],
63
- AdwordsApi::Utils.format_id(record[:client_customer_id])]
64
- end
65
- end
51
+ # Update ad.
52
+ response = ad_group_ad_srv.mutate([operation])
53
+ ad = response[:value].first
54
+ puts "Ad ID %d was successfully updated, status set to '%s'." %
55
+ [ad[:ad][:id], ad[:status]]
66
56
  end
67
57
 
68
58
  if __FILE__ == $0
59
+ API_VERSION = :v201109
60
+
69
61
  begin
70
- get_client_customer_id()
62
+ ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
63
+ ad_id = 'INSERT_AD_ID_HERE'.to_i
64
+ pause_ad(ad_group_id, ad_id)
71
65
 
72
66
  # HTTP errors.
73
67
  rescue AdsCommon::Errors::HttpError => e