google-dfp-api 0.2.2 → 0.2.3

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 +3 -0
  2. data/examples/v201101/company_service/create_companies.rb +3 -4
  3. data/examples/v201101/company_service/update_companies.rb +2 -2
  4. data/examples/v201101/creative_service/create_creatives.rb +8 -11
  5. data/examples/v201101/inventory_service/create_ad_units.rb +7 -10
  6. data/examples/v201101/inventory_service/update_ad_units.rb +1 -1
  7. data/examples/v201101/line_item_service/create_line_items.rb +2 -3
  8. data/examples/v201101/line_item_service/update_line_items.rb +1 -1
  9. data/examples/v201101/order_service/create_orders.rb +5 -6
  10. data/examples/v201101/order_service/update_orders.rb +1 -1
  11. data/examples/v201101/placement_service/create_placements.rb +1 -1
  12. data/examples/v201101/placement_service/update_placements.rb +2 -1
  13. data/examples/v201101/user_service/update_users.rb +1 -1
  14. data/examples/v201103/company_service/create_companies.rb +3 -4
  15. data/examples/v201103/company_service/update_companies.rb +2 -2
  16. data/examples/v201103/creative_service/create_creatives.rb +8 -11
  17. data/examples/v201103/inventory_service/create_ad_units.rb +7 -10
  18. data/examples/v201103/inventory_service/update_ad_units.rb +1 -1
  19. data/examples/v201103/line_item_service/create_line_items.rb +2 -3
  20. data/examples/v201103/line_item_service/update_line_items.rb +1 -1
  21. data/examples/v201103/order_service/create_orders.rb +5 -6
  22. data/examples/v201103/order_service/update_orders.rb +1 -1
  23. data/examples/v201103/placement_service/create_placements.rb +1 -1
  24. data/examples/v201103/placement_service/update_placements.rb +2 -1
  25. data/examples/v201103/user_service/update_users.rb +1 -1
  26. data/examples/v201104/company_service/create_companies.rb +3 -4
  27. data/examples/v201104/company_service/update_companies.rb +2 -2
  28. data/examples/v201104/creative_service/create_creatives.rb +8 -11
  29. data/examples/v201104/inventory_service/create_ad_units.rb +7 -10
  30. data/examples/v201104/inventory_service/update_ad_units.rb +1 -1
  31. data/examples/v201104/line_item_service/create_line_items.rb +2 -3
  32. data/examples/v201104/line_item_service/update_line_items.rb +1 -1
  33. data/examples/v201104/order_service/create_orders.rb +5 -6
  34. data/examples/v201104/order_service/update_orders.rb +1 -1
  35. data/examples/v201104/placement_service/create_placements.rb +1 -1
  36. data/examples/v201104/placement_service/update_placements.rb +2 -1
  37. data/examples/v201104/user_service/update_users.rb +1 -1
  38. data/examples/v201107/common/error_handling.rb +76 -0
  39. data/examples/v201107/common/oauth_handling.rb +128 -0
  40. data/examples/v201107/company_service/create_companies.rb +81 -0
  41. data/examples/v201107/company_service/get_all_companies.rb +92 -0
  42. data/examples/v201107/company_service/get_companies_by_statement.rb +88 -0
  43. data/examples/v201107/company_service/get_company.rb +72 -0
  44. data/examples/v201107/company_service/update_companies.rb +95 -0
  45. data/examples/v201107/creative_service/copy_image_creatives.rb +117 -0
  46. data/examples/v201107/creative_service/create_creatives.rb +106 -0
  47. data/examples/v201107/creative_service/get_all_creatives.rb +93 -0
  48. data/examples/v201107/creative_service/get_creative.rb +72 -0
  49. data/examples/v201107/creative_service/get_creatives_by_statement.rb +87 -0
  50. data/examples/v201107/creative_service/update_creatives.rb +98 -0
  51. data/examples/v201107/custom_targeting_service/create_custom_targeting_keys_and_values.rb +118 -0
  52. data/examples/v201107/custom_targeting_service/delete_custom_targeting_keys.rb +121 -0
  53. data/examples/v201107/custom_targeting_service/delete_custom_targeting_values.rb +125 -0
  54. data/examples/v201107/custom_targeting_service/get_all_custom_targeting_keys_and_values.rb +148 -0
  55. data/examples/v201107/custom_targeting_service/get_custom_targeting_keys_by_statement.rb +92 -0
  56. data/examples/v201107/custom_targeting_service/get_custom_targeting_values_by_statement.rb +98 -0
  57. data/examples/v201107/custom_targeting_service/update_custom_targeting_keys.rb +94 -0
  58. data/examples/v201107/custom_targeting_service/update_custom_targeting_values.rb +106 -0
  59. data/examples/v201107/forecast_service/get_forecast.rb +103 -0
  60. data/examples/v201107/forecast_service/get_forecast_by_id.rb +80 -0
  61. data/examples/v201107/inventory_service/create_ad_units.rb +95 -0
  62. data/examples/v201107/inventory_service/deactivate_ad_units.rb +119 -0
  63. data/examples/v201107/inventory_service/get_ad_unit.rb +72 -0
  64. data/examples/v201107/inventory_service/get_ad_unit_sizes.rb +73 -0
  65. data/examples/v201107/inventory_service/get_ad_units_by_statement.rb +96 -0
  66. data/examples/v201107/inventory_service/get_all_ad_units.rb +93 -0
  67. data/examples/v201107/inventory_service/update_ad_units.rb +94 -0
  68. data/examples/v201107/label_service/create_labels.rb +83 -0
  69. data/examples/v201107/label_service/deactivate_labels.rb +118 -0
  70. data/examples/v201107/label_service/get_all_labels.rb +94 -0
  71. data/examples/v201107/label_service/get_label.rb +76 -0
  72. data/examples/v201107/label_service/get_labels_by_statement.rb +91 -0
  73. data/examples/v201107/label_service/update_labels.rb +104 -0
  74. data/examples/v201107/line_item_creative_association_service/create_licas.rb +94 -0
  75. data/examples/v201107/line_item_creative_association_service/deactivate_licas.rb +127 -0
  76. data/examples/v201107/line_item_creative_association_service/get_all_licas.rb +95 -0
  77. data/examples/v201107/line_item_creative_association_service/get_lica.rb +77 -0
  78. data/examples/v201107/line_item_creative_association_service/get_licas_by_statement.rb +91 -0
  79. data/examples/v201107/line_item_creative_association_service/update_licas.rb +92 -0
  80. data/examples/v201107/line_item_service/activate_line_items.rb +131 -0
  81. data/examples/v201107/line_item_service/create_line_items.rb +167 -0
  82. data/examples/v201107/line_item_service/get_all_line_items.rb +94 -0
  83. data/examples/v201107/line_item_service/get_line_item.rb +74 -0
  84. data/examples/v201107/line_item_service/get_line_items_by_statement.rb +89 -0
  85. data/examples/v201107/line_item_service/target_custom_criteria.rb +129 -0
  86. data/examples/v201107/line_item_service/update_line_items.rb +110 -0
  87. data/examples/v201107/network_service/get_all_networks.rb +74 -0
  88. data/examples/v201107/network_service/get_current_network.rb +66 -0
  89. data/examples/v201107/order_service/approve_orders.rb +116 -0
  90. data/examples/v201107/order_service/create_orders.rb +92 -0
  91. data/examples/v201107/order_service/get_all_orders.rb +93 -0
  92. data/examples/v201107/order_service/get_order.rb +74 -0
  93. data/examples/v201107/order_service/get_orders_by_statement.rb +90 -0
  94. data/examples/v201107/order_service/update_orders.rb +95 -0
  95. data/examples/v201107/placement_service/create_placements.rb +128 -0
  96. data/examples/v201107/placement_service/deactivate_placements.rb +118 -0
  97. data/examples/v201107/placement_service/get_all_placements.rb +93 -0
  98. data/examples/v201107/placement_service/get_placement.rb +74 -0
  99. data/examples/v201107/placement_service/get_placements_by_statement.rb +86 -0
  100. data/examples/v201107/placement_service/update_placements.rb +97 -0
  101. data/examples/v201107/publisher_query_language_service/get_all_bandwidth_groups.rb +85 -0
  102. data/examples/v201107/publisher_query_language_service/get_all_browser_languages.rb +85 -0
  103. data/examples/v201107/publisher_query_language_service/get_all_browsers.rb +85 -0
  104. data/examples/v201107/publisher_query_language_service/get_all_cities.rb +85 -0
  105. data/examples/v201107/publisher_query_language_service/get_all_countries.rb +85 -0
  106. data/examples/v201107/publisher_query_language_service/get_all_metros.rb +85 -0
  107. data/examples/v201107/publisher_query_language_service/get_all_operating_systems.rb +85 -0
  108. data/examples/v201107/publisher_query_language_service/get_all_regions.rb +85 -0
  109. data/examples/v201107/report_service/download_report.rb +81 -0
  110. data/examples/v201107/report_service/run_delivery_report.rb +89 -0
  111. data/examples/v201107/report_service/run_inventory_report.rb +90 -0
  112. data/examples/v201107/report_service/run_sales_report.rb +89 -0
  113. data/examples/v201107/user_service/create_users.rb +89 -0
  114. data/examples/v201107/user_service/deactivate_users.rb +99 -0
  115. data/examples/v201107/user_service/get_all_roles.rb +73 -0
  116. data/examples/v201107/user_service/get_all_users.rb +92 -0
  117. data/examples/v201107/user_service/get_current_user.rb +66 -0
  118. data/examples/v201107/user_service/get_user.rb +73 -0
  119. data/examples/v201107/user_service/get_users_by_statement.rb +79 -0
  120. data/examples/v201107/user_service/update_users.rb +89 -0
  121. data/lib/dfp_api/api_config.rb +16 -7
  122. data/lib/dfp_api/v201107/company_service.rb +52 -0
  123. data/lib/dfp_api/v201107/company_service_registry.rb +42 -0
  124. data/lib/dfp_api/v201107/creative_service.rb +52 -0
  125. data/lib/dfp_api/v201107/creative_service_registry.rb +42 -0
  126. data/lib/dfp_api/v201107/custom_targeting_service.rb +60 -0
  127. data/lib/dfp_api/v201107/custom_targeting_service_registry.rb +42 -0
  128. data/lib/dfp_api/v201107/forecast_service.rb +36 -0
  129. data/lib/dfp_api/v201107/forecast_service_registry.rb +42 -0
  130. data/lib/dfp_api/v201107/inventory_service.rb +60 -0
  131. data/lib/dfp_api/v201107/inventory_service_registry.rb +42 -0
  132. data/lib/dfp_api/v201107/label_service.rb +56 -0
  133. data/lib/dfp_api/v201107/label_service_registry.rb +42 -0
  134. data/lib/dfp_api/v201107/line_item_creative_association_service.rb +56 -0
  135. data/lib/dfp_api/v201107/line_item_creative_association_service_registry.rb +42 -0
  136. data/lib/dfp_api/v201107/line_item_service.rb +56 -0
  137. data/lib/dfp_api/v201107/line_item_service_registry.rb +42 -0
  138. data/lib/dfp_api/v201107/network_service.rb +40 -0
  139. data/lib/dfp_api/v201107/network_service_registry.rb +42 -0
  140. data/lib/dfp_api/v201107/order_service.rb +56 -0
  141. data/lib/dfp_api/v201107/order_service_registry.rb +42 -0
  142. data/lib/dfp_api/v201107/placement_service.rb +56 -0
  143. data/lib/dfp_api/v201107/placement_service_registry.rb +42 -0
  144. data/lib/dfp_api/v201107/publisher_query_language_service.rb +32 -0
  145. data/lib/dfp_api/v201107/publisher_query_language_service_registry.rb +42 -0
  146. data/lib/dfp_api/v201107/report_service.rb +40 -0
  147. data/lib/dfp_api/v201107/report_service_registry.rb +42 -0
  148. data/lib/dfp_api/v201107/user_service.rb +64 -0
  149. data/lib/dfp_api/v201107/user_service_registry.rb +42 -0
  150. metadata +115 -4
@@ -0,0 +1,167 @@
1
+ #!/usr/bin/ruby
2
+ #
3
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
+ #
5
+ # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
+ #
7
+ # License:: Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
16
+ # implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+ # This example creates new line items. To determine which line items exist, run
21
+ # get_all_line_items.rb. To determine which orders exist, run
22
+ # get_all_orders.rb. To determine which placements exist, run
23
+ # get_all_placements.rb. To determine the IDs for locations, run
24
+ # get_all_cities.rb, get_all_countries.rb, get_all_metros.rb and
25
+ # get_all_regions.rb.
26
+ #
27
+ # Tags: LineItemService.createLineItems
28
+
29
+ require 'rubygems'
30
+ require 'dfp_api'
31
+
32
+ API_VERSION = :v201107
33
+ # Number of line items to create.
34
+ ITEM_COUNT = 5
35
+
36
+ def create_line_items()
37
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
38
+ dfp = DfpApi::Api.new
39
+
40
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
41
+ # the configuration file or provide your own logger:
42
+ # dfp.logger = Logger.new('dfp_xml.log')
43
+
44
+ # Get the LineItemService.
45
+ line_item_service = dfp.service(:LineItemService, API_VERSION)
46
+
47
+ # Set the order that all created line items will belong to and the placement
48
+ # ID to target.
49
+ order_id = 'INSERT_ORDER_ID_HERE'.to_i
50
+ targeted_placement_ids = Array.new(ITEM_COUNT) do
51
+ 'INSERT_PLACEMENT_ID_HERE'.to_i
52
+ end
53
+
54
+ # Create inventory targeting.
55
+ inventory_targeting = {:targeted_placement_ids => targeted_placement_ids}
56
+
57
+ # Create geographical targeting.
58
+ geo_targeting = {
59
+ # Include the US and Quebec, Canada.
60
+ :targeted_locations => [{:id => 2840}, {:id => 20123}],
61
+ # Exclude Chicago and the New York metro area.
62
+ :excluded_locations => [{:id => 1016367}, {:id => 200501}]
63
+ }
64
+
65
+ # Create user domain targeting. Exclude domains that are not under the
66
+ # network's control.
67
+ user_domain_targeting = {:domains => ['usa.gov'], :targeted => false}
68
+
69
+ # Create day-part targeting.
70
+ day_part_targeting = {
71
+ # Target only the weekend in the browser's timezone.
72
+ :time_zone => 'BROWSER',
73
+ :day_parts => [
74
+ {:day_of_week => 'SATURDAY',
75
+ :start_time => {:hour => 0, :minute => 'ZERO'},
76
+ :end_time => {:hour => 24, :minute => 'ZERO'}},
77
+ {:day_of_week => 'SUNDAY',
78
+ :start_time => {:hour => 0, :minute => 'ZERO'},
79
+ :end_time => {:hour => 24, :minute => 'ZERO'}}
80
+ ]
81
+ }
82
+
83
+ # Create technology targeting.
84
+ technology_targeting = {
85
+ # Create browser targeting.
86
+ :browser_targeting => {
87
+ :is_targeted => true,
88
+ # Target just the Chrome browser.
89
+ :browsers => [{:id => 500072}]
90
+ }
91
+ }
92
+
93
+ # Create targeting.
94
+ targeting = {:geo_targeting => geo_targeting,
95
+ :inventory_targeting => inventory_targeting,
96
+ :user_domain_targeting => user_domain_targeting,
97
+ :day_part_targeting => day_part_targeting,
98
+ :technology_targeting => technology_targeting
99
+ }
100
+
101
+ # Create an array to store local line item objects.
102
+ line_items = (1..ITEM_COUNT).map do |index|
103
+ line_item = {:name => "Line item #%d" % index,
104
+ :order_id => order_id,
105
+ :targeting => targeting,
106
+ :line_item_type => 'STANDARD',
107
+ :allow_overbook => true}
108
+ # Set the creative rotation type to even.
109
+ line_item[:creative_rotation_type] = 'EVEN'
110
+
111
+ # Set the size of creatives that can be associated with this line item.
112
+ line_item[:creative_sizes] = [
113
+ {:width => 300, :height => 250, :is_aspect_ratio => false}
114
+ ]
115
+
116
+ # Set the length of the line item to run.
117
+ line_item[:start_date_time_type] = 'IMMEDIATELY'
118
+ line_item[:end_date_time] = Time.new + 60 * 60 * 24 * 7
119
+
120
+ # Set the cost per unit to $2.
121
+ line_item[:cost_type] = 'CPM'
122
+ line_item[:cost_per_unit] = {
123
+ :currency_code => 'USD',
124
+ :micro_amount => 2000000
125
+ }
126
+
127
+ # Set the number of units bought to 500,000 so that the budget is $1,000.
128
+ line_item[:units_bought] = 500000
129
+ line_item[:unit_type] = 'IMPRESSIONS'
130
+
131
+ line_item
132
+ end
133
+
134
+ # Create the line items on the server.
135
+ return_line_items = line_item_service.create_line_items(line_items)
136
+
137
+ if return_line_items
138
+ return_line_items.each do |line_item|
139
+ puts ("Line item with ID: %d, belonging to order ID: %d, " +
140
+ "and named: %s was created.") %
141
+ [line_item[:id], line_item[:order_id], line_item[:name]]
142
+ end
143
+ else
144
+ raise 'No line items were created.'
145
+ end
146
+ end
147
+
148
+ if __FILE__ == $0
149
+ begin
150
+ create_line_items()
151
+
152
+ # HTTP errors.
153
+ rescue AdsCommon::Errors::HttpError => e
154
+ puts "HTTP Error: %s" % e
155
+
156
+ # API errors.
157
+ rescue DfpApi::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
@@ -0,0 +1,94 @@
1
+ #!/usr/bin/ruby
2
+ #
3
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
+ #
5
+ # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
+ #
7
+ # License:: Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
16
+ # implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+ # This example gets all line items. To create line items, run
21
+ # create_line_items.rb.
22
+ #
23
+ # Tags: LineItemService.getLineItemsByStatement
24
+
25
+ require 'rubygems'
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201107
29
+ PAGE_SIZE = 500
30
+
31
+ def get_all_line_items()
32
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
33
+ dfp = DfpApi::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
+ # dfp.logger = Logger.new('dfp_xml.log')
38
+
39
+ # Get the LineItemService.
40
+ line_item_service = dfp.service(:LineItemService, API_VERSION)
41
+
42
+ # Define initial values.
43
+ offset = 0
44
+ page = {}
45
+
46
+ begin
47
+ # Create a statement to get one page with current offset.
48
+ statement = {:query => "LIMIT %d OFFSET %d" % [PAGE_SIZE, offset]}
49
+
50
+ # Get line items by statement.
51
+ page = line_item_service.get_line_items_by_statement(statement)
52
+
53
+ if page[:results]
54
+ # Increase query offset by page size.
55
+ offset += PAGE_SIZE
56
+
57
+ # Get the start index for printout.
58
+ start_index = page[:start_index]
59
+
60
+ # Print details about each line item in results.
61
+ page[:results].each_with_index do |line_item, index|
62
+ puts "%d) Line item ID: %d, order ID: %d, name: %s" %
63
+ [index + start_index, line_item[:id],
64
+ line_item[:order_id], line_item[:name]]
65
+ end
66
+ end
67
+ end while offset < page[:total_result_set_size]
68
+
69
+ # Print a footer.
70
+ if page.include?(:total_result_set_size)
71
+ puts "Total number of line items: %d" % page[:total_result_set_size]
72
+ end
73
+ end
74
+
75
+ if __FILE__ == $0
76
+ begin
77
+ get_all_line_items()
78
+
79
+ # HTTP errors.
80
+ rescue AdsCommon::Errors::HttpError => e
81
+ puts "HTTP Error: %s" % e
82
+
83
+ # API errors.
84
+ rescue DfpApi::Errors::ApiException => e
85
+ puts "Message: %s" % e.message
86
+ puts 'Errors:'
87
+ e.errors.each_with_index do |error, index|
88
+ puts "\tError [%d]:" % (index + 1)
89
+ error.each do |field, value|
90
+ puts "\t\t%s: %s" % [field, value]
91
+ end
92
+ end
93
+ end
94
+ end
@@ -0,0 +1,74 @@
1
+ #!/usr/bin/ruby
2
+ #
3
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
+ #
5
+ # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
+ #
7
+ # License:: Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
16
+ # implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+ # This example gets a line item by its ID. To determine which line items
21
+ # exist, run get_all_line_items.rb.
22
+ #
23
+ # Tags: LineItemService.getLineItem
24
+
25
+ require 'rubygems'
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201107
29
+
30
+ def get_line_item()
31
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
32
+ dfp = DfpApi::Api.new
33
+
34
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
35
+ # the configuration file or provide your own logger:
36
+ # dfp.logger = Logger.new('dfp_xml.log')
37
+
38
+ # Get the LineItemService.
39
+ line_item_service = dfp.service(:LineItemService, API_VERSION)
40
+
41
+ # Set the ID of the line_item to get.
42
+ line_item_id = 'INSERT_LINE_ITEM_ID_HERE'.to_i
43
+
44
+ # Get the line item.
45
+ line_item = line_item_service.get_line_item(line_item_id)
46
+
47
+ if line_item
48
+ puts "Line item with ID: %d, name: %s and order id: %d was found." %
49
+ [line_item[:id], line_item[:name], line_item[:order_id]]
50
+ else
51
+ puts 'No line item found for this ID.'
52
+ end
53
+ end
54
+
55
+ if __FILE__ == $0
56
+ begin
57
+ get_line_item()
58
+
59
+ # HTTP errors.
60
+ rescue AdsCommon::Errors::HttpError => e
61
+ puts "HTTP Error: %s" % e
62
+
63
+ # API errors.
64
+ rescue DfpApi::Errors::ApiException => e
65
+ puts "Message: %s" % e.message
66
+ puts 'Errors:'
67
+ e.errors.each_with_index do |error, index|
68
+ puts "\tError [%d]:" % (index + 1)
69
+ error.each do |field, value|
70
+ puts "\t\t%s: %s" % [field, value]
71
+ end
72
+ end
73
+ end
74
+ end
@@ -0,0 +1,89 @@
1
+ #!/usr/bin/ruby
2
+ #
3
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
+ #
5
+ # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
+ #
7
+ # License:: Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
16
+ # implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+ # This example gets all line items for the given order. The statement retrieves
21
+ # up to the maximum page size limit of 500. To create line items, run
22
+ # create_line_items.rb. To determine which orders exist, run get_all_orders.rb.
23
+ #
24
+ # Tags: LineItemService.getLineItemsByStatement
25
+
26
+ require 'rubygems'
27
+ require 'dfp_api'
28
+
29
+ API_VERSION = :v201107
30
+
31
+ def get_line_items_by_statement()
32
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
33
+ dfp = DfpApi::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
+ # dfp.logger = Logger.new('dfp_xml.log')
38
+
39
+ # Get the LineItemService.
40
+ line_item_service = dfp.service(:LineItemService, API_VERSION)
41
+
42
+ # Set the ID of the order to get line items from.
43
+ order_id = 'INSERT_ORDER_ID_HERE'.to_i
44
+
45
+ # Create a statement to only select line items from a given order.
46
+ statement = {
47
+ :query => 'WHERE orderId = :order_id LIMIT 500',
48
+ :values => [
49
+ {:key => 'order_id',
50
+ :value => {:value => order_id, :xsi_type => 'NumberValue'}}
51
+ ]
52
+ }
53
+
54
+ # Get line items by statement.
55
+ page = line_item_service.get_line_items_by_statement(statement)
56
+
57
+ if page and page[:results]
58
+ page[:results].each_with_index do |line_item, index|
59
+ puts "%d) [%d] belongs to order ID %d, name: %s." % [index,
60
+ line_item[:id], line_item[:order_id], line_item[:name]]
61
+ end
62
+ end
63
+
64
+ # Print a footer.
65
+ if page.include?(:total_result_set_size)
66
+ puts "Number of results found: %d" % page[:total_result_set_size]
67
+ end
68
+ end
69
+
70
+ if __FILE__ == $0
71
+ begin
72
+ get_line_items_by_statement()
73
+
74
+ # HTTP errors.
75
+ rescue AdsCommon::Errors::HttpError => e
76
+ puts "HTTP Error: %s" % e
77
+
78
+ # API errors.
79
+ rescue DfpApi::Errors::ApiException => e
80
+ puts "Message: %s" % e.message
81
+ puts 'Errors:'
82
+ e.errors.each_with_index do |error, index|
83
+ puts "\tError [%d]:" % (index + 1)
84
+ error.each do |field, value|
85
+ puts "\t\t%s: %s" % [field, value]
86
+ end
87
+ end
88
+ end
89
+ end
@@ -0,0 +1,129 @@
1
+ #!/usr/bin/ruby
2
+ #
3
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
4
+ #
5
+ # Copyright:: Copyright 2011, Google Inc. All Rights Reserved.
6
+ #
7
+ # License:: Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
16
+ # implied.
17
+ # See the License for the specific language governing permissions and
18
+ # limitations under the License.
19
+ #
20
+ # This example updates a line item to add custom criteria targeting. To
21
+ # determine which line items exist, run get_all_line_items.rb. To determine
22
+ # which custom targeting keys and values exist, run
23
+ # get_all_custom_targeting_keys_and_values.rb.
24
+ #
25
+ # Tags: LineItemService.getLineItem, LineItemService.updateLineItem
26
+
27
+ require 'rubygems'
28
+ require 'dfp_api'
29
+
30
+ require 'pp'
31
+
32
+ API_VERSION = :v201107
33
+ PAGE_SIZE = 500
34
+
35
+ def target_custom_criteria()
36
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
37
+ dfp = DfpApi::Api.new
38
+
39
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
40
+ # the configuration file or provide your own logger:
41
+ # dfp.logger = Logger.new('dfp_xml.log')
42
+
43
+ # Get the LineItemService.
44
+ line_item_service = dfp.service(:LineItemService, API_VERSION)
45
+
46
+ # Set the ID of the line item to update targeting.
47
+ line_item_id = 'INSERT_LINE_ITEM_ID_HERE'.to_i
48
+
49
+ # Set the IDs of the custom targeting keys.
50
+ custom_criteria_ids = [
51
+ {:key => 'INSERT_CUSTOM_TARGETING_KEY_ID_HERE'.to_i,
52
+ :values => ['INSERT_CUSTOM_TARGETING_VALUE_IDS_HERE'.to_i]},
53
+ {:key => 'INSERT_CUSTOM_TARGETING_KEY_ID_HERE'.to_i,
54
+ :values => ['INSERT_CUSTOM_TARGETING_VALUE_IDS_HERE'.to_i]},
55
+ {:key => 'INSERT_CUSTOM_TARGETING_KEY_ID_HERE'.to_i,
56
+ :values => ['INSERT_CUSTOM_TARGETING_VALUE_IDS_HERE'.to_i]}
57
+ ]
58
+
59
+ # Create custom criteria.
60
+ custom_criteria = [
61
+ {:xsi_type => 'CustomCriteria',
62
+ :key_id => custom_criteria_ids[0][:key],
63
+ :value_ids => custom_criteria_ids[0][:values],
64
+ :operator => 'IS'},
65
+ {:xsi_type => 'CustomCriteria',
66
+ :key_id => custom_criteria_ids[1][:key],
67
+ :value_ids => custom_criteria_ids[1][:values],
68
+ :operator => 'IS_NOT'},
69
+ {:xsi_type => 'CustomCriteria',
70
+ :key_id => custom_criteria_ids[2][:key],
71
+ :value_ids => custom_criteria_ids[2][:values],
72
+ :operator => 'IS'}
73
+ ]
74
+
75
+ # Create the custom criteria set that will resemble:
76
+ #
77
+ # (custom_criteria[0].key == custom_criteria[0].values OR
78
+ # (custom_criteria[1].key != custom_criteria[1].values AND
79
+ # custom_criteria[2].key == custom_criteria[2].values))
80
+ sub_custom_criteria_set = {
81
+ :xsi_type => 'CustomCriteriaSet',
82
+ :logical_operator => 'AND',
83
+ :children => [custom_criteria[1], custom_criteria[2]]
84
+ }
85
+ top_custom_criteria_set = {
86
+ :xsi_type => 'CustomCriteriaSet',
87
+ :logical_operator => 'OR',
88
+ :children => [custom_criteria[0], sub_custom_criteria_set]
89
+ }
90
+
91
+ # Get the line item.
92
+ line_item = line_item_service.get_line_item(line_item_id)
93
+
94
+ # Set the custom criteria targeting on the line item.
95
+ line_item[:targeting] = {:custom_targeting => top_custom_criteria_set}
96
+
97
+ # Update the line items on the server.
98
+ return_line_item = line_item_service.update_line_item(line_item)
99
+
100
+ # Display the updated line item.
101
+ if return_line_item
102
+ puts "Line item ID: %d was updated with custom criteria targeting:" %
103
+ return_line_item[:id]
104
+ pp return_line_item[:targeting]
105
+ else
106
+ puts 'Line item update failed.'
107
+ end
108
+ end
109
+
110
+ if __FILE__ == $0
111
+ begin
112
+ target_custom_criteria()
113
+
114
+ # HTTP errors.
115
+ rescue AdsCommon::Errors::HttpError => e
116
+ puts "HTTP Error: %s" % e
117
+
118
+ # API errors.
119
+ rescue DfpApi::Errors::ApiException => e
120
+ puts "Message: %s" % e.message
121
+ puts 'Errors:'
122
+ e.errors.each_with_index do |error, index|
123
+ puts "\tError [%d]:" % (index + 1)
124
+ error.each do |field, value|
125
+ puts "\t\t%s: %s" % [field, value]
126
+ end
127
+ end
128
+ end
129
+ end