google-adwords-api 0.8.1 → 0.8.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 (149) hide show
  1. data/ChangeLog +3 -0
  2. data/examples/v201206/campaign_management/add_keywords_in_bulk.rb +1 -1
  3. data/examples/v201209/campaign_management/add_keywords_in_bulk.rb +1 -1
  4. data/examples/v201302/account_management/create_account.rb +87 -0
  5. data/examples/v201302/account_management/get_account_alerts.rb +114 -0
  6. data/examples/v201302/account_management/get_account_changes.rb +137 -0
  7. data/examples/v201302/account_management/get_account_hierarchy.rb +95 -0
  8. data/examples/v201302/advanced_operations/add_click_to_download_ad.rb +129 -0
  9. data/examples/v201302/advanced_operations/add_site_links.rb +213 -0
  10. data/examples/v201302/basic_operations/add_ad_groups.rb +135 -0
  11. data/examples/v201302/basic_operations/add_campaigns.rb +154 -0
  12. data/examples/v201302/basic_operations/add_keywords.rb +108 -0
  13. data/examples/v201302/basic_operations/add_text_ads.rb +105 -0
  14. data/examples/v201302/basic_operations/delete_ad.rb +85 -0
  15. data/examples/v201302/basic_operations/delete_ad_group.rb +102 -0
  16. data/examples/v201302/basic_operations/delete_campaign.rb +103 -0
  17. data/examples/v201302/basic_operations/delete_keyword.rb +90 -0
  18. data/examples/v201302/basic_operations/get_ad_groups.rb +98 -0
  19. data/examples/v201302/basic_operations/get_campaigns.rb +93 -0
  20. data/examples/v201302/basic_operations/get_campaigns_with_awql.rb +85 -0
  21. data/examples/v201302/basic_operations/get_keywords.rb +104 -0
  22. data/examples/v201302/basic_operations/get_text_ads.rb +106 -0
  23. data/examples/v201302/basic_operations/pause_ad.rb +84 -0
  24. data/examples/v201302/basic_operations/update_ad_group.rb +81 -0
  25. data/examples/v201302/basic_operations/update_campaign.rb +82 -0
  26. data/examples/v201302/basic_operations/update_keyword.rb +102 -0
  27. data/examples/v201302/campaign_management/add_experiment.rb +158 -0
  28. data/examples/v201302/campaign_management/add_keywords_in_bulk.rb +150 -0
  29. data/examples/v201302/campaign_management/add_location_extension.rb +117 -0
  30. data/examples/v201302/campaign_management/add_location_extension_override.rb +83 -0
  31. data/examples/v201302/campaign_management/get_all_disapproved_ads.rb +93 -0
  32. data/examples/v201302/campaign_management/get_all_disapproved_ads_with_awql.rb +84 -0
  33. data/examples/v201302/campaign_management/promote_experiment.rb +77 -0
  34. data/examples/v201302/campaign_management/set_ad_parameters.rb +114 -0
  35. data/examples/v201302/campaign_management/set_campaign_enhanced.rb +83 -0
  36. data/examples/v201302/campaign_management/set_criterion_bid_modifier.rb +102 -0
  37. data/examples/v201302/campaign_management/validate_text_ad.rb +106 -0
  38. data/examples/v201302/error_handling/handle_captcha_challenge.rb +93 -0
  39. data/examples/v201302/error_handling/handle_partial_failures.rb +126 -0
  40. data/examples/v201302/error_handling/handle_policy_violation_error.rb +137 -0
  41. data/examples/v201302/error_handling/handle_two_factor_authorization_error.rb +88 -0
  42. data/examples/v201302/misc/get_all_images_and_videos.rb +100 -0
  43. data/examples/v201302/misc/upload_image.rb +89 -0
  44. data/examples/v201302/misc/use_oauth2.rb +97 -0
  45. data/examples/v201302/misc/use_oauth2_jwt.rb +93 -0
  46. data/examples/v201302/optimization/estimate_keyword_traffic.rb +129 -0
  47. data/examples/v201302/optimization/get_keyword_bid_simulations.rb +92 -0
  48. data/examples/v201302/optimization/get_keyword_ideas.rb +122 -0
  49. data/examples/v201302/optimization/get_placement_ideas.rb +104 -0
  50. data/examples/v201302/remarketing/add_audience.rb +115 -0
  51. data/examples/v201302/remarketing/add_conversion_tracker.rb +96 -0
  52. data/examples/v201302/reporting/download_criteria_report.rb +79 -0
  53. data/examples/v201302/reporting/download_criteria_report_with_awql.rb +78 -0
  54. data/examples/v201302/reporting/get_campaign_stats.rb +105 -0
  55. data/examples/v201302/reporting/get_report_fields.rb +71 -0
  56. data/examples/v201302/reporting/parallel_report_download.rb +163 -0
  57. data/examples/v201302/targeting/add_campaign_targeting_criteria.rb +115 -0
  58. data/examples/v201302/targeting/add_demographic_targeting_criteria.rb +108 -0
  59. data/examples/v201302/targeting/get_campaign_targeting_criteria.rb +102 -0
  60. data/examples/v201302/targeting/get_targetable_languages_and_carriers.rb +86 -0
  61. data/examples/v201302/targeting/lookup_location.rb +104 -0
  62. data/lib/adwords_api/api_config.rb +74 -4
  63. data/lib/adwords_api/v201302/ad_extension_override_service.rb +38 -0
  64. data/lib/adwords_api/v201302/ad_extension_override_service_registry.rb +46 -0
  65. data/lib/adwords_api/v201302/ad_group_ad_service.rb +42 -0
  66. data/lib/adwords_api/v201302/ad_group_ad_service_registry.rb +46 -0
  67. data/lib/adwords_api/v201302/ad_group_criterion_service.rb +42 -0
  68. data/lib/adwords_api/v201302/ad_group_criterion_service_registry.rb +46 -0
  69. data/lib/adwords_api/v201302/ad_group_feed_service.rb +38 -0
  70. data/lib/adwords_api/v201302/ad_group_feed_service_registry.rb +47 -0
  71. data/lib/adwords_api/v201302/ad_group_service.rb +42 -0
  72. data/lib/adwords_api/v201302/ad_group_service_registry.rb +46 -0
  73. data/lib/adwords_api/v201302/ad_param_service.rb +38 -0
  74. data/lib/adwords_api/v201302/ad_param_service_registry.rb +46 -0
  75. data/lib/adwords_api/v201302/alert_service.rb +34 -0
  76. data/lib/adwords_api/v201302/alert_service_registry.rb +46 -0
  77. data/lib/adwords_api/v201302/budget_order_service.rb +42 -0
  78. data/lib/adwords_api/v201302/budget_order_service_registry.rb +46 -0
  79. data/lib/adwords_api/v201302/budget_service.rb +38 -0
  80. data/lib/adwords_api/v201302/budget_service_registry.rb +46 -0
  81. data/lib/adwords_api/v201302/campaign_ad_extension_service.rb +38 -0
  82. data/lib/adwords_api/v201302/campaign_ad_extension_service_registry.rb +46 -0
  83. data/lib/adwords_api/v201302/campaign_criterion_service.rb +42 -0
  84. data/lib/adwords_api/v201302/campaign_criterion_service_registry.rb +46 -0
  85. data/lib/adwords_api/v201302/campaign_feed_service.rb +38 -0
  86. data/lib/adwords_api/v201302/campaign_feed_service_registry.rb +46 -0
  87. data/lib/adwords_api/v201302/campaign_service.rb +42 -0
  88. data/lib/adwords_api/v201302/campaign_service_registry.rb +46 -0
  89. data/lib/adwords_api/v201302/campaign_shared_set_service.rb +38 -0
  90. data/lib/adwords_api/v201302/campaign_shared_set_service_registry.rb +47 -0
  91. data/lib/adwords_api/v201302/constant_data_service.rb +62 -0
  92. data/lib/adwords_api/v201302/constant_data_service_registry.rb +46 -0
  93. data/lib/adwords_api/v201302/conversion_tracker_service.rb +38 -0
  94. data/lib/adwords_api/v201302/conversion_tracker_service_registry.rb +46 -0
  95. data/lib/adwords_api/v201302/customer_service.rb +34 -0
  96. data/lib/adwords_api/v201302/customer_service_registry.rb +46 -0
  97. data/lib/adwords_api/v201302/customer_sync_service.rb +34 -0
  98. data/lib/adwords_api/v201302/customer_sync_service_registry.rb +47 -0
  99. data/lib/adwords_api/v201302/data_service.rb +38 -0
  100. data/lib/adwords_api/v201302/data_service_registry.rb +46 -0
  101. data/lib/adwords_api/v201302/experiment_service.rb +38 -0
  102. data/lib/adwords_api/v201302/experiment_service_registry.rb +46 -0
  103. data/lib/adwords_api/v201302/feed_item_service.rb +38 -0
  104. data/lib/adwords_api/v201302/feed_item_service_registry.rb +47 -0
  105. data/lib/adwords_api/v201302/feed_mapping_service.rb +38 -0
  106. data/lib/adwords_api/v201302/feed_mapping_service_registry.rb +46 -0
  107. data/lib/adwords_api/v201302/feed_service.rb +38 -0
  108. data/lib/adwords_api/v201302/feed_service_registry.rb +47 -0
  109. data/lib/adwords_api/v201302/geo_location_service.rb +34 -0
  110. data/lib/adwords_api/v201302/geo_location_service_registry.rb +46 -0
  111. data/lib/adwords_api/v201302/location_criterion_service.rb +34 -0
  112. data/lib/adwords_api/v201302/location_criterion_service_registry.rb +46 -0
  113. data/lib/adwords_api/v201302/managed_customer_service.rb +50 -0
  114. data/lib/adwords_api/v201302/managed_customer_service_registry.rb +46 -0
  115. data/lib/adwords_api/v201302/media_service.rb +38 -0
  116. data/lib/adwords_api/v201302/media_service_registry.rb +46 -0
  117. data/lib/adwords_api/v201302/mutate_job_service.rb +42 -0
  118. data/lib/adwords_api/v201302/mutate_job_service_registry.rb +46 -0
  119. data/lib/adwords_api/v201302/report_definition_service.rb +34 -0
  120. data/lib/adwords_api/v201302/report_definition_service_registry.rb +46 -0
  121. data/lib/adwords_api/v201302/shared_criterion_service.rb +38 -0
  122. data/lib/adwords_api/v201302/shared_criterion_service_registry.rb +47 -0
  123. data/lib/adwords_api/v201302/targeting_idea_service.rb +38 -0
  124. data/lib/adwords_api/v201302/targeting_idea_service_registry.rb +46 -0
  125. data/lib/adwords_api/v201302/traffic_estimator_service.rb +34 -0
  126. data/lib/adwords_api/v201302/traffic_estimator_service_registry.rb +46 -0
  127. data/lib/adwords_api/v201302/user_list_service.rb +38 -0
  128. data/lib/adwords_api/v201302/user_list_service_registry.rb +46 -0
  129. data/lib/adwords_api/version.rb +1 -1
  130. data/test/adwords_api/test_adwords_api.rb +1 -1
  131. data/test/adwords_api/test_api_config.rb +8 -8
  132. data/test/adwords_api/test_report_utils.rb +1 -1
  133. data/test/bugs/test_issue_00000031.rb +2 -2
  134. data/test/bugs/test_issue_00000063.rb +6 -6
  135. data/test/examples/v201302/test_account_management.rb +50 -0
  136. data/test/examples/v201302/test_advanced_operations.rb +54 -0
  137. data/test/examples/v201302/test_basic_operations.rb +177 -0
  138. data/test/examples/v201302/test_campaign_management.rb +140 -0
  139. data/test/examples/v201302/test_error_handling.rb +63 -0
  140. data/test/examples/v201302/test_misc.rb +39 -0
  141. data/test/examples/v201302/test_optimization.rb +63 -0
  142. data/test/examples/v201302/test_remarketing.rb +39 -0
  143. data/test/examples/v201302/test_reporting.rb +84 -0
  144. data/test/examples/v201302/test_targeting.rb +68 -0
  145. data/test/examples/v201302/utils.rb +267 -0
  146. data/test/suite_exampletests_v201302.rb +37 -0
  147. data/test/templates/v201209/basic_operations_get_campaigns.def +1 -1
  148. data/test/templates/v201302/basic_operations_get_campaigns.def +114 -0
  149. metadata +139 -2
@@ -0,0 +1,114 @@
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 text ad with ad parameters. To add an
22
+ # ad group, run add_ad_group.rb. To add a keyword, run add_keywords.rb.
23
+ #
24
+ # Tags: AdGroupAdService.mutate, AdParamService.mutate
25
+
26
+ require 'adwords_api'
27
+
28
+ def set_ad_parameters(ad_group_id, criterion_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
+ ad_param_srv = adwords.service(:AdParamService, API_VERSION)
39
+
40
+ # Prepare for adding ad.
41
+ ad_operation = {
42
+ :operator => 'ADD',
43
+ :operand => {
44
+ :ad_group_id => ad_group_id,
45
+ :ad => {
46
+ # The 'xsi_type' field allows you to specify the xsi:type of the object
47
+ # being created. It's only necessary when you must provide an explicit
48
+ # type that the client library can't infer.
49
+ :xsi_type => 'TextAd',
50
+ :headline => 'Luxury Mars Cruises',
51
+ :description1 => 'Low-gravity fun for {param1:cheap}.',
52
+ :description2 => 'Only {param2:a few} seats left!',
53
+ :url => 'http://www.example.com',
54
+ :display_url => 'www.example.com'
55
+ }
56
+ }
57
+ }
58
+
59
+ # Add ad.
60
+ response = ad_group_ad_srv.mutate([ad_operation])
61
+ ad = response[:value].first[:ad]
62
+ puts "Text ad ID %d was successfully added." % ad[:id]
63
+
64
+ # Prepare for setting ad parameters.
65
+ price_operation = {
66
+ :operator => 'SET',
67
+ :operand => {
68
+ :ad_group_id => ad_group_id,
69
+ :criterion_id => criterion_id,
70
+ :param_index => 1,
71
+ :insertion_text => '$100'
72
+ }
73
+ }
74
+
75
+ seat_operation = {
76
+ :operator => 'SET',
77
+ :operand => {
78
+ :ad_group_id => ad_group_id,
79
+ :criterion_id => criterion_id,
80
+ :param_index => 2,
81
+ :insertion_text => '50'
82
+ }
83
+ }
84
+
85
+ # Set ad parameters.
86
+ response = ad_param_srv.mutate([price_operation, seat_operation])
87
+ puts 'Parameters were successfully updated.'
88
+ end
89
+
90
+ if __FILE__ == $0
91
+ API_VERSION = :v201302
92
+
93
+ begin
94
+ # IDs of ad group and criterion to set ad parameter for.
95
+ ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
96
+ criterion_id = 'INSERT_CRITERION_ID_HERE'.to_i
97
+ set_ad_parameters(ad_group_id, criterion_id)
98
+
99
+ # HTTP errors.
100
+ rescue AdsCommon::Errors::HttpError => e
101
+ puts "HTTP Error: %s" % e
102
+
103
+ # API errors.
104
+ rescue AdwordsApi::Errors::ApiException => e
105
+ puts "Message: %s" % e.message
106
+ puts 'Errors:'
107
+ e.errors.each_with_index do |error, index|
108
+ puts "\tError [%d]:" % (index + 1)
109
+ error.each do |field, value|
110
+ puts "\t\t%s: %s" % [field, value]
111
+ end
112
+ end
113
+ end
114
+ end
@@ -0,0 +1,83 @@
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 sets the enhanced bit in a given campaign. To get campaigns, run
22
+ # get_campaigns.rb.
23
+ #
24
+ # Tags: CampaignService.mutate
25
+
26
+ require 'adwords_api'
27
+
28
+ def set_campaign_enhanced(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
+ campaign_srv = adwords.service(:CampaignService, API_VERSION)
38
+
39
+ # Prepare for updating campaign. Note: After setting the enhanced value to
40
+ # true, setting it back to false will generate an ApiError.
41
+ operation = {
42
+ :operator => 'SET',
43
+ :operand => {
44
+ :id => campaign_id,
45
+ :enhanced => true
46
+ }
47
+ }
48
+
49
+ # Update campaign.
50
+ response = campaign_srv.mutate([operation])
51
+ if response and response[:value]
52
+ campaign = response[:value].first
53
+ puts "Campaign ID %d was successfully updated, enhanced bit set to: '%s'." %
54
+ [campaign[:id], campaign[:enhanced]]
55
+ else
56
+ puts 'No campaigns were updated.'
57
+ end
58
+ end
59
+
60
+ if __FILE__ == $0
61
+ API_VERSION = :v201302
62
+
63
+ begin
64
+ # ID of a campaign to be updated with the enhanced value.
65
+ campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
66
+ set_campaign_enhanced(campaign_id)
67
+
68
+ # HTTP errors.
69
+ rescue AdsCommon::Errors::HttpError => e
70
+ puts "HTTP Error: %s" % e
71
+
72
+ # API errors.
73
+ rescue AdwordsApi::Errors::ApiException => e
74
+ puts "Message: %s" % e.message
75
+ puts 'Errors:'
76
+ e.errors.each_with_index do |error, index|
77
+ puts "\tError [%d]:" % (index + 1)
78
+ error.each do |field, value|
79
+ puts "\t\t%s: %s" % [field, value]
80
+ end
81
+ end
82
+ end
83
+ end
@@ -0,0 +1,102 @@
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 sets a bid modifier for the mobile platform on given campaign.
22
+ #
23
+ # NOTE: the campaign must be an enhanced type of campaign. To get campaigns, run
24
+ # get_campaigns.rb. To enhance a campaign, run set_campaign_enhanced.rb.
25
+ #
26
+ # Tags: CampaignCriterionService.mutate
27
+
28
+ require 'adwords_api'
29
+
30
+ def set_criterion_bid_modifier(campaign_id, bid_modifier)
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
+ campaign_criterion_srv =
40
+ adwords.service(:CampaignCriterionService, API_VERSION)
41
+
42
+ # Create campaign criterion with modified bid.
43
+ campaign_criterion = {
44
+ :campaign_id => campaign_id,
45
+ # Mobile platform. The ID can be found in the documentation.
46
+ # https://developers.google.com/adwords/api/docs/appendix/platforms
47
+ :criterion => {
48
+ :xsi_type => 'Platform',
49
+ :id => 30001
50
+ },
51
+ :bid_modifier => bid_modifier
52
+ }
53
+
54
+ # Create operation.
55
+ operation = {
56
+ :operator => 'SET',
57
+ :operand => campaign_criterion
58
+ }
59
+
60
+ response = campaign_criterion_srv.mutate([operation])
61
+
62
+ if response and response[:value]
63
+ criteria = response[:value]
64
+ criteria.each do |campaign_criterion|
65
+ criterion = campaign_criterion[:criterion]
66
+ puts ("Campaign criterion with campaign ID %d, criterion ID %d was " +
67
+ "updated with bid modifier %f.") % [campaign_criterion[:campaign_id],
68
+ criterion[:id], campaign_criterion[:bid_modifier]]
69
+ end
70
+ else
71
+ puts 'No criteria were returned.'
72
+ end
73
+ end
74
+
75
+ if __FILE__ == $0
76
+ API_VERSION = :v201302
77
+
78
+ begin
79
+ # ID of a campaign to be updated with the enhanced value.
80
+ campaign_id = 'INSERT_CAMPAIGN_ID_HERE'.to_i
81
+
82
+ # Bid modifier to set.
83
+ bid_modifier = 1.5
84
+
85
+ set_criterion_bid_modifier(campaign_id, bid_modifier)
86
+
87
+ # HTTP errors.
88
+ rescue AdsCommon::Errors::HttpError => e
89
+ puts "HTTP Error: %s" % e
90
+
91
+ # API errors.
92
+ rescue AdwordsApi::Errors::ApiException => e
93
+ puts "Message: %s" % e.message
94
+ puts 'Errors:'
95
+ e.errors.each_with_index do |error, index|
96
+ puts "\tError [%d]:" % (index + 1)
97
+ error.each do |field, value|
98
+ puts "\t\t%s: %s" % [field, value]
99
+ end
100
+ end
101
+ end
102
+ end
@@ -0,0 +1,106 @@
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 shows how to use the 'validate only' header. No objects will be
22
+ # created, but exceptions will still be thrown.
23
+ #
24
+ # Tags: CampaignService.mutate
25
+
26
+ require 'adwords_api'
27
+
28
+ def validate_text_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
+ # Enable 'validate only' option.
40
+ adwords.validate_only = true
41
+
42
+ # Prepare for adding text ad.
43
+ operation = {
44
+ :operator => 'ADD',
45
+ :operand => {
46
+ :ad_group_id => ad_group_id,
47
+ :ad => {
48
+ :xsi_type => 'TextAd',
49
+ :headline => 'Luxury Cruise to Mars',
50
+ :description1 => 'Visit the Red Planet in style.',
51
+ :description2 => 'Low-gravity fun for everyone!',
52
+ :url => 'http://www.example.com',
53
+ :display_url => 'www.example.com'
54
+ }
55
+ }
56
+ }
57
+
58
+ # Validate text ad add operation.
59
+ response = ad_group_ad_srv.mutate([operation])
60
+ if response and response[:value]
61
+ ad = response[:value].first
62
+ puts "Unexpected ad creation! Name '%s', ID %d and status '%s'." %
63
+ [campaign[:name], campaign[:id], campaign[:status]]
64
+ else
65
+ puts 'Text ad validated, no error thrown and no ad created.'
66
+ end
67
+
68
+ # Now let's check an invalid ad using extra punctuation to trigger an error.
69
+ operation[:operand][:ad][:headline] = 'Luxury Cruise to Mars!!!!!'
70
+
71
+ # Validate text ad add operation.
72
+ begin
73
+ response = ad_group_ad_srv.mutate([operation])
74
+ if response and response[:value]
75
+ ad = response[:value].first
76
+ raise StandardError, ("Unexpected ad creation! Name '%s', ID %d and " +
77
+ "status '%s'.") % [campaign[:name], campaign[:id], campaign[:status]]
78
+ end
79
+ rescue AdwordsApi::Errors::ApiException => e
80
+ puts "Validation correctly failed with an exception: %s" % e.class
81
+ end
82
+ end
83
+
84
+ if __FILE__ == $0
85
+ API_VERSION = :v201302
86
+
87
+ begin
88
+ ad_group_id = 'INSERT_AD_GROUP_ID_HERE'.to_i
89
+ validate_text_ad(ad_group_id)
90
+
91
+ # HTTP errors.
92
+ rescue AdsCommon::Errors::HttpError => e
93
+ puts "HTTP Error: %s" % e
94
+
95
+ # API errors.
96
+ rescue AdwordsApi::Errors::ApiException => e
97
+ puts "Message: %s" % e.message
98
+ puts 'Errors:'
99
+ e.errors.each_with_index do |error, index|
100
+ puts "\tError [%d]:" % (index + 1)
101
+ error.each do |field, value|
102
+ puts "\t\t%s: %s" % [field, value]
103
+ end
104
+ end
105
+ end
106
+ end
@@ -0,0 +1,93 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
5
+ #
6
+ # Copyright:: Copyright 2012, 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 handle 'CAPTCHA required' authorization
22
+ # errors. Refer to the best practices guide on how to avoid this error:
23
+ #
24
+ # http://code.google.com/apis/adwords/docs/guides/bestpractices.html#auth_tokens
25
+
26
+ require 'adwords_api'
27
+
28
+ def handle_captcha_challenge()
29
+ # Initialize token variable.
30
+ logintoken = nil
31
+
32
+ # This code will repeatedly request authToken from the server until it gets
33
+ # a CAPTCHA challenge request. It is here for illustration purposes only
34
+ # and should never be used in a real application.
35
+ begin
36
+ MAX_RETRIES.times do |retry_number|
37
+ puts "Running request %d of %d..." % [retry_number + 1, MAX_RETRIES]
38
+ # Forcing library to request a new authorization token.
39
+ adwords = AdwordsApi::Api.new
40
+ auth_token = adwords.authorize()
41
+ end
42
+ # Still no challenge, make sure ClientLogin authorization is used.
43
+ raise StandardError, "Failed to get challenge after %d requests." %
44
+ MAX_RETRIES
45
+ rescue AdsCommon::Errors::CaptchaRequiredError => e
46
+ logintoken = e.captcha_token
47
+ end
48
+
49
+ puts "CaptchaRequiredError occurred. To recover download the image and type" +
50
+ " the CAPTCHA below: %s\n" % e.captcha_url
51
+ puts 'Enter code or ENTER to retry: '
52
+ logincaptcha = gets.chomp
53
+
54
+ # Initialize variable for extra parameters.
55
+ credentials = {}
56
+ if logincaptcha and !logincaptcha.empty?
57
+ credentials[:logincaptcha] = logincaptcha
58
+ credentials[:logintoken] = logintoken
59
+ end
60
+
61
+ begin
62
+ adwords = AdwordsApi::Api.new
63
+ auth_token = adwords.authorize(credentials)
64
+ puts "Successfully retrieved authToken: " + auth_token
65
+ rescue AdsCommon::Errors::CaptchaRequiredError => e
66
+ puts 'Invalid CAPTCHA text entered.'
67
+ raise e
68
+ end
69
+ end
70
+
71
+ if __FILE__ == $0
72
+ API_VERSION = :v201302
73
+ MAX_RETRIES = 500
74
+
75
+ begin
76
+ handle_captcha_challenge()
77
+
78
+ # HTTP errors.
79
+ rescue AdsCommon::Errors::HttpError => e
80
+ puts "HTTP Error: %s" % e
81
+
82
+ # API errors.
83
+ rescue AdwordsApi::Errors::ApiException => e
84
+ puts "Message: %s" % e.message
85
+ puts 'Errors:'
86
+ e.errors.each_with_index do |error, index|
87
+ puts "\tError [%d]:" % (index + 1)
88
+ error.each do |field, value|
89
+ puts "\t\t%s: %s" % [field, value]
90
+ end
91
+ end
92
+ end
93
+ end