google-dfp-api 0.6.2 → 0.6.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 (234) hide show
  1. data/ChangeLog +3 -0
  2. data/README +15 -6
  3. data/dfp_api.yml +6 -5
  4. data/examples/v201302/activity_group_service/get_all_activity_groups.rb +0 -0
  5. data/examples/v201302/activity_service/get_all_activities.rb +0 -0
  6. data/examples/v201302/contact_service/get_uninvited_contacts.rb +0 -0
  7. data/examples/v201302/report_service/display_report.rb +0 -0
  8. data/examples/v201302/report_service/run_reach_report.rb +1 -1
  9. data/examples/v201306/activity_group_service/create_activity_groups.rb +94 -0
  10. data/examples/v201306/activity_group_service/get_active_activity_groups.rb +100 -0
  11. data/examples/v201306/activity_group_service/get_all_activity_groups.rb +95 -0
  12. data/examples/v201306/activity_group_service/update_activity_groups.rb +87 -0
  13. data/examples/v201306/activity_service/create_activities.rb +91 -0
  14. data/examples/v201306/activity_service/get_active_activities.rb +107 -0
  15. data/examples/v201306/activity_service/get_all_activities.rb +144 -0
  16. data/examples/v201306/activity_service/update_activities.rb +85 -0
  17. data/examples/v201306/audience_segment_service/get_all_audience_segments.rb +93 -0
  18. data/examples/v201306/common/error_handling.rb +76 -0
  19. data/examples/v201306/common/oauth2_handling.rb +128 -0
  20. data/examples/v201306/common/oauth2_jwt_handling.rb +107 -0
  21. data/examples/v201306/company_service/create_companies.rb +81 -0
  22. data/examples/v201306/company_service/get_all_companies.rb +92 -0
  23. data/examples/v201306/company_service/get_companies_by_statement.rb +88 -0
  24. data/examples/v201306/company_service/get_company.rb +72 -0
  25. data/examples/v201306/company_service/update_companies.rb +102 -0
  26. data/examples/v201306/contact_service/create_contacts.rb +95 -0
  27. data/examples/v201306/contact_service/get_all_contacts.rb +92 -0
  28. data/examples/v201306/contact_service/get_uninvited_contacts.rb +102 -0
  29. data/examples/v201306/contact_service/update_contacts.rb +84 -0
  30. data/examples/v201306/content_service/get_all_content.rb +94 -0
  31. data/examples/v201306/content_service/get_content_by_category.rb +143 -0
  32. data/examples/v201306/creative_service/copy_image_creatives.rb +115 -0
  33. data/examples/v201306/creative_service/create_creative_from_template.rb +139 -0
  34. data/examples/v201306/creative_service/create_creatives.rb +112 -0
  35. data/examples/v201306/creative_service/create_custom_creative.rb +104 -0
  36. data/examples/v201306/creative_service/get_all_creatives.rb +93 -0
  37. data/examples/v201306/creative_service/get_creative.rb +72 -0
  38. data/examples/v201306/creative_service/get_creatives_by_statement.rb +87 -0
  39. data/examples/v201306/creative_service/update_creatives.rb +96 -0
  40. data/examples/v201306/creative_set_service/associate_creative_set_to_line_item.rb +77 -0
  41. data/examples/v201306/creative_set_service/create_creative_set.rb +83 -0
  42. data/examples/v201306/creative_set_service/get_all_creative_sets.rb +94 -0
  43. data/examples/v201306/creative_set_service/get_creative_sets_by_statement.rb +90 -0
  44. data/examples/v201306/creative_set_service/update_creative_sets.rb +85 -0
  45. data/examples/v201306/creative_template_service/get_all_creative_templates.rb +94 -0
  46. data/examples/v201306/creative_template_service/get_creative_template.rb +74 -0
  47. data/examples/v201306/creative_template_service/get_creative_templates_by_statement.rb +80 -0
  48. data/examples/v201306/creative_wrapper_service/create_creative_wrappers.rb +89 -0
  49. data/examples/v201306/creative_wrapper_service/deactivate_creative_wrapper.rb +102 -0
  50. data/examples/v201306/creative_wrapper_service/get_all_creative_wrappers.rb +94 -0
  51. data/examples/v201306/creative_wrapper_service/get_creative_wrappers_by_statement.rb +88 -0
  52. data/examples/v201306/creative_wrapper_service/update_creative_wrappers.rb +86 -0
  53. data/examples/v201306/custom_field_service/create_custom_field_options.rb +87 -0
  54. data/examples/v201306/custom_field_service/create_custom_fields.rb +86 -0
  55. data/examples/v201306/custom_field_service/deactivate_all_line_item_custom_fields.rb +112 -0
  56. data/examples/v201306/custom_field_service/get_all_custom_fields.rb +102 -0
  57. data/examples/v201306/custom_field_service/get_all_line_item_custom_fields.rb +86 -0
  58. data/examples/v201306/custom_field_service/set_line_item_custom_field_value.rb +135 -0
  59. data/examples/v201306/custom_field_service/update_custom_fields.rb +84 -0
  60. data/examples/v201306/custom_targeting_service/create_custom_targeting_keys_and_values.rb +140 -0
  61. data/examples/v201306/custom_targeting_service/delete_custom_targeting_keys.rb +121 -0
  62. data/examples/v201306/custom_targeting_service/delete_custom_targeting_values.rb +125 -0
  63. data/examples/v201306/custom_targeting_service/get_all_custom_targeting_keys_and_values.rb +148 -0
  64. data/examples/v201306/custom_targeting_service/get_custom_targeting_keys_by_statement.rb +92 -0
  65. data/examples/v201306/custom_targeting_service/get_custom_targeting_values_by_statement.rb +98 -0
  66. data/examples/v201306/custom_targeting_service/update_custom_targeting_keys.rb +94 -0
  67. data/examples/v201306/custom_targeting_service/update_custom_targeting_values.rb +106 -0
  68. data/examples/v201306/forecast_service/get_forecast.rb +107 -0
  69. data/examples/v201306/forecast_service/get_forecast_by_id.rb +80 -0
  70. data/examples/v201306/inventory_service/create_ad_units.rb +101 -0
  71. data/examples/v201306/inventory_service/create_mobile_ad_unit.rb +101 -0
  72. data/examples/v201306/inventory_service/create_video_ad_unit.rb +108 -0
  73. data/examples/v201306/inventory_service/deactivate_ad_units.rb +119 -0
  74. data/examples/v201306/inventory_service/get_ad_unit.rb +72 -0
  75. data/examples/v201306/inventory_service/get_ad_unit_sizes.rb +85 -0
  76. data/examples/v201306/inventory_service/get_ad_units_by_statement.rb +96 -0
  77. data/examples/v201306/inventory_service/get_all_ad_units.rb +93 -0
  78. data/examples/v201306/inventory_service/update_ad_units.rb +96 -0
  79. data/examples/v201306/label_service/create_labels.rb +83 -0
  80. data/examples/v201306/label_service/deactivate_labels.rb +118 -0
  81. data/examples/v201306/label_service/get_all_labels.rb +95 -0
  82. data/examples/v201306/label_service/get_label.rb +76 -0
  83. data/examples/v201306/label_service/get_labels_by_statement.rb +81 -0
  84. data/examples/v201306/label_service/update_labels.rb +102 -0
  85. data/examples/v201306/line_item_creative_association_service/create_licas.rb +94 -0
  86. data/examples/v201306/line_item_creative_association_service/deactivate_licas.rb +127 -0
  87. data/examples/v201306/line_item_creative_association_service/get_all_licas.rb +98 -0
  88. data/examples/v201306/line_item_creative_association_service/get_lica.rb +77 -0
  89. data/examples/v201306/line_item_creative_association_service/get_licas_by_statement.rb +91 -0
  90. data/examples/v201306/line_item_creative_association_service/update_licas.rb +91 -0
  91. data/examples/v201306/line_item_service/activate_line_items.rb +131 -0
  92. data/examples/v201306/line_item_service/create_line_items.rb +177 -0
  93. data/examples/v201306/line_item_service/create_mobile_line_item.rb +135 -0
  94. data/examples/v201306/line_item_service/create_video_line_item.rb +158 -0
  95. data/examples/v201306/line_item_service/get_all_line_items.rb +94 -0
  96. data/examples/v201306/line_item_service/get_line_item.rb +74 -0
  97. data/examples/v201306/line_item_service/get_line_items_by_statement.rb +93 -0
  98. data/examples/v201306/line_item_service/get_recently_updated_line_items.rb +98 -0
  99. data/examples/v201306/line_item_service/target_custom_criteria.rb +129 -0
  100. data/examples/v201306/line_item_service/update_line_items.rb +109 -0
  101. data/examples/v201306/network_service/get_all_networks.rb +74 -0
  102. data/examples/v201306/network_service/get_current_network.rb +66 -0
  103. data/examples/v201306/network_service/make_test_network.rb +79 -0
  104. data/examples/v201306/order_service/approve_orders.rb +122 -0
  105. data/examples/v201306/order_service/create_orders.rb +92 -0
  106. data/examples/v201306/order_service/get_all_orders.rb +93 -0
  107. data/examples/v201306/order_service/get_order.rb +74 -0
  108. data/examples/v201306/order_service/get_orders_by_statement.rb +90 -0
  109. data/examples/v201306/order_service/update_orders.rb +97 -0
  110. data/examples/v201306/placement_service/create_placements.rb +131 -0
  111. data/examples/v201306/placement_service/deactivate_placements.rb +118 -0
  112. data/examples/v201306/placement_service/get_all_placements.rb +93 -0
  113. data/examples/v201306/placement_service/get_placement.rb +74 -0
  114. data/examples/v201306/placement_service/get_placements_by_statement.rb +86 -0
  115. data/examples/v201306/placement_service/update_placements.rb +97 -0
  116. data/examples/v201306/publisher_query_language_service/get_all_cities.rb +104 -0
  117. data/examples/v201306/report_service/display_report.rb +81 -0
  118. data/examples/v201306/report_service/download_report.rb +81 -0
  119. data/examples/v201306/report_service/run_delivery_report.rb +103 -0
  120. data/examples/v201306/report_service/run_inventory_report.rb +96 -0
  121. data/examples/v201306/report_service/run_merged_delivery_report.rb +94 -0
  122. data/examples/v201306/report_service/run_reach_report.rb +87 -0
  123. data/examples/v201306/report_service/run_report_with_custom_fields.rb +135 -0
  124. data/examples/v201306/report_service/run_sales_report.rb +92 -0
  125. data/examples/v201306/suggested_ad_unit_service/approve_all_suggested_ad_units.rb +109 -0
  126. data/examples/v201306/suggested_ad_unit_service/get_all_suggested_ad_units.rb +96 -0
  127. data/examples/v201306/suggested_ad_unit_service/get_suggested_ad_unit.rb +75 -0
  128. data/examples/v201306/suggested_ad_unit_service/get_suggested_ad_units_by_statement.rb +92 -0
  129. data/examples/v201306/team_service/create_teams.rb +83 -0
  130. data/examples/v201306/team_service/get_all_teams.rb +92 -0
  131. data/examples/v201306/team_service/get_team.rb +74 -0
  132. data/examples/v201306/team_service/get_teams_by_statement.rb +78 -0
  133. data/examples/v201306/team_service/update_teams.rb +97 -0
  134. data/examples/v201306/user_service/create_users.rb +89 -0
  135. data/examples/v201306/user_service/deactivate_users.rb +97 -0
  136. data/examples/v201306/user_service/get_all_roles.rb +73 -0
  137. data/examples/v201306/user_service/get_all_users.rb +93 -0
  138. data/examples/v201306/user_service/get_current_user.rb +66 -0
  139. data/examples/v201306/user_service/get_user.rb +73 -0
  140. data/examples/v201306/user_service/get_users_by_statement.rb +79 -0
  141. data/examples/v201306/user_service/update_users.rb +89 -0
  142. data/examples/v201306/user_team_association_service/create_user_team_associations.rb +86 -0
  143. data/examples/v201306/user_team_association_service/delete_user_team_associations.rb +111 -0
  144. data/examples/v201306/user_team_association_service/get_all_user_team_associations.rb +94 -0
  145. data/examples/v201306/user_team_association_service/get_user_team_association.rb +76 -0
  146. data/examples/v201306/user_team_association_service/get_user_team_associations_by_statement.rb +94 -0
  147. data/examples/v201306/user_team_association_service/update_user_team_associations.rb +102 -0
  148. data/lib/dfp_api.rb +3 -3
  149. data/lib/dfp_api/api_config.rb +24 -4
  150. data/lib/dfp_api/v201306/activity_group_service.rb +54 -0
  151. data/lib/dfp_api/v201306/activity_group_service_registry.rb +46 -0
  152. data/lib/dfp_api/v201306/activity_service.rb +54 -0
  153. data/lib/dfp_api/v201306/activity_service_registry.rb +46 -0
  154. data/lib/dfp_api/v201306/ad_rule_service.rb +58 -0
  155. data/lib/dfp_api/v201306/ad_rule_service_registry.rb +46 -0
  156. data/lib/dfp_api/v201306/audience_segment_service.rb +34 -0
  157. data/lib/dfp_api/v201306/audience_segment_service_registry.rb +46 -0
  158. data/lib/dfp_api/v201306/base_rate_service.rb +58 -0
  159. data/lib/dfp_api/v201306/base_rate_service_registry.rb +46 -0
  160. data/lib/dfp_api/v201306/company_service.rb +54 -0
  161. data/lib/dfp_api/v201306/company_service_registry.rb +46 -0
  162. data/lib/dfp_api/v201306/contact_service.rb +54 -0
  163. data/lib/dfp_api/v201306/contact_service_registry.rb +46 -0
  164. data/lib/dfp_api/v201306/content_bundle_service.rb +58 -0
  165. data/lib/dfp_api/v201306/content_bundle_service_registry.rb +46 -0
  166. data/lib/dfp_api/v201306/content_service.rb +38 -0
  167. data/lib/dfp_api/v201306/content_service_registry.rb +46 -0
  168. data/lib/dfp_api/v201306/creative_service.rb +54 -0
  169. data/lib/dfp_api/v201306/creative_service_registry.rb +46 -0
  170. data/lib/dfp_api/v201306/creative_set_service.rb +46 -0
  171. data/lib/dfp_api/v201306/creative_set_service_registry.rb +46 -0
  172. data/lib/dfp_api/v201306/creative_template_service.rb +38 -0
  173. data/lib/dfp_api/v201306/creative_template_service_registry.rb +46 -0
  174. data/lib/dfp_api/v201306/creative_wrapper_service.rb +58 -0
  175. data/lib/dfp_api/v201306/creative_wrapper_service_registry.rb +46 -0
  176. data/lib/dfp_api/v201306/custom_field_service.rb +78 -0
  177. data/lib/dfp_api/v201306/custom_field_service_registry.rb +46 -0
  178. data/lib/dfp_api/v201306/custom_targeting_service.rb +62 -0
  179. data/lib/dfp_api/v201306/custom_targeting_service_registry.rb +46 -0
  180. data/lib/dfp_api/v201306/forecast_service.rb +38 -0
  181. data/lib/dfp_api/v201306/forecast_service_registry.rb +46 -0
  182. data/lib/dfp_api/v201306/inventory_service.rb +62 -0
  183. data/lib/dfp_api/v201306/inventory_service_registry.rb +46 -0
  184. data/lib/dfp_api/v201306/label_service.rb +58 -0
  185. data/lib/dfp_api/v201306/label_service_registry.rb +46 -0
  186. data/lib/dfp_api/v201306/line_item_creative_association_service.rb +62 -0
  187. data/lib/dfp_api/v201306/line_item_creative_association_service_registry.rb +46 -0
  188. data/lib/dfp_api/v201306/line_item_service.rb +58 -0
  189. data/lib/dfp_api/v201306/line_item_service_registry.rb +46 -0
  190. data/lib/dfp_api/v201306/line_item_template_service.rb +34 -0
  191. data/lib/dfp_api/v201306/line_item_template_service_registry.rb +46 -0
  192. data/lib/dfp_api/v201306/network_service.rb +46 -0
  193. data/lib/dfp_api/v201306/network_service_registry.rb +46 -0
  194. data/lib/dfp_api/v201306/order_service.rb +58 -0
  195. data/lib/dfp_api/v201306/order_service_registry.rb +46 -0
  196. data/lib/dfp_api/v201306/placement_service.rb +58 -0
  197. data/lib/dfp_api/v201306/placement_service_registry.rb +46 -0
  198. data/lib/dfp_api/v201306/product_service.rb +50 -0
  199. data/lib/dfp_api/v201306/product_service_registry.rb +46 -0
  200. data/lib/dfp_api/v201306/product_template_service.rb +58 -0
  201. data/lib/dfp_api/v201306/product_template_service_registry.rb +46 -0
  202. data/lib/dfp_api/v201306/proposal_line_item_service.rb +58 -0
  203. data/lib/dfp_api/v201306/proposal_line_item_service_registry.rb +46 -0
  204. data/lib/dfp_api/v201306/proposal_service.rb +58 -0
  205. data/lib/dfp_api/v201306/proposal_service_registry.rb +46 -0
  206. data/lib/dfp_api/v201306/publisher_query_language_service.rb +34 -0
  207. data/lib/dfp_api/v201306/publisher_query_language_service_registry.rb +46 -0
  208. data/lib/dfp_api/v201306/rate_card_customization_service.rb +58 -0
  209. data/lib/dfp_api/v201306/rate_card_customization_service_registry.rb +46 -0
  210. data/lib/dfp_api/v201306/rate_card_service.rb +58 -0
  211. data/lib/dfp_api/v201306/rate_card_service_registry.rb +46 -0
  212. data/lib/dfp_api/v201306/reconciliation_order_report_service.rb +42 -0
  213. data/lib/dfp_api/v201306/reconciliation_order_report_service_registry.rb +46 -0
  214. data/lib/dfp_api/v201306/reconciliation_report_row_service.rb +38 -0
  215. data/lib/dfp_api/v201306/reconciliation_report_row_service_registry.rb +46 -0
  216. data/lib/dfp_api/v201306/reconciliation_report_service.rb +46 -0
  217. data/lib/dfp_api/v201306/reconciliation_report_service_registry.rb +46 -0
  218. data/lib/dfp_api/v201306/report_service.rb +46 -0
  219. data/lib/dfp_api/v201306/report_service_registry.rb +46 -0
  220. data/lib/dfp_api/v201306/suggested_ad_unit_service.rb +42 -0
  221. data/lib/dfp_api/v201306/suggested_ad_unit_service_registry.rb +46 -0
  222. data/lib/dfp_api/v201306/team_service.rb +54 -0
  223. data/lib/dfp_api/v201306/team_service_registry.rb +46 -0
  224. data/lib/dfp_api/v201306/user_service.rb +66 -0
  225. data/lib/dfp_api/v201306/user_service_registry.rb +46 -0
  226. data/lib/dfp_api/v201306/user_team_association_service.rb +58 -0
  227. data/lib/dfp_api/v201306/user_team_association_service_registry.rb +46 -0
  228. data/lib/dfp_api/v201306/workflow_action_service.rb +38 -0
  229. data/lib/dfp_api/v201306/workflow_action_service_registry.rb +46 -0
  230. data/lib/dfp_api/version.rb +1 -1
  231. data/test/bugs/test_issue_00000016.rb +3 -3
  232. data/test/dfp_api/test_dfp_api.rb +30 -6
  233. data/test/suite_unittests.rb +6 -6
  234. metadata +1218 -999
@@ -0,0 +1,107 @@
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 a forecast for a prospective line item. To determine which
22
+ # placements exist, run get_all_placements.rb.
23
+ #
24
+ # Tags: ForecastService.getForecast
25
+
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201306
29
+
30
+ def get_forecast()
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 CreativeService.
39
+ forecast_service = dfp.service(:ForecastService, API_VERSION)
40
+
41
+ # Set the placement that the prospective line item will target.
42
+ targeted_placement_ids = ['INSERT_PLACEMENT_ID_HERE'.to_i]
43
+
44
+ # Create targeting.
45
+ targeting = {
46
+ :inventory_targeting =>
47
+ {:targeted_placement_ids => targeted_placement_ids}
48
+ }
49
+
50
+ # Create the creative placeholder.
51
+ creative_placeholder = {
52
+ :size => {:width => 300, :height => 250, :is_aspect_ratio => false}
53
+ }
54
+
55
+ # Create prospective line item.
56
+ line_item = {
57
+ :line_item_type => 'SPONSORSHIP',
58
+ :targeting => targeting,
59
+ # Set the size of creatives that can be associated with this line item.
60
+ :creative_placeholders => [creative_placeholder],
61
+ # Set the line item's time to be now until the projected end date time.
62
+ :start_date_time_type => 'IMMEDIATELY',
63
+ :end_date_time => Time.utc(2014, 01, 01),
64
+ # Set the line item to use 50% of the impressions.
65
+ :unit_type => 'IMPRESSIONS',
66
+ :units_bought => 50,
67
+ # Set the cost type to match the unit type.
68
+ :cost_type => 'CPM'
69
+ }
70
+
71
+ # Get forecast for the line item.
72
+ forecast = forecast_service.get_forecast(line_item)
73
+
74
+ if forecast
75
+ # Display results.
76
+ matched = forecast[:matched_units]
77
+ available_percent = forecast[:available_units] * 100.0 / matched
78
+ unit_type = forecast[:unit_type].to_s.downcase
79
+ puts "%.2f %s matched." % [matched, unit_type]
80
+ puts "%.2f%% %s available." % [available_percent, unit_type]
81
+ if forecast[:possible_units]
82
+ possible_percent = forecast[:possible_units] * 100.0 / matched
83
+ puts "%.2f%% %s possible." % [possible_percent, unit_type]
84
+ end
85
+ end
86
+ end
87
+
88
+ if __FILE__ == $0
89
+ begin
90
+ get_forecast()
91
+
92
+ # HTTP errors.
93
+ rescue AdsCommon::Errors::HttpError => e
94
+ puts "HTTP Error: %s" % e
95
+
96
+ # API errors.
97
+ rescue DfpApi::Errors::ApiException => e
98
+ puts "Message: %s" % e.message
99
+ puts 'Errors:'
100
+ e.errors.each_with_index do |error, index|
101
+ puts "\tError [%d]:" % (index + 1)
102
+ error.each do |field, value|
103
+ puts "\t\t%s: %s" % [field, value]
104
+ end
105
+ end
106
+ end
107
+ end
@@ -0,0 +1,80 @@
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 a forecast for an existing line item. To determine which
22
+ # line items exist, run get_all_line_items.rb.
23
+ #
24
+ # Tags: ForecastService.getForecastById
25
+
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201306
29
+
30
+ def get_forecast_by_id()
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 CreativeService.
39
+ forecast_service = dfp.service(:ForecastService, API_VERSION)
40
+
41
+ # Set the line item to get a forecast for.
42
+ line_item_id = 'INSERT_LINE_ITEM_ID_HERE'.to_i
43
+
44
+ # Get forecast for line item.
45
+ forecast = forecast_service.get_forecast_by_id(line_item_id)
46
+
47
+ if forecast
48
+ # Display results.
49
+ matched = forecast[:matched_units]
50
+ available_percent = forecast[:available_units] * 100.0 / matched
51
+ unit_type = forecast[:unit_type].to_s.downcase
52
+ puts "%.2f %s matched." % [matched, unit_type]
53
+ puts "%.2f%% %s available." % [available_percent, unit_type]
54
+ if forecast[:possible_units]
55
+ possible_percent = forecast[:possible_units] * 100.0 / matched
56
+ puts "%.2f%% %s possible." % [possible_percent, unit_type]
57
+ end
58
+ end
59
+ end
60
+
61
+ if __FILE__ == $0
62
+ begin
63
+ get_forecast_by_id()
64
+
65
+ # HTTP errors.
66
+ rescue AdsCommon::Errors::HttpError => e
67
+ puts "HTTP Error: %s" % e
68
+
69
+ # API errors.
70
+ rescue DfpApi::Errors::ApiException => e
71
+ puts "Message: %s" % e.message
72
+ puts 'Errors:'
73
+ e.errors.each_with_index do |error, index|
74
+ puts "\tError [%d]:" % (index + 1)
75
+ error.each do |field, value|
76
+ puts "\t\t%s: %s" % [field, value]
77
+ end
78
+ end
79
+ end
80
+ end
@@ -0,0 +1,101 @@
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 new ad units under a the effective root ad unit. To
22
+ # determine which ad units exist, run get_inventory_tree.rb or
23
+ # get_all_ad_units.rb.
24
+ #
25
+ # Tags: InventoryService.createAdUnits, NetworkService.getCurrentNetwork
26
+
27
+ require 'dfp_api'
28
+
29
+ API_VERSION = :v201306
30
+ # Number of ad units to create.
31
+ ITEM_COUNT = 5
32
+
33
+ def create_ad_units()
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 InventoryService.
42
+ inventory_service = dfp.service(:InventoryService, API_VERSION)
43
+
44
+ # Get the NetworkService.
45
+ network_service = dfp.service(:NetworkService, API_VERSION)
46
+
47
+ # Get the effective root ad unit ID of the network.
48
+ effective_root_ad_unit_id =
49
+ network_service.get_current_network[:effective_root_ad_unit_id]
50
+
51
+ puts "Using effective root ad unit: %d" % effective_root_ad_unit_id
52
+
53
+ # Create the creative placeholder.
54
+ creative_placeholder = {
55
+ :size => {:width => 300, :height => 250, :is_aspect_ratio => false},
56
+ :environment_type => 'BROWSER'
57
+ }
58
+
59
+ # Create an array to store local ad unit objects.
60
+ ad_units = (1..ITEM_COUNT).map do |index|
61
+ {:name => "Ad_Unit_%d" % index,
62
+ :parent_id => effective_root_ad_unit_id,
63
+ :description => 'Ad unit description.',
64
+ :target_window => 'BLANK',
65
+ # Set the size of possible creatives that can match this ad unit.
66
+ :ad_unit_sizes => [creative_placeholder]}
67
+ end
68
+
69
+ # Create the ad units on the server.
70
+ return_ad_units = inventory_service.create_ad_units(ad_units)
71
+
72
+ if return_ad_units
73
+ return_ad_units.each do |ad_unit|
74
+ puts "Ad unit with ID: %d, name: %s and status: %s was created." %
75
+ [ad_unit[:id], ad_unit[:name], ad_unit[:status]]
76
+ end
77
+ else
78
+ raise 'No ad units were created.'
79
+ end
80
+ end
81
+
82
+ if __FILE__ == $0
83
+ begin
84
+ create_ad_units()
85
+
86
+ # HTTP errors.
87
+ rescue AdsCommon::Errors::HttpError => e
88
+ puts "HTTP Error: %s" % e
89
+
90
+ # API errors.
91
+ rescue DfpApi::Errors::ApiException => e
92
+ puts "Message: %s" % e.message
93
+ puts 'Errors:'
94
+ e.errors.each_with_index do |error, index|
95
+ puts "\tError [%d]:" % (index + 1)
96
+ error.each do |field, value|
97
+ puts "\t\t%s: %s" % [field, value]
98
+ end
99
+ end
100
+ end
101
+ end
@@ -0,0 +1,101 @@
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 mobile ad unit under the effective root ad unit.
22
+ # To determine which ad units exist, run get_inventory_tree.rb or
23
+ # get_all_ad_units.rb.
24
+ #
25
+ # Mobile features need to be enabled on your account to use mobile targeting.
26
+ #
27
+ # Tags: InventoryService.createAdUnits, NetworkService.getCurrentNetwork
28
+
29
+ require 'dfp_api'
30
+
31
+ API_VERSION = :v201306
32
+
33
+ def create_mobile_ad_unit()
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 InventoryService.
42
+ inventory_service = dfp.service(:InventoryService, API_VERSION)
43
+
44
+ # Get the NetworkService.
45
+ network_service = dfp.service(:NetworkService, API_VERSION)
46
+
47
+ # Get the effective root ad unit ID of the network.
48
+ effective_root_ad_unit_id =
49
+ network_service.get_current_network[:effective_root_ad_unit_id]
50
+
51
+ puts "Using effective root ad unit: %s" % effective_root_ad_unit_id.to_s
52
+
53
+ # Create ad unit size.
54
+ ad_unit_size = {
55
+ :size => {:width => 400, :height => 300, :is_aspect_ratio => false},
56
+ :environment_type => 'BROWSER'
57
+ }
58
+
59
+ # Create local ad unit object.
60
+ ad_unit = {
61
+ :name => "Mobile_Ad_Unit_%d" % (Time.new.to_f * 1000).to_i,
62
+ :parent_id => effective_root_ad_unit_id,
63
+ :description => 'Mobile Ad unit description',
64
+ :target_window => 'BLANK',
65
+ :target_platform => 'MOBILE',
66
+ :mobile_platform => 'APPLICATION',
67
+ # Set the size of possible creatives that can match this ad unit.
68
+ :ad_unit_sizes => [ad_unit_size]
69
+ }
70
+
71
+ # Create the ad unit on the server.
72
+ return_ad_unit = inventory_service.create_ad_unit(ad_unit)
73
+
74
+ if return_ad_unit
75
+ puts "Ad unit with ID: %d, name: %s and status: %s was created." %
76
+ [return_ad_unit[:id], return_ad_unit[:name], return_ad_unit[:status]]
77
+ else
78
+ raise 'No ad units were created.'
79
+ end
80
+ end
81
+
82
+ if __FILE__ == $0
83
+ begin
84
+ create_mobile_ad_unit()
85
+
86
+ # HTTP errors.
87
+ rescue AdsCommon::Errors::HttpError => e
88
+ puts "HTTP Error: %s" % e
89
+
90
+ # API errors.
91
+ rescue DfpApi::Errors::ApiException => e
92
+ puts "Message: %s" % e.message
93
+ puts 'Errors:'
94
+ e.errors.each_with_index do |error, index|
95
+ puts "\tError [%d]:" % (index + 1)
96
+ error.each do |field, value|
97
+ puts "\t\t%s: %s" % [field, value]
98
+ end
99
+ end
100
+ end
101
+ end
@@ -0,0 +1,108 @@
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 video ad unit under a the effective root ad unit.
22
+ # To determine which ad units exist, run get_inventory_tree.rb or
23
+ # get_all_ad_units.rb.
24
+ #
25
+ # This feature is only available to DFP premium solution networks.
26
+ #
27
+ # Tags: InventoryService.createAdUnits, NetworkService.getCurrentNetwork
28
+
29
+ require 'dfp_api'
30
+
31
+ API_VERSION = :v201306
32
+
33
+ def create_video_ad_unit()
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 InventoryService.
42
+ inventory_service = dfp.service(:InventoryService, API_VERSION)
43
+
44
+ # Get the NetworkService.
45
+ network_service = dfp.service(:NetworkService, API_VERSION)
46
+
47
+ # Get the effective root ad unit ID of the network.
48
+ effective_root_ad_unit_id =
49
+ network_service.get_current_network[:effective_root_ad_unit_id]
50
+
51
+ puts "Using effective root ad unit: %s" % effective_root_ad_unit_id.to_s
52
+
53
+ # Create master ad unit size.
54
+ master_ad_unit_size = {
55
+ :size => {:width => 400, :height => 300, :is_aspect_ratio => false},
56
+ :environment_type => 'VIDEO_PLAYER',
57
+ # Add companions to master ad unit size.
58
+ :companions => [
59
+ {:size => {:width => 300, :height => 250, :is_aspect_ratio => false},
60
+ :environment_type => 'BROWSER'},
61
+ {:size => {:width => 728, :height => 90, :is_aspect_ratio => false},
62
+ :environment_type => 'BROWSER'}
63
+ ]
64
+ }
65
+
66
+ # Create local ad unit object.
67
+ ad_unit = {
68
+ :name => "Video_Ad_Unit_%d" % (Time.new.to_f * 1000).to_i,
69
+ :parent_id => effective_root_ad_unit_id,
70
+ :description => 'Video Ad unit description',
71
+ :target_window => 'BLANK',
72
+ :explicitly_targeted => true,
73
+ :target_platform => 'WEB',
74
+ # Set the size of possible creatives that can match this ad unit.
75
+ :ad_unit_sizes => [master_ad_unit_size]
76
+ }
77
+
78
+ # Create the ad unit on the server.
79
+ return_ad_unit = inventory_service.create_ad_unit(ad_unit)
80
+
81
+ if return_ad_unit
82
+ puts "Ad unit with ID: %d, name: %s and status: %s was created." %
83
+ [return_ad_unit[:id], return_ad_unit[:name], return_ad_unit[:status]]
84
+ else
85
+ raise 'No ad units were created.'
86
+ end
87
+ end
88
+
89
+ if __FILE__ == $0
90
+ begin
91
+ create_video_ad_unit()
92
+
93
+ # HTTP errors.
94
+ rescue AdsCommon::Errors::HttpError => e
95
+ puts "HTTP Error: %s" % e
96
+
97
+ # API errors.
98
+ rescue DfpApi::Errors::ApiException => e
99
+ puts "Message: %s" % e.message
100
+ puts 'Errors:'
101
+ e.errors.each_with_index do |error, index|
102
+ puts "\tError [%d]:" % (index + 1)
103
+ error.each do |field, value|
104
+ puts "\t\t%s: %s" % [field, value]
105
+ end
106
+ end
107
+ end
108
+ end