google-adwords-api 0.18.0 → 0.18.1
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.
- checksums.yaml +4 -4
- data/ChangeLog +8 -0
- data/examples/v201509/basic_operations/add_ad_groups.rb +4 -2
- data/examples/v201509/remarketing/add_crm_based_user_list.rb +2 -4
- data/examples/v201509/{advanced_operations → remarketing}/upload_offline_conversions.rb +6 -21
- data/examples/v201601/account_management/create_account.rb +88 -0
- data/examples/v201601/account_management/get_account_changes.rb +139 -0
- data/examples/v201601/account_management/get_account_hierarchy.rb +132 -0
- data/examples/v201601/advanced_operations/add_ad_customizers.rb +184 -0
- data/examples/v201601/advanced_operations/add_ad_group_bid_modifier.rb +101 -0
- data/examples/v201601/advanced_operations/add_click_to_download_ad.rb +133 -0
- data/examples/v201601/advanced_operations/add_html5_ad.rb +137 -0
- data/examples/v201601/advanced_operations/add_keywords_using_incremental_batch_job.rb +179 -0
- data/examples/v201601/advanced_operations/add_text_ad_with_upgraded_urls.rb +134 -0
- data/examples/v201601/advanced_operations/create_and_attach_shared_keyword_set.rb +141 -0
- data/examples/v201601/advanced_operations/find_and_remove_criteria_from_shared_set.rb +174 -0
- data/examples/v201601/advanced_operations/get_ad_group_bid_modifiers.rb +102 -0
- data/examples/v201601/advanced_operations/use_shared_bidding_strategy.rb +147 -0
- data/examples/v201601/basic_operations/add_ad_groups.rb +142 -0
- data/examples/v201601/basic_operations/add_campaigns.rb +139 -0
- data/examples/v201601/basic_operations/add_keywords.rb +114 -0
- data/examples/v201601/basic_operations/add_text_ads.rb +109 -0
- data/examples/v201601/basic_operations/get_ad_groups.rb +102 -0
- data/examples/v201601/basic_operations/get_campaigns.rb +97 -0
- data/examples/v201601/basic_operations/get_campaigns_with_awql.rb +89 -0
- data/examples/v201601/basic_operations/get_keywords.rb +109 -0
- data/examples/v201601/basic_operations/get_text_ads.rb +110 -0
- data/examples/v201601/basic_operations/pause_ad.rb +88 -0
- data/examples/v201601/basic_operations/remove_ad.rb +89 -0
- data/examples/v201601/basic_operations/remove_ad_group.rb +85 -0
- data/examples/v201601/basic_operations/remove_campaign.rb +87 -0
- data/examples/v201601/basic_operations/remove_keyword.rb +94 -0
- data/examples/v201601/basic_operations/update_ad_group.rb +85 -0
- data/examples/v201601/basic_operations/update_campaign.rb +86 -0
- data/examples/v201601/basic_operations/update_keyword.rb +106 -0
- data/examples/v201601/campaign_management/add_campaign_labels.rb +82 -0
- data/examples/v201601/campaign_management/add_complete_campaigns_using_batch_job.rb +356 -0
- data/examples/v201601/campaign_management/add_experiment.rb +162 -0
- data/examples/v201601/campaign_management/add_keywords_in_bulk.rb +153 -0
- data/examples/v201601/campaign_management/get_all_disapproved_ads.rb +97 -0
- data/examples/v201601/campaign_management/get_all_disapproved_ads_with_awql.rb +89 -0
- data/examples/v201601/campaign_management/get_campaigns_by_label.rb +108 -0
- data/examples/v201601/campaign_management/promote_experiment.rb +81 -0
- data/examples/v201601/campaign_management/set_ad_parameters.rb +118 -0
- data/examples/v201601/campaign_management/set_criterion_bid_modifier.rb +104 -0
- data/examples/v201601/campaign_management/validate_text_ad.rb +110 -0
- data/examples/v201601/error_handling/handle_partial_failures.rb +130 -0
- data/examples/v201601/error_handling/handle_policy_violation_error.rb +141 -0
- data/examples/v201601/extensions/add_google_my_business_location_extensions.rb +193 -0
- data/examples/v201601/extensions/add_site_links.rb +164 -0
- data/examples/v201601/extensions/add_site_links_using_feeds.rb +281 -0
- data/examples/v201601/migration/migrate_to_extension_settings.rb +386 -0
- data/examples/v201601/migration/upgrade_ad_url.rb +93 -0
- data/examples/v201601/misc/get_all_images_and_videos.rb +104 -0
- data/examples/v201601/misc/setup_oauth2.rb +84 -0
- data/examples/v201601/misc/upload_image.rb +93 -0
- data/examples/v201601/misc/upload_media_bundle.rb +90 -0
- data/examples/v201601/misc/use_oauth2_jwt.rb +93 -0
- data/examples/v201601/misc/use_runtime_config.rb +92 -0
- data/examples/v201601/optimization/estimate_keyword_traffic.rb +146 -0
- data/examples/v201601/optimization/get_keyword_bid_simulations.rb +95 -0
- data/examples/v201601/optimization/get_keyword_ideas.rb +126 -0
- data/examples/v201601/remarketing/add_audience.rb +118 -0
- data/examples/v201601/remarketing/add_conversion_tracker.rb +97 -0
- data/examples/v201601/remarketing/add_crm_based_user_list.rb +119 -0
- data/examples/v201601/remarketing/add_rule_based_user_lists.rb +167 -0
- data/examples/v201601/remarketing/upload_offline_conversions.rb +98 -0
- data/examples/v201601/reporting/download_criteria_report.rb +92 -0
- data/examples/v201601/reporting/download_criteria_report_with_awql.rb +93 -0
- data/examples/v201601/reporting/get_report_fields.rb +75 -0
- data/examples/v201601/reporting/parallel_report_download.rb +166 -0
- data/examples/v201601/reporting/stream_criteria_report_results.rb +97 -0
- data/examples/v201601/shopping_campaigns/add_product_partition_tree.rb +267 -0
- data/examples/v201601/shopping_campaigns/add_product_scope.rb +129 -0
- data/examples/v201601/shopping_campaigns/add_shopping_campaign.rb +129 -0
- data/examples/v201601/shopping_campaigns/get_product_category_taxonomy.rb +115 -0
- data/examples/v201601/targeting/add_campaign_targeting_criteria.rb +180 -0
- data/examples/v201601/targeting/add_demographic_targeting_criteria.rb +112 -0
- data/examples/v201601/targeting/get_campaign_targeting_criteria.rb +106 -0
- data/examples/v201601/targeting/get_targetable_languages_and_carriers.rb +89 -0
- data/examples/v201601/targeting/lookup_location.rb +108 -0
- data/lib/adwords_api/api_config.rb +90 -4
- data/lib/adwords_api/batch_job_utils.rb +29 -17
- data/lib/adwords_api/incremental_upload_helper.rb +5 -1
- data/lib/adwords_api/report_stream.rb +7 -8
- data/lib/adwords_api/report_utils.rb +4 -4
- data/lib/adwords_api/v201601/account_label_service.rb +46 -0
- data/lib/adwords_api/v201601/account_label_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_customizer_feed_service.rb +46 -0
- data/lib/adwords_api/v201601/ad_customizer_feed_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_group_ad_service.rb +70 -0
- data/lib/adwords_api/v201601/ad_group_ad_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_group_bid_modifier_service.rb +54 -0
- data/lib/adwords_api/v201601/ad_group_bid_modifier_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_group_criterion_service.rb +62 -0
- data/lib/adwords_api/v201601/ad_group_criterion_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_group_extension_setting_service.rb +54 -0
- data/lib/adwords_api/v201601/ad_group_extension_setting_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_group_feed_service.rb +54 -0
- data/lib/adwords_api/v201601/ad_group_feed_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_group_service.rb +62 -0
- data/lib/adwords_api/v201601/ad_group_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/ad_param_service.rb +46 -0
- data/lib/adwords_api/v201601/ad_param_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/adwords_user_list_service.rb +54 -0
- data/lib/adwords_api/v201601/adwords_user_list_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/batch_job_service.rb +54 -0
- data/lib/adwords_api/v201601/batch_job_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/bidding_strategy_service.rb +54 -0
- data/lib/adwords_api/v201601/bidding_strategy_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/budget_order_service.rb +54 -0
- data/lib/adwords_api/v201601/budget_order_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/budget_service.rb +54 -0
- data/lib/adwords_api/v201601/budget_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/campaign_criterion_service.rb +54 -0
- data/lib/adwords_api/v201601/campaign_criterion_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/campaign_extension_setting_service.rb +54 -0
- data/lib/adwords_api/v201601/campaign_extension_setting_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/campaign_feed_service.rb +54 -0
- data/lib/adwords_api/v201601/campaign_feed_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/campaign_service.rb +62 -0
- data/lib/adwords_api/v201601/campaign_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/campaign_shared_set_service.rb +54 -0
- data/lib/adwords_api/v201601/campaign_shared_set_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/constant_data_service.rb +110 -0
- data/lib/adwords_api/v201601/constant_data_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/conversion_tracker_service.rb +54 -0
- data/lib/adwords_api/v201601/conversion_tracker_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/customer_extension_setting_service.rb +54 -0
- data/lib/adwords_api/v201601/customer_extension_setting_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/customer_feed_service.rb +54 -0
- data/lib/adwords_api/v201601/customer_feed_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/customer_service.rb +54 -0
- data/lib/adwords_api/v201601/customer_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/customer_sync_service.rb +38 -0
- data/lib/adwords_api/v201601/customer_sync_service_registry.rb +47 -0
- data/lib/adwords_api/v201601/data_service.rb +78 -0
- data/lib/adwords_api/v201601/data_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/experiment_service.rb +46 -0
- data/lib/adwords_api/v201601/experiment_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/feed_item_service.rb +54 -0
- data/lib/adwords_api/v201601/feed_item_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/feed_mapping_service.rb +54 -0
- data/lib/adwords_api/v201601/feed_mapping_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/feed_service.rb +54 -0
- data/lib/adwords_api/v201601/feed_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/label_service.rb +54 -0
- data/lib/adwords_api/v201601/label_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/location_criterion_service.rb +46 -0
- data/lib/adwords_api/v201601/location_criterion_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/managed_customer_service.rb +78 -0
- data/lib/adwords_api/v201601/managed_customer_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/media_service.rb +54 -0
- data/lib/adwords_api/v201601/media_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/mutate_job_service.rb +54 -0
- data/lib/adwords_api/v201601/mutate_job_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/offline_conversion_feed_service.rb +38 -0
- data/lib/adwords_api/v201601/offline_conversion_feed_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/report_definition_service.rb +38 -0
- data/lib/adwords_api/v201601/report_definition_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/shared_criterion_service.rb +54 -0
- data/lib/adwords_api/v201601/shared_criterion_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/shared_set_service.rb +54 -0
- data/lib/adwords_api/v201601/shared_set_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/targeting_idea_service.rb +38 -0
- data/lib/adwords_api/v201601/targeting_idea_service_registry.rb +46 -0
- data/lib/adwords_api/v201601/traffic_estimator_service.rb +38 -0
- data/lib/adwords_api/v201601/traffic_estimator_service_registry.rb +46 -0
- data/lib/adwords_api/version.rb +1 -1
- data/test/adwords_api/test_batch_job_utils.rb +11 -2
- metadata +163 -5
@@ -0,0 +1,118 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# Encoding: utf-8
|
3
|
+
#
|
4
|
+
# Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
|
5
|
+
#
|
6
|
+
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
+
# implied.
|
16
|
+
# See the License for the specific language governing permissions and
|
17
|
+
# limitations under the License.
|
18
|
+
#
|
19
|
+
# This example illustrates how to create a user list (a.k.a. Audience) and shows
|
20
|
+
# its associated conversion tracker code snippet.
|
21
|
+
|
22
|
+
require 'adwords_api'
|
23
|
+
|
24
|
+
def add_audience()
|
25
|
+
# AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
|
26
|
+
# when called without parameters.
|
27
|
+
adwords = AdwordsApi::Api.new
|
28
|
+
|
29
|
+
# To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
|
30
|
+
# the configuration file or provide your own logger:
|
31
|
+
# adwords.logger = Logger.new('adwords_xml.log')
|
32
|
+
|
33
|
+
user_list_srv = adwords.service(:AdwordsUserListService, API_VERSION)
|
34
|
+
conv_tracker_srv = adwords.service(:ConversionTrackerService, API_VERSION)
|
35
|
+
|
36
|
+
# Prepare for adding remarketing user list.
|
37
|
+
name = "Mars cruise customers #%d" % (Time.new.to_f * 1000).to_i
|
38
|
+
operation = {
|
39
|
+
:operator => 'ADD',
|
40
|
+
:operand => {
|
41
|
+
# The 'xsi_type' field allows you to specify the xsi:type of the object
|
42
|
+
# being created. It's only necessary when you must provide an explicit
|
43
|
+
# type that the client library can't infer.
|
44
|
+
:xsi_type => 'BasicUserList',
|
45
|
+
:name => name,
|
46
|
+
:description => 'A list of mars cruise customers in the last year',
|
47
|
+
:membership_life_span => 365,
|
48
|
+
:conversion_types => [{:name => name}],
|
49
|
+
# Optional field.
|
50
|
+
:status => 'OPEN'
|
51
|
+
}
|
52
|
+
}
|
53
|
+
|
54
|
+
# Add user list.
|
55
|
+
response = user_list_srv.mutate([operation])
|
56
|
+
if response and response[:value]
|
57
|
+
user_list = response[:value].first
|
58
|
+
|
59
|
+
# Get conversion snippets.
|
60
|
+
if user_list and user_list[:conversion_types]
|
61
|
+
conversion_ids = user_list[:conversion_types][:id]
|
62
|
+
selector = {
|
63
|
+
# We're actually interested in the 'Snippet' field, which is returned
|
64
|
+
# automatically.
|
65
|
+
:fields => ['Id'],
|
66
|
+
:predicates => [
|
67
|
+
{:field => 'Id', :operator => 'IN', :values => [conversion_ids]}
|
68
|
+
]
|
69
|
+
}
|
70
|
+
conv_tracker_response = conv_tracker_srv.get(selector)
|
71
|
+
if conv_tracker_response and conv_tracker_response[:entries]
|
72
|
+
conversions = conv_tracker_response[:entries]
|
73
|
+
end
|
74
|
+
end
|
75
|
+
puts "User list with name '%s' and ID %d was added." %
|
76
|
+
[user_list[:name], user_list[:id]]
|
77
|
+
# Display user list associated conversion code snippets.
|
78
|
+
if conversions
|
79
|
+
conversions.each do |conversion|
|
80
|
+
puts "Conversion type code snipped associated to the list:\n\t\t%s\n" %
|
81
|
+
conversion[:snippet]
|
82
|
+
end
|
83
|
+
end
|
84
|
+
else
|
85
|
+
puts 'No user lists were added.'
|
86
|
+
end
|
87
|
+
end
|
88
|
+
|
89
|
+
if __FILE__ == $0
|
90
|
+
API_VERSION = :v201601
|
91
|
+
|
92
|
+
begin
|
93
|
+
add_audience()
|
94
|
+
|
95
|
+
# Authorization error.
|
96
|
+
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
97
|
+
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
98
|
+
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
99
|
+
"to retrieve and store OAuth2 tokens."
|
100
|
+
puts "See this wiki page for more details:\n\n " +
|
101
|
+
'https://github.com/googleads/google-api-ads-ruby/wiki/OAuth2'
|
102
|
+
|
103
|
+
# HTTP errors.
|
104
|
+
rescue AdsCommon::Errors::HttpError => e
|
105
|
+
puts "HTTP Error: %s" % e
|
106
|
+
|
107
|
+
# API errors.
|
108
|
+
rescue AdwordsApi::Errors::ApiException => e
|
109
|
+
puts "Message: %s" % e.message
|
110
|
+
puts 'Errors:'
|
111
|
+
e.errors.each_with_index do |error, index|
|
112
|
+
puts "\tError [%d]:" % (index + 1)
|
113
|
+
error.each do |field, value|
|
114
|
+
puts "\t\t%s: %s" % [field, value]
|
115
|
+
end
|
116
|
+
end
|
117
|
+
end
|
118
|
+
end
|
@@ -0,0 +1,97 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# Encoding: utf-8
|
3
|
+
#
|
4
|
+
# Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
|
5
|
+
#
|
6
|
+
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
+
# implied.
|
16
|
+
# See the License for the specific language governing permissions and
|
17
|
+
# limitations under the License.
|
18
|
+
#
|
19
|
+
# This example illustrates how to add an AdWords conversion tracker.
|
20
|
+
|
21
|
+
require 'adwords_api'
|
22
|
+
|
23
|
+
def add_conversion_tracker()
|
24
|
+
# AdwordsApi::Api will read a config file from ENV['HOME']/adwords_api.yml
|
25
|
+
# when called without parameters.
|
26
|
+
adwords = AdwordsApi::Api.new
|
27
|
+
|
28
|
+
# To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
|
29
|
+
# the configuration file or provide your own logger:
|
30
|
+
# adwords.logger = Logger.new('adwords_xml.log')
|
31
|
+
|
32
|
+
conv_tracker_srv = adwords.service(:ConversionTrackerService, API_VERSION)
|
33
|
+
|
34
|
+
# Prepare for adding conversion.
|
35
|
+
operation = {
|
36
|
+
:operator => 'ADD',
|
37
|
+
:operand => {
|
38
|
+
# The 'xsi_type' field allows you to specify the xsi:type of the object
|
39
|
+
# being created. It's only necessary when you must provide an explicit
|
40
|
+
# type that the client library can't infer.
|
41
|
+
:xsi_type => 'AdWordsConversionTracker',
|
42
|
+
:name => "Earth to Mars Cruises Conversion #%d" %
|
43
|
+
(Time.new.to_f * 1000).to_i,
|
44
|
+
:category => 'DEFAULT',
|
45
|
+
:text_format => 'HIDDEN',
|
46
|
+
# Optional fields:
|
47
|
+
:status => 'ENABLED',
|
48
|
+
:viewthrough_lookback_window => 15,
|
49
|
+
:conversion_page_language => 'en',
|
50
|
+
:background_color => '#0000FF',
|
51
|
+
:default_revenue_value => 23.41,
|
52
|
+
:always_use_default_revenue_value => true
|
53
|
+
}
|
54
|
+
}
|
55
|
+
|
56
|
+
# Add conversion.
|
57
|
+
response = conv_tracker_srv.mutate([operation])
|
58
|
+
if response and response[:value]
|
59
|
+
conversion = response[:value].first
|
60
|
+
puts ("Conversion with ID %d, name '%s', status '%s' and category '%s'" +
|
61
|
+
" was added.") % [conversion[:id], conversion[:name],
|
62
|
+
conversion[:status], conversion[:category]]
|
63
|
+
else
|
64
|
+
puts 'No conversions were added.'
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
if __FILE__ == $0
|
69
|
+
API_VERSION = :v201601
|
70
|
+
|
71
|
+
begin
|
72
|
+
add_conversion_tracker()
|
73
|
+
|
74
|
+
# Authorization error.
|
75
|
+
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
76
|
+
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
77
|
+
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
78
|
+
"to retrieve and store OAuth2 tokens."
|
79
|
+
puts "See this wiki page for more details:\n\n " +
|
80
|
+
'https://github.com/googleads/google-api-ads-ruby/wiki/OAuth2'
|
81
|
+
|
82
|
+
# HTTP errors.
|
83
|
+
rescue AdsCommon::Errors::HttpError => e
|
84
|
+
puts "HTTP Error: %s" % e
|
85
|
+
|
86
|
+
# API errors.
|
87
|
+
rescue AdwordsApi::Errors::ApiException => e
|
88
|
+
puts "Message: %s" % e.message
|
89
|
+
puts 'Errors:'
|
90
|
+
e.errors.each_with_index do |error, index|
|
91
|
+
puts "\tError [%d]:" % (index + 1)
|
92
|
+
error.each do |field, value|
|
93
|
+
puts "\t\t%s: %s" % [field, value]
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
@@ -0,0 +1,119 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# Encoding: utf-8
|
3
|
+
#
|
4
|
+
# Copyright:: Copyright 2015, Google Inc. All Rights Reserved.
|
5
|
+
#
|
6
|
+
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
+
# implied.
|
16
|
+
# See the License for the specific language governing permissions and
|
17
|
+
# limitations under the License.
|
18
|
+
#
|
19
|
+
# This example adds a remarketing user list (a.k.a. audience) and uploads
|
20
|
+
# hashed email addresses to populate the list.
|
21
|
+
#
|
22
|
+
# Note: It may take several hours for the list to be populated with members.
|
23
|
+
# Email addresses must be associated with a Google account. For privacy
|
24
|
+
# purposes, the user list size will show as zero until the list has at least
|
25
|
+
# 1000 members. After that, the size will be rounded to the two most
|
26
|
+
# significant digits.
|
27
|
+
|
28
|
+
require 'adwords_api'
|
29
|
+
require 'digest'
|
30
|
+
|
31
|
+
def add_crm_based_user_list(emails)
|
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
|
+
user_list_srv = adwords.service(:AdwordsUserListService, API_VERSION)
|
41
|
+
|
42
|
+
user_list = {
|
43
|
+
:xsi_type => 'CrmBasedUserList',
|
44
|
+
:name => 'Customer relationship management list #%d' % Time.new.usec,
|
45
|
+
:description => 'A list of customers that originated from email addresses',
|
46
|
+
# Maximum life span is 180 days.
|
47
|
+
:membership_life_span => 180,
|
48
|
+
# This field is optional. It links to a service you created that allows
|
49
|
+
# members of this list to remove themselves.
|
50
|
+
:opt_out_link => 'http://endpoint1.example.com/optout'
|
51
|
+
}
|
52
|
+
|
53
|
+
operation = {
|
54
|
+
:operand => user_list,
|
55
|
+
:operator => 'ADD'
|
56
|
+
}
|
57
|
+
|
58
|
+
result = user_list_srv.mutate([operation])
|
59
|
+
user_list_id = result[:value].first[:id]
|
60
|
+
|
61
|
+
sha_digest = Digest::SHA256.new
|
62
|
+
hashed_emails = emails.map do |email|
|
63
|
+
# Remove leading and trailing whitespace and convert all characters to
|
64
|
+
# lowercase before generating the hashed version.
|
65
|
+
email = email.strip.downcase
|
66
|
+
sha_digest.hexdigest(email)
|
67
|
+
end
|
68
|
+
|
69
|
+
mutate_members_operation = {
|
70
|
+
:operand => {
|
71
|
+
:user_list_id => user_list_id,
|
72
|
+
:data_type => 'EMAIL_SHA256',
|
73
|
+
:members => hashed_emails
|
74
|
+
},
|
75
|
+
:operator => 'ADD'
|
76
|
+
}
|
77
|
+
|
78
|
+
mutate_members_result =
|
79
|
+
user_list_srv.mutate_members([mutate_members_operation])
|
80
|
+
|
81
|
+
mutate_members_result[:user_lists].each do |user_list|
|
82
|
+
puts "User list with name '%s' and ID '%d' was added." %
|
83
|
+
[user_list[:name], user_list[:id]]
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
87
|
+
if __FILE__ == $0
|
88
|
+
API_VERSION = :v201601
|
89
|
+
|
90
|
+
emails = ['customer1@example.com', 'customer2@example.com',
|
91
|
+
' Customer3@example.com ']
|
92
|
+
|
93
|
+
begin
|
94
|
+
add_crm_based_user_list(emails)
|
95
|
+
|
96
|
+
# Authorization error.
|
97
|
+
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
98
|
+
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
99
|
+
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
100
|
+
"to retrieve and store OAuth2 tokens."
|
101
|
+
puts "See this wiki page for more details:\n\n " +
|
102
|
+
'https://github.com/googleads/google-api-ads-ruby/wiki/OAuth2'
|
103
|
+
|
104
|
+
# HTTP errors.
|
105
|
+
rescue AdsCommon::Errors::HttpError => e
|
106
|
+
puts "HTTP Error: %s" % e
|
107
|
+
|
108
|
+
# API errors.
|
109
|
+
rescue AdwordsApi::Errors::ApiException => e
|
110
|
+
puts "Message: %s" % e.message
|
111
|
+
puts 'Errors:'
|
112
|
+
e.errors.each_with_index do |error, index|
|
113
|
+
puts "\tError [%d]:" % (index + 1)
|
114
|
+
error.each do |field, value|
|
115
|
+
puts "\t\t%s: %s" % [field, value]
|
116
|
+
end
|
117
|
+
end
|
118
|
+
end
|
119
|
+
end
|
@@ -0,0 +1,167 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# Encoding: utf-8
|
3
|
+
#
|
4
|
+
# Copyright:: Copyright 2014, Google Inc. All Rights Reserved.
|
5
|
+
#
|
6
|
+
# License:: Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
15
|
+
# implied.
|
16
|
+
# See the License for the specific language governing permissions and
|
17
|
+
# limitations under the License.
|
18
|
+
#
|
19
|
+
# This example adds two rule-based remarketing user lists: one with no site
|
20
|
+
# visit data restrictions, and another that will only include users who visit
|
21
|
+
# your site in the next six months.
|
22
|
+
|
23
|
+
require 'adwords_api'
|
24
|
+
|
25
|
+
def add_rule_based_user_lists()
|
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
|
+
user_list_srv = adwords.service(:AdwordsUserListService, API_VERSION)
|
35
|
+
|
36
|
+
# First rule item group - users who visited the checkout page and had more
|
37
|
+
# than one item in their shopping cart.
|
38
|
+
cart_rule_item = {
|
39
|
+
:xsi_type => 'StringRuleItem',
|
40
|
+
:key => {
|
41
|
+
:name => 'ecomm_pagetype'
|
42
|
+
},
|
43
|
+
:op => 'EQUALS',
|
44
|
+
:value => 'checkout'
|
45
|
+
}
|
46
|
+
|
47
|
+
cart_size_rule_item = {
|
48
|
+
:xsi_type => 'NumberRuleItem',
|
49
|
+
:key => {
|
50
|
+
:name => 'cartsize'
|
51
|
+
},
|
52
|
+
:op => 'GREATER_THAN',
|
53
|
+
:value => 1.0
|
54
|
+
}
|
55
|
+
|
56
|
+
# Combine the two rule items into a RuleItemGroup so AdWords will AND
|
57
|
+
# their rules together.
|
58
|
+
checkout_multiple_item_group = {
|
59
|
+
:items => [cart_rule_item, cart_size_rule_item]
|
60
|
+
}
|
61
|
+
|
62
|
+
# Second rule item group - users who checked out after October 31st
|
63
|
+
# and before January 1st.
|
64
|
+
start_date_rule_item = {
|
65
|
+
:xsi_type => 'DateRuleItem',
|
66
|
+
:key => {
|
67
|
+
:name => 'checkoutdate'
|
68
|
+
},
|
69
|
+
:op => 'AFTER',
|
70
|
+
:value => '20141031'
|
71
|
+
}
|
72
|
+
|
73
|
+
end_date_rule_item = {
|
74
|
+
:xsi_type => 'DateRuleItem',
|
75
|
+
:key => {
|
76
|
+
:name => 'checkoutdate'
|
77
|
+
},
|
78
|
+
:op => 'BEFORE',
|
79
|
+
:value => '20150101'
|
80
|
+
}
|
81
|
+
|
82
|
+
# Combine the date rule items into a RuleItemGroup.
|
83
|
+
checked_out_nov_dec_item_group = {
|
84
|
+
:items => [start_date_rule_item, end_date_rule_item]
|
85
|
+
}
|
86
|
+
|
87
|
+
# Combine the rule item groups into a Rule so AdWords will OR the
|
88
|
+
# groups together.
|
89
|
+
rule = {
|
90
|
+
:groups => [checkout_multiple_item_group, checked_out_nov_dec_item_group]
|
91
|
+
}
|
92
|
+
|
93
|
+
# Create the user list with no restrictions on site visit date.
|
94
|
+
expression_user_list = {
|
95
|
+
:xsi_type => 'ExpressionRuleUserList',
|
96
|
+
:name => 'Users who checked out in November or December OR ' +
|
97
|
+
'visited the checkout page with more than one item in their cart',
|
98
|
+
:description => 'Expression based user list',
|
99
|
+
:rule => rule
|
100
|
+
}
|
101
|
+
|
102
|
+
# Create the user list restricted to users who visit your site within the
|
103
|
+
# specified timeframe.
|
104
|
+
date_user_list = {
|
105
|
+
:xsi_type => 'DateSpecificRuleUserList',
|
106
|
+
:name => 'Date rule user list created at ' + Time.now.to_s,
|
107
|
+
:description => 'Users who visited the site between 20141031 and ' +
|
108
|
+
'20150331 and checked out in November or December OR visited the ' +
|
109
|
+
'checkout page with more than one item in their cart',
|
110
|
+
# We re-use the rule here. To avoid side effects, we need a deep copy.
|
111
|
+
:rule => Marshal.load(Marshal.dump(rule)),
|
112
|
+
# Set the start and end dates of the user list.
|
113
|
+
:start_date => '20141031',
|
114
|
+
:end_date => '20150331'
|
115
|
+
}
|
116
|
+
|
117
|
+
# Create operations to add the user lists.
|
118
|
+
operations = [expression_user_list, date_user_list].map do |user_list|
|
119
|
+
{
|
120
|
+
:operand => user_list,
|
121
|
+
:operator => 'ADD'
|
122
|
+
}
|
123
|
+
end
|
124
|
+
|
125
|
+
# Submit the operations.
|
126
|
+
response = user_list_srv.mutate(operations)
|
127
|
+
|
128
|
+
# Display the results.
|
129
|
+
response[:value].each do |user_list|
|
130
|
+
puts ("User list added with ID %d, name '%s', status '%s', " +
|
131
|
+
"list type '%s', accountUserListStatus '%s', description '%s'.") %
|
132
|
+
[user_list[:id], user_list[:name], user_list[:status],
|
133
|
+
user_list[:list_type], user_list[:account_user_list_status],
|
134
|
+
user_list[:description]]
|
135
|
+
end
|
136
|
+
end
|
137
|
+
|
138
|
+
if __FILE__ == $0
|
139
|
+
API_VERSION = :v201601
|
140
|
+
|
141
|
+
begin
|
142
|
+
add_rule_based_user_lists()
|
143
|
+
|
144
|
+
# Authorization error.
|
145
|
+
rescue AdsCommon::Errors::OAuth2VerificationRequired => e
|
146
|
+
puts "Authorization credentials are not valid. Edit adwords_api.yml for " +
|
147
|
+
"OAuth2 client ID and secret and run misc/setup_oauth2.rb example " +
|
148
|
+
"to retrieve and store OAuth2 tokens."
|
149
|
+
puts "See this wiki page for more details:\n\n " +
|
150
|
+
'https://github.com/googleads/google-api-ads-ruby/wiki/OAuth2'
|
151
|
+
|
152
|
+
# HTTP errors.
|
153
|
+
rescue AdsCommon::Errors::HttpError => e
|
154
|
+
puts "HTTP Error: %s" % e
|
155
|
+
|
156
|
+
# API errors.
|
157
|
+
rescue AdwordsApi::Errors::ApiException => e
|
158
|
+
puts "Message: %s" % e.message
|
159
|
+
puts 'Errors:'
|
160
|
+
e.errors.each_with_index do |error, index|
|
161
|
+
puts "\tError [%d]:" % (index + 1)
|
162
|
+
error.each do |field, value|
|
163
|
+
puts "\t\t%s: %s" % [field, value]
|
164
|
+
end
|
165
|
+
end
|
166
|
+
end
|
167
|
+
end
|