google-dfp-api 0.6.1 → 0.6.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 (206) hide show
  1. data/ChangeLog +3 -0
  2. data/examples/v201302/activity_group_service/create_activity_groups.rb +94 -0
  3. data/examples/v201302/activity_group_service/get_active_activity_groups.rb +100 -0
  4. data/examples/v201302/activity_group_service/get_all_activity_groups.rb +95 -0
  5. data/examples/v201302/activity_group_service/update_activity_groups.rb +87 -0
  6. data/examples/v201302/activity_service/create_activities.rb +91 -0
  7. data/examples/v201302/activity_service/get_active_activities.rb +107 -0
  8. data/examples/v201302/activity_service/get_all_activities.rb +144 -0
  9. data/examples/v201302/activity_service/update_activities.rb +85 -0
  10. data/examples/v201302/audience_segment_service/get_all_audience_segments.rb +93 -0
  11. data/examples/v201302/common/error_handling.rb +76 -0
  12. data/examples/v201302/common/oauth2_handling.rb +128 -0
  13. data/examples/v201302/common/oauth2_jwt_handling.rb +107 -0
  14. data/examples/v201302/company_service/create_companies.rb +81 -0
  15. data/examples/v201302/company_service/get_all_companies.rb +92 -0
  16. data/examples/v201302/company_service/get_companies_by_statement.rb +88 -0
  17. data/examples/v201302/company_service/get_company.rb +72 -0
  18. data/examples/v201302/company_service/update_companies.rb +102 -0
  19. data/examples/v201302/contact_service/create_contacts.rb +95 -0
  20. data/examples/v201302/contact_service/get_all_contacts.rb +92 -0
  21. data/examples/v201302/contact_service/get_uninvited_contacts.rb +102 -0
  22. data/examples/v201302/contact_service/update_contacts.rb +84 -0
  23. data/examples/v201302/content_service/get_all_content.rb +94 -0
  24. data/examples/v201302/content_service/get_content_by_category.rb +143 -0
  25. data/examples/v201302/creative_service/copy_image_creatives.rb +115 -0
  26. data/examples/v201302/creative_service/create_creative_from_template.rb +139 -0
  27. data/examples/v201302/creative_service/create_creatives.rb +112 -0
  28. data/examples/v201302/creative_service/create_custom_creative.rb +104 -0
  29. data/examples/v201302/creative_service/get_all_creatives.rb +93 -0
  30. data/examples/v201302/creative_service/get_creative.rb +72 -0
  31. data/examples/v201302/creative_service/get_creatives_by_statement.rb +87 -0
  32. data/examples/v201302/creative_service/update_creatives.rb +96 -0
  33. data/examples/v201302/creative_set_service/associate_creative_set_to_line_item.rb +77 -0
  34. data/examples/v201302/creative_set_service/create_creative_set.rb +83 -0
  35. data/examples/v201302/creative_set_service/get_all_creative_sets.rb +94 -0
  36. data/examples/v201302/creative_set_service/get_creative_sets_by_statement.rb +90 -0
  37. data/examples/v201302/creative_set_service/update_creative_sets.rb +85 -0
  38. data/examples/v201302/creative_template_service/get_all_creative_templates.rb +94 -0
  39. data/examples/v201302/creative_template_service/get_creative_template.rb +74 -0
  40. data/examples/v201302/creative_template_service/get_creative_templates_by_statement.rb +80 -0
  41. data/examples/v201302/creative_wrapper_service/create_creative_wrappers.rb +89 -0
  42. data/examples/v201302/creative_wrapper_service/deactivate_creative_wrapper.rb +102 -0
  43. data/examples/v201302/creative_wrapper_service/get_all_creative_wrappers.rb +94 -0
  44. data/examples/v201302/creative_wrapper_service/get_creative_wrappers_by_statement.rb +88 -0
  45. data/examples/v201302/creative_wrapper_service/update_creative_wrappers.rb +86 -0
  46. data/examples/v201302/custom_field_service/create_custom_field_options.rb +87 -0
  47. data/examples/v201302/custom_field_service/create_custom_fields.rb +86 -0
  48. data/examples/v201302/custom_field_service/deactivate_all_line_item_custom_fields.rb +112 -0
  49. data/examples/v201302/custom_field_service/get_all_custom_fields.rb +102 -0
  50. data/examples/v201302/custom_field_service/get_all_line_item_custom_fields.rb +86 -0
  51. data/examples/v201302/custom_field_service/set_line_item_custom_field_value.rb +135 -0
  52. data/examples/v201302/custom_field_service/update_custom_fields.rb +84 -0
  53. data/examples/v201302/custom_targeting_service/create_custom_targeting_keys_and_values.rb +140 -0
  54. data/examples/v201302/custom_targeting_service/delete_custom_targeting_keys.rb +121 -0
  55. data/examples/v201302/custom_targeting_service/delete_custom_targeting_values.rb +125 -0
  56. data/examples/v201302/custom_targeting_service/get_all_custom_targeting_keys_and_values.rb +148 -0
  57. data/examples/v201302/custom_targeting_service/get_custom_targeting_keys_by_statement.rb +92 -0
  58. data/examples/v201302/custom_targeting_service/get_custom_targeting_values_by_statement.rb +98 -0
  59. data/examples/v201302/custom_targeting_service/update_custom_targeting_keys.rb +94 -0
  60. data/examples/v201302/custom_targeting_service/update_custom_targeting_values.rb +106 -0
  61. data/examples/v201302/forecast_service/get_forecast.rb +107 -0
  62. data/examples/v201302/forecast_service/get_forecast_by_id.rb +80 -0
  63. data/examples/v201302/inventory_service/create_ad_units.rb +101 -0
  64. data/examples/v201302/inventory_service/create_mobile_ad_unit.rb +101 -0
  65. data/examples/v201302/inventory_service/create_video_ad_unit.rb +108 -0
  66. data/examples/v201302/inventory_service/deactivate_ad_units.rb +119 -0
  67. data/examples/v201302/inventory_service/get_ad_unit.rb +72 -0
  68. data/examples/v201302/inventory_service/get_ad_unit_sizes.rb +85 -0
  69. data/examples/v201302/inventory_service/get_ad_units_by_statement.rb +96 -0
  70. data/examples/v201302/inventory_service/get_all_ad_units.rb +93 -0
  71. data/examples/v201302/inventory_service/update_ad_units.rb +96 -0
  72. data/examples/v201302/label_service/create_labels.rb +83 -0
  73. data/examples/v201302/label_service/deactivate_labels.rb +118 -0
  74. data/examples/v201302/label_service/get_all_labels.rb +95 -0
  75. data/examples/v201302/label_service/get_label.rb +76 -0
  76. data/examples/v201302/label_service/get_labels_by_statement.rb +81 -0
  77. data/examples/v201302/label_service/update_labels.rb +102 -0
  78. data/examples/v201302/line_item_creative_association_service/create_licas.rb +94 -0
  79. data/examples/v201302/line_item_creative_association_service/deactivate_licas.rb +127 -0
  80. data/examples/v201302/line_item_creative_association_service/get_all_licas.rb +98 -0
  81. data/examples/v201302/line_item_creative_association_service/get_lica.rb +77 -0
  82. data/examples/v201302/line_item_creative_association_service/get_licas_by_statement.rb +91 -0
  83. data/examples/v201302/line_item_creative_association_service/update_licas.rb +91 -0
  84. data/examples/v201302/line_item_service/activate_line_items.rb +131 -0
  85. data/examples/v201302/line_item_service/create_line_items.rb +177 -0
  86. data/examples/v201302/line_item_service/create_mobile_line_item.rb +135 -0
  87. data/examples/v201302/line_item_service/create_video_line_item.rb +158 -0
  88. data/examples/v201302/line_item_service/get_all_line_items.rb +94 -0
  89. data/examples/v201302/line_item_service/get_line_item.rb +74 -0
  90. data/examples/v201302/line_item_service/get_line_items_by_statement.rb +93 -0
  91. data/examples/v201302/line_item_service/get_recently_updated_line_items.rb +98 -0
  92. data/examples/v201302/line_item_service/target_custom_criteria.rb +129 -0
  93. data/examples/v201302/line_item_service/update_line_items.rb +109 -0
  94. data/examples/v201302/network_service/get_all_networks.rb +74 -0
  95. data/examples/v201302/network_service/get_current_network.rb +66 -0
  96. data/examples/v201302/network_service/make_test_network.rb +79 -0
  97. data/examples/v201302/order_service/approve_orders.rb +122 -0
  98. data/examples/v201302/order_service/create_orders.rb +92 -0
  99. data/examples/v201302/order_service/get_all_orders.rb +93 -0
  100. data/examples/v201302/order_service/get_order.rb +74 -0
  101. data/examples/v201302/order_service/get_orders_by_statement.rb +90 -0
  102. data/examples/v201302/order_service/update_orders.rb +97 -0
  103. data/examples/v201302/placement_service/create_placements.rb +131 -0
  104. data/examples/v201302/placement_service/deactivate_placements.rb +118 -0
  105. data/examples/v201302/placement_service/get_all_placements.rb +93 -0
  106. data/examples/v201302/placement_service/get_placement.rb +74 -0
  107. data/examples/v201302/placement_service/get_placements_by_statement.rb +86 -0
  108. data/examples/v201302/placement_service/update_placements.rb +97 -0
  109. data/examples/v201302/publisher_query_language_service/get_all_cities.rb +104 -0
  110. data/examples/v201302/report_service/display_report.rb +81 -0
  111. data/examples/v201302/report_service/download_report.rb +81 -0
  112. data/examples/v201302/report_service/run_delivery_report.rb +103 -0
  113. data/examples/v201302/report_service/run_inventory_report.rb +96 -0
  114. data/examples/v201302/report_service/run_merged_delivery_report.rb +94 -0
  115. data/examples/v201302/report_service/run_reach_report.rb +87 -0
  116. data/examples/v201302/report_service/run_report_with_custom_fields.rb +135 -0
  117. data/examples/v201302/report_service/run_sales_report.rb +92 -0
  118. data/examples/v201302/suggested_ad_unit_service/approve_all_suggested_ad_units.rb +109 -0
  119. data/examples/v201302/suggested_ad_unit_service/get_all_suggested_ad_units.rb +96 -0
  120. data/examples/v201302/suggested_ad_unit_service/get_suggested_ad_unit.rb +75 -0
  121. data/examples/v201302/suggested_ad_unit_service/get_suggested_ad_units_by_statement.rb +92 -0
  122. data/examples/v201302/team_service/create_teams.rb +83 -0
  123. data/examples/v201302/team_service/get_all_teams.rb +92 -0
  124. data/examples/v201302/team_service/get_team.rb +74 -0
  125. data/examples/v201302/team_service/get_teams_by_statement.rb +78 -0
  126. data/examples/v201302/team_service/update_teams.rb +97 -0
  127. data/examples/v201302/third_party_slot_service/archive_third_party_slots.rb +125 -0
  128. data/examples/v201302/third_party_slot_service/create_third_party_slot.rb +91 -0
  129. data/examples/v201302/third_party_slot_service/get_all_third_party_slots.rb +93 -0
  130. data/examples/v201302/third_party_slot_service/get_third_party_slot_by_statement.rb +86 -0
  131. data/examples/v201302/third_party_slot_service/update_third_party_slots.rb +95 -0
  132. data/examples/v201302/user_service/create_users.rb +89 -0
  133. data/examples/v201302/user_service/deactivate_users.rb +97 -0
  134. data/examples/v201302/user_service/get_all_roles.rb +73 -0
  135. data/examples/v201302/user_service/get_all_users.rb +93 -0
  136. data/examples/v201302/user_service/get_current_user.rb +66 -0
  137. data/examples/v201302/user_service/get_user.rb +73 -0
  138. data/examples/v201302/user_service/get_users_by_statement.rb +79 -0
  139. data/examples/v201302/user_service/update_users.rb +89 -0
  140. data/examples/v201302/user_team_association_service/create_user_team_associations.rb +86 -0
  141. data/examples/v201302/user_team_association_service/delete_user_team_associations.rb +111 -0
  142. data/examples/v201302/user_team_association_service/get_all_user_team_associations.rb +94 -0
  143. data/examples/v201302/user_team_association_service/get_user_team_association.rb +76 -0
  144. data/examples/v201302/user_team_association_service/get_user_team_associations_by_statement.rb +94 -0
  145. data/examples/v201302/user_team_association_service/update_user_team_associations.rb +102 -0
  146. data/lib/dfp_api/api_config.rb +17 -4
  147. data/lib/dfp_api/v201302/activity_group_service.rb +54 -0
  148. data/lib/dfp_api/v201302/activity_group_service_registry.rb +46 -0
  149. data/lib/dfp_api/v201302/activity_service.rb +54 -0
  150. data/lib/dfp_api/v201302/activity_service_registry.rb +46 -0
  151. data/lib/dfp_api/v201302/ad_rule_service.rb +58 -0
  152. data/lib/dfp_api/v201302/ad_rule_service_registry.rb +46 -0
  153. data/lib/dfp_api/v201302/audience_segment_service.rb +34 -0
  154. data/lib/dfp_api/v201302/audience_segment_service_registry.rb +46 -0
  155. data/lib/dfp_api/v201302/company_service.rb +54 -0
  156. data/lib/dfp_api/v201302/company_service_registry.rb +46 -0
  157. data/lib/dfp_api/v201302/contact_service.rb +54 -0
  158. data/lib/dfp_api/v201302/contact_service_registry.rb +46 -0
  159. data/lib/dfp_api/v201302/content_bundle_service.rb +58 -0
  160. data/lib/dfp_api/v201302/content_bundle_service_registry.rb +46 -0
  161. data/lib/dfp_api/v201302/content_service.rb +38 -0
  162. data/lib/dfp_api/v201302/content_service_registry.rb +46 -0
  163. data/lib/dfp_api/v201302/creative_service.rb +54 -0
  164. data/lib/dfp_api/v201302/creative_service_registry.rb +46 -0
  165. data/lib/dfp_api/v201302/creative_set_service.rb +46 -0
  166. data/lib/dfp_api/v201302/creative_set_service_registry.rb +46 -0
  167. data/lib/dfp_api/v201302/creative_template_service.rb +38 -0
  168. data/lib/dfp_api/v201302/creative_template_service_registry.rb +46 -0
  169. data/lib/dfp_api/v201302/creative_wrapper_service.rb +58 -0
  170. data/lib/dfp_api/v201302/creative_wrapper_service_registry.rb +46 -0
  171. data/lib/dfp_api/v201302/custom_field_service.rb +78 -0
  172. data/lib/dfp_api/v201302/custom_field_service_registry.rb +46 -0
  173. data/lib/dfp_api/v201302/custom_targeting_service.rb +62 -0
  174. data/lib/dfp_api/v201302/custom_targeting_service_registry.rb +46 -0
  175. data/lib/dfp_api/v201302/forecast_service.rb +38 -0
  176. data/lib/dfp_api/v201302/forecast_service_registry.rb +46 -0
  177. data/lib/dfp_api/v201302/inventory_service.rb +62 -0
  178. data/lib/dfp_api/v201302/inventory_service_registry.rb +46 -0
  179. data/lib/dfp_api/v201302/label_service.rb +58 -0
  180. data/lib/dfp_api/v201302/label_service_registry.rb +46 -0
  181. data/lib/dfp_api/v201302/line_item_creative_association_service.rb +62 -0
  182. data/lib/dfp_api/v201302/line_item_creative_association_service_registry.rb +46 -0
  183. data/lib/dfp_api/v201302/line_item_service.rb +58 -0
  184. data/lib/dfp_api/v201302/line_item_service_registry.rb +46 -0
  185. data/lib/dfp_api/v201302/network_service.rb +46 -0
  186. data/lib/dfp_api/v201302/network_service_registry.rb +46 -0
  187. data/lib/dfp_api/v201302/order_service.rb +58 -0
  188. data/lib/dfp_api/v201302/order_service_registry.rb +46 -0
  189. data/lib/dfp_api/v201302/placement_service.rb +58 -0
  190. data/lib/dfp_api/v201302/placement_service_registry.rb +46 -0
  191. data/lib/dfp_api/v201302/publisher_query_language_service.rb +34 -0
  192. data/lib/dfp_api/v201302/publisher_query_language_service_registry.rb +46 -0
  193. data/lib/dfp_api/v201302/report_service.rb +46 -0
  194. data/lib/dfp_api/v201302/report_service_registry.rb +46 -0
  195. data/lib/dfp_api/v201302/suggested_ad_unit_service.rb +42 -0
  196. data/lib/dfp_api/v201302/suggested_ad_unit_service_registry.rb +46 -0
  197. data/lib/dfp_api/v201302/team_service.rb +54 -0
  198. data/lib/dfp_api/v201302/team_service_registry.rb +46 -0
  199. data/lib/dfp_api/v201302/third_party_slot_service.rb +46 -0
  200. data/lib/dfp_api/v201302/third_party_slot_service_registry.rb +46 -0
  201. data/lib/dfp_api/v201302/user_service.rb +66 -0
  202. data/lib/dfp_api/v201302/user_service_registry.rb +46 -0
  203. data/lib/dfp_api/v201302/user_team_association_service.rb +58 -0
  204. data/lib/dfp_api/v201302/user_team_association_service_registry.rb +46 -0
  205. data/lib/dfp_api/version.rb +1 -1
  206. metadata +988 -786
@@ -0,0 +1,84 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.davidtorres@gmail.com (David Torres)
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 updates contact comments. To determine which contacts exist,
22
+ # run get_all_contacts.rb.
23
+ #
24
+ # Tags: ContactService.updateContacts
25
+
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201302
29
+
30
+ def update_contacts()
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 ContactService.
39
+ contact_service = dfp.service(:ContactService, API_VERSION)
40
+
41
+ contact_id = 'INSERT_CONTACT_ID_HERE'
42
+
43
+ # Get contact.
44
+ contact = contact_service.get_contact(contact_id)
45
+
46
+ # Update the comment of the contact.
47
+ contact[:address] = '123 New Street, New York, NY, 10011'
48
+
49
+ # Update the contact on the server.
50
+ return_contacts = contact_service.update_contacts([contact])
51
+
52
+ # Display results.
53
+ if return_contacts
54
+ return_contacts.each do |updated_contact|
55
+ puts "Contact with ID: %d, name: %s and comment: '%s' was updated." %
56
+ [updated_contact[:id], updated_contact[:name],
57
+ updated_contact[:comment]]
58
+ end
59
+ else
60
+ raise 'No contacts were updated.'
61
+ end
62
+
63
+ end
64
+
65
+ if __FILE__ == $0
66
+ begin
67
+ update_contacts()
68
+
69
+ # HTTP errors.
70
+ rescue AdsCommon::Errors::HttpError => e
71
+ puts "HTTP Error: %s" % e
72
+
73
+ # API errors.
74
+ rescue DfpApi::Errors::ApiException => e
75
+ puts "Message: %s" % e.message
76
+ puts 'Errors:'
77
+ e.errors.each_with_index do |error, index|
78
+ puts "\tError [%d]:" % (index + 1)
79
+ error.each do |field, value|
80
+ puts "\t\t%s: %s" % [field, value]
81
+ end
82
+ end
83
+ end
84
+ end
@@ -0,0 +1,94 @@
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 gets all content.
22
+ #
23
+ # This feature is only available to DFP video publishers.
24
+ #
25
+ # Tags: ContentService.getContentByStatement
26
+
27
+ require 'dfp_api'
28
+
29
+ API_VERSION = :v201302
30
+ PAGE_SIZE = 500
31
+
32
+ def get_all_content()
33
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
34
+ dfp = DfpApi::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
+ # dfp.logger = Logger.new('dfp_xml.log')
39
+
40
+ # Get the ContentService.
41
+ content_service = dfp.service(:ContentService, API_VERSION)
42
+
43
+ # Define initial values.
44
+ offset = 0
45
+ page = {}
46
+
47
+ begin
48
+ # Create statement for one page with current offset.
49
+ statement = {:query => "LIMIT %d OFFSET %d" % [PAGE_SIZE, offset]}
50
+
51
+ # Get content by statement.
52
+ page = content_service.get_content_by_statement(statement)
53
+
54
+ if page[:results]
55
+ # Increase query offset by page size.
56
+ offset += PAGE_SIZE
57
+
58
+ # Get the start index for printout.
59
+ start_index = page[:start_index]
60
+
61
+ # Print details about each content object in results page.
62
+ page[:results].each_with_index do |content, index|
63
+ puts "%d) Content ID: %d, name: %s, status: %s." % [index + start_index,
64
+ content[:id], content[:name], content[:status]]
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 results: %d" % page[:total_result_set_size]
72
+ end
73
+ end
74
+
75
+ if __FILE__ == $0
76
+ begin
77
+ get_all_content()
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,143 @@
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 gets all active content categorized as "comedy" using the
22
+ # network's content browse custom targeting key.
23
+ #
24
+ # This feature is only available to DFP video publishers.
25
+ #
26
+ # Tags: NetworkService.getCurrentNetwork
27
+ # Tags: ContentService.getContentByStatementAndCustomTargetingValue
28
+ # Tags: CustomTargetingService.getCustomTargetingValuesByStatement
29
+
30
+ require 'dfp_api'
31
+
32
+ API_VERSION = :v201302
33
+ PAGE_SIZE = 500
34
+
35
+ def get_content_by_statement()
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 NetworkService.
44
+ network_service = dfp.service(:NetworkService, API_VERSION)
45
+
46
+ # Get content browse custom targeting key ID.
47
+ current_network = network_service.get_current_network
48
+ content_browse_custom_targeting_key_id =
49
+ current_network[:content_browse_custom_targeting_key_id]
50
+
51
+ # Get the CustomTargetingService.
52
+ custom_targeting_service = dfp.service(:CustomTargetingService, API_VERSION)
53
+
54
+ # Create a statement to select the categories matching the name comedy.
55
+ statement = {
56
+ :query => 'WHERE customTargetingKeyId = :targeting_key_id' +
57
+ ' and name = :category LIMIT 1',
58
+ :values => [
59
+ {:key => 'targeting_key_id',
60
+ :value => {:value => content_browse_custom_targeting_key_id,
61
+ :xsi_type => 'NumberValue'}},
62
+ {:key => 'category',
63
+ :value => {:value => 'comedy',
64
+ :xsi_type => 'TextValue'}},
65
+ ]
66
+ }
67
+
68
+ # Get categories matching the filter statement.
69
+ page = custom_targeting_service.get_custom_targeting_values_by_statement(
70
+ statement)
71
+
72
+ # Get the custom targeting value ID for the comedy category.
73
+ if page[:results]
74
+ category_custom_targeting_value_id = page[:results].first()[:id]
75
+
76
+ # Get the ContentService.
77
+ content_service = dfp.service(:ContentService, API_VERSION)
78
+
79
+ # Define initial values.
80
+ offset = 0
81
+ page = {}
82
+
83
+ statement_text = 'WHERE status = :status'
84
+ statement = {
85
+ :query => statement_text,
86
+ :values => [
87
+ {:key => 'status',
88
+ :value => {:value => 'ACTIVE', :xsi_type => 'TextValue'}}
89
+ ]
90
+ }
91
+
92
+ begin
93
+ # Create a statement to get one page with current offset.
94
+ statement[:query] = statement_text +
95
+ " LIMIT %d OFFSET %d" % [PAGE_SIZE, offset]
96
+
97
+ # Get content by statement.
98
+ page =
99
+ content_service.get_content_by_statement_and_custom_targeting_value(
100
+ statement, category_custom_targeting_value_id)
101
+
102
+ if page[:results]
103
+ # Increase query offset by page size.
104
+ offset += PAGE_SIZE
105
+
106
+ page[:results].each_with_index do |content, index|
107
+ puts "%d) Content ID: %d, name: %s, status: %s." %
108
+ [index + start_index, content[:id], content[:name],
109
+ content[:status]]
110
+ end
111
+ end
112
+ end while offset < page[:total_result_set_size]
113
+
114
+ # Print a footer.
115
+ if page.include?(:total_result_set_size)
116
+ puts "Number of results found: %d" % page[:total_result_set_size]
117
+ end
118
+ else
119
+ puts "Category was not found for targeting key ID %d." %
120
+ content_browse_custom_targeting_key_id
121
+ end
122
+ end
123
+
124
+ if __FILE__ == $0
125
+ begin
126
+ get_content_by_statement()
127
+
128
+ # HTTP errors.
129
+ rescue AdsCommon::Errors::HttpError => e
130
+ puts "HTTP Error: %s" % e
131
+
132
+ # API errors.
133
+ rescue DfpApi::Errors::ApiException => e
134
+ puts "Message: %s" % e.message
135
+ puts 'Errors:'
136
+ e.errors.each_with_index do |error, index|
137
+ puts "\tError [%d]:" % (index + 1)
138
+ error.each do |field, value|
139
+ puts "\t\t%s: %s" % [field, value]
140
+ end
141
+ end
142
+ end
143
+ end
@@ -0,0 +1,115 @@
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 copies a given set of image creatives. This would typically be
22
+ # done to reuse creatives in a small business network. To determine which
23
+ # creatives exist, run get_all_creatives.rb.
24
+ #
25
+ # Tags: CreativeService.getCreativesByStatement, CreativeService.createCreatives
26
+
27
+ require 'dfp_api'
28
+
29
+ require 'base64'
30
+
31
+ API_VERSION = :v201302
32
+
33
+ def copy_image_creatives()
34
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
35
+ dfp = DfpApi::Api.new
36
+
37
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
38
+ # the configuration file or provide your own logger:
39
+ # dfp.logger = Logger.new('dfp_xml.log')
40
+
41
+ # Get the CreativeService.
42
+ creative_service = dfp.service(:CreativeService, API_VERSION)
43
+
44
+ # Create a list of creative ids to copy.
45
+ image_creative_ids = [
46
+ 'INSERT_IMAGE_CREATIVE_ID_HERE'.to_i,
47
+ 'INSERT_IMAGE_CREATIVE_ID_HERE'.to_i,
48
+ 'INSERT_IMAGE_CREATIVE_ID_HERE'.to_i,
49
+ 'INSERT_IMAGE_CREATIVE_ID_HERE'.to_i
50
+ ]
51
+
52
+ # Create the statement to filter image creatives by ID.
53
+ statement = {
54
+ :query => "WHERE id IN (%s) AND creativeType = :creative_type" %
55
+ image_creative_ids.join(', '),
56
+ :values => [
57
+ {:key => 'creative_type',
58
+ :value => {:value => 'ImageCreative', :xsi_type => 'TextValue'}}
59
+ ]
60
+ }
61
+
62
+ # Get creatives by statement.
63
+ page = creative_service.get_creatives_by_statement(statement)
64
+
65
+ if page[:results]
66
+ creatives = page[:results]
67
+
68
+ # Copy each local creative object and change its name.
69
+ new_creatives = creatives.map do |creative|
70
+ new_creative = creative.dup()
71
+ old_id = new_creative.delete(:id)
72
+ new_creative[:name] += " (Copy of %d)" % old_id
73
+ image_url = new_creative.delete(:image_url)
74
+ new_creative[:image_byte_array] =
75
+ Base64.encode64(AdsCommon::Http.get(image_url, dfp.config))
76
+ new_creative
77
+ end
78
+
79
+ # Create the creatives on the server.
80
+ return_creatives = creative_service.create_creatives(new_creatives)
81
+
82
+ # Display copied creatives.
83
+ if return_creatives
84
+ return_creatives.each_with_index do |creative, index|
85
+ puts "A creative with ID [%d] was copied to ID [%d], name: %s" %
86
+ [creatives[index][:id], creative[:id], creative[:name]]
87
+ end
88
+ else
89
+ raise 'No creatives were copied.'
90
+ end
91
+ else
92
+ puts 'No creatives found to copy.'
93
+ end
94
+ end
95
+
96
+ if __FILE__ == $0
97
+ begin
98
+ copy_image_creatives()
99
+
100
+ # HTTP errors.
101
+ rescue AdsCommon::Errors::HttpError => e
102
+ puts "HTTP Error: %s" % e
103
+
104
+ # API errors.
105
+ rescue DfpApi::Errors::ApiException => e
106
+ puts "Message: %s" % e.message
107
+ puts 'Errors:'
108
+ e.errors.each_with_index do |error, index|
109
+ puts "\tError [%d]:" % (index + 1)
110
+ error.each do |field, value|
111
+ puts "\t\t%s: %s" % [field, value]
112
+ end
113
+ end
114
+ end
115
+ end
@@ -0,0 +1,139 @@
1
+ #!/usr/bin/env ruby
2
+ # Encoding: utf-8
3
+ #
4
+ # Author:: api.dklimkin@gmail.com (Danial Klimkin)
5
+ #
6
+ # Copyright:: Copyright 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 creates a new template creative for a given advertiser. To
22
+ # determine which companies are advertisers, run get_companies_by_statement.rb.
23
+ # To determine which creatives already exist, run get_all_creatives.rb. To
24
+ # determine which creative templates run get_all_creative_templates.rb.
25
+ #
26
+ # Tags: CreativeService.createCreative
27
+
28
+ require 'base64'
29
+ require 'dfp_api'
30
+
31
+ API_VERSION = :v201302
32
+
33
+ def create_creative_from_template()
34
+ # Get DfpApi instance and load configuration from ~/dfp_api.yml.
35
+ dfp = DfpApi::Api.new
36
+
37
+ # To enable logging of SOAP requests, set the log_level value to 'DEBUG' in
38
+ # the configuration file or provide your own logger:
39
+ # dfp.logger = Logger.new('dfp_xml.log')
40
+
41
+ # Get the CreativeService.
42
+ creative_service = dfp.service(:CreativeService, API_VERSION)
43
+
44
+ # Set the ID of the advertiser (company) that all creatives will be assigned
45
+ # to.
46
+ advertiser_id = 'INSERT_ADVERTISER_COMPANY_ID_HERE'.to_i
47
+
48
+ # Use the image banner with optional third party tracking template.
49
+ creative_template_id = 10000680
50
+
51
+ # Create the local custom creative object.
52
+ creative = {
53
+ :xsi_type => 'TemplateCreative',
54
+ :name => 'Template creative',
55
+ :advertiser_id => advertiser_id,
56
+ :creative_template_id => creative_template_id,
57
+ :size => {:width => 300, :height => 250, :is_aspect_ratio => false}
58
+ }
59
+
60
+ # Prepare image data for asset value.
61
+ image_url =
62
+ 'http://www.google.com/intl/en/adwords/select/images/samples/inline.jpg'
63
+ image_data = AdsCommon::Http.get(image_url, dfp.config)
64
+ image_data_base64 = Base64.encode64(image_data)
65
+
66
+ # Create the asset variable value.
67
+ asset_variable_value = {
68
+ :xsi_type => 'AssetCreativeTemplateVariableValue',
69
+ :unique_name => 'Imagefile',
70
+ :asset_byte_array => image_data_base64,
71
+ # Filenames must be unique.
72
+ :file_name => "image%d.jpg" % Time.new.to_i
73
+ }
74
+
75
+ # Create the image width variable value.
76
+ image_width_variable_value = {
77
+ :xsi_type => 'LongCreativeTemplateVariableValue',
78
+ :unique_name => 'Imagewidth',
79
+ :value => 300
80
+ }
81
+
82
+ # Create the image height variable value.
83
+ image_height_variable_value = {
84
+ :xsi_type => 'LongCreativeTemplateVariableValue',
85
+ :unique_name => 'Imageheight',
86
+ :value => 250
87
+ }
88
+
89
+ # Create the URL variable value.
90
+ url_variable_value = {
91
+ :xsi_type => 'UrlCreativeTemplateVariableValue',
92
+ :unique_name => 'ClickthroughURL',
93
+ :value => 'www.google.com'
94
+ }
95
+
96
+ # Create the target window variable value.
97
+ target_window_variable_value = {
98
+ :xsi_type => 'StringCreativeTemplateVariableValue',
99
+ :unique_name => 'Targetwindow',
100
+ :value => '__blank'
101
+ }
102
+
103
+ creative[:creative_template_variable_values] = [asset_variable_value,
104
+ image_width_variable_value, image_height_variable_value,
105
+ url_variable_value, target_window_variable_value]
106
+
107
+ # Create the creatives on the server.
108
+ return_creative = creative_service.create_creative(creative)
109
+
110
+ if return_creative
111
+ puts(("Template creative with ID: %d, name: %s and type '%s' was " +
112
+ "created and can be previewed at: '%s'") %
113
+ [return_creative[:id], return_creative[:name],
114
+ return_creative[:creative_type], return_creative[:preview_url]])
115
+ else
116
+ raise 'No creatives were created.'
117
+ end
118
+ end
119
+
120
+ if __FILE__ == $0
121
+ begin
122
+ create_creative_from_template()
123
+
124
+ # HTTP errors.
125
+ rescue AdsCommon::Errors::HttpError => e
126
+ puts "HTTP Error: %s" % e
127
+
128
+ # API errors.
129
+ rescue DfpApi::Errors::ApiException => e
130
+ puts "Message: %s" % e.message
131
+ puts 'Errors:'
132
+ e.errors.each_with_index do |error, index|
133
+ puts "\tError [%d]:" % (index + 1)
134
+ error.each do |field, value|
135
+ puts "\t\t%s: %s" % [field, value]
136
+ end
137
+ end
138
+ end
139
+ end