google-dfp-api 0.2.0

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 (106) hide show
  1. data/COPYING +201 -0
  2. data/ChangeLog +10 -0
  3. data/README +210 -0
  4. data/Rakefile +83 -0
  5. data/examples/v201101/common/error_handling.rb +76 -0
  6. data/examples/v201101/company_service/create_companies.rb +82 -0
  7. data/examples/v201101/company_service/get_all_companies.rb +92 -0
  8. data/examples/v201101/company_service/get_companies_by_statement.rb +88 -0
  9. data/examples/v201101/company_service/get_company.rb +72 -0
  10. data/examples/v201101/company_service/update_companies.rb +95 -0
  11. data/examples/v201101/creative_service/copy_image_creatives.rb +117 -0
  12. data/examples/v201101/creative_service/create_creatives.rb +109 -0
  13. data/examples/v201101/creative_service/get_all_creatives.rb +93 -0
  14. data/examples/v201101/creative_service/get_creative.rb +72 -0
  15. data/examples/v201101/creative_service/get_creatives_by_statement.rb +87 -0
  16. data/examples/v201101/creative_service/update_creatives.rb +98 -0
  17. data/examples/v201101/custom_targeting_service/create_custom_targeting_keys_and_values.rb +118 -0
  18. data/examples/v201101/custom_targeting_service/delete_custom_targeting_keys.rb +121 -0
  19. data/examples/v201101/custom_targeting_service/delete_custom_targeting_values.rb +125 -0
  20. data/examples/v201101/custom_targeting_service/get_all_custom_targeting_keys_and_values.rb +148 -0
  21. data/examples/v201101/custom_targeting_service/get_custom_targeting_keys_by_statement.rb +92 -0
  22. data/examples/v201101/custom_targeting_service/get_custom_targeting_values_by_statement.rb +98 -0
  23. data/examples/v201101/custom_targeting_service/update_custom_targeting_keys.rb +94 -0
  24. data/examples/v201101/custom_targeting_service/update_custom_targeting_values.rb +106 -0
  25. data/examples/v201101/forecast_service/get_forecast.rb +103 -0
  26. data/examples/v201101/forecast_service/get_forecast_by_id.rb +80 -0
  27. data/examples/v201101/inventory_service/create_ad_units.rb +98 -0
  28. data/examples/v201101/inventory_service/deactivate_ad_units.rb +119 -0
  29. data/examples/v201101/inventory_service/get_ad_unit.rb +72 -0
  30. data/examples/v201101/inventory_service/get_ad_units_by_statement.rb +96 -0
  31. data/examples/v201101/inventory_service/get_all_ad_units.rb +93 -0
  32. data/examples/v201101/inventory_service/update_ad_units.rb +94 -0
  33. data/examples/v201101/line_item_creative_association_service/create_licas.rb +94 -0
  34. data/examples/v201101/line_item_creative_association_service/deactivate_licas.rb +127 -0
  35. data/examples/v201101/line_item_creative_association_service/get_all_licas.rb +95 -0
  36. data/examples/v201101/line_item_creative_association_service/get_lica.rb +77 -0
  37. data/examples/v201101/line_item_creative_association_service/get_licas_by_statement.rb +91 -0
  38. data/examples/v201101/line_item_creative_association_service/update_licas.rb +92 -0
  39. data/examples/v201101/line_item_service/activate_line_items.rb +131 -0
  40. data/examples/v201101/line_item_service/create_line_items.rb +141 -0
  41. data/examples/v201101/line_item_service/get_all_line_items.rb +94 -0
  42. data/examples/v201101/line_item_service/get_line_item.rb +74 -0
  43. data/examples/v201101/line_item_service/get_line_items_by_statement.rb +89 -0
  44. data/examples/v201101/line_item_service/target_custom_criteria.rb +135 -0
  45. data/examples/v201101/line_item_service/update_line_items.rb +110 -0
  46. data/examples/v201101/network_service/get_all_networks.rb +74 -0
  47. data/examples/v201101/network_service/get_current_network.rb +66 -0
  48. data/examples/v201101/order_service/approve_orders.rb +116 -0
  49. data/examples/v201101/order_service/create_orders.rb +93 -0
  50. data/examples/v201101/order_service/get_all_orders.rb +93 -0
  51. data/examples/v201101/order_service/get_order.rb +74 -0
  52. data/examples/v201101/order_service/get_orders_by_statement.rb +90 -0
  53. data/examples/v201101/order_service/update_orders.rb +95 -0
  54. data/examples/v201101/placement_service/create_placements.rb +128 -0
  55. data/examples/v201101/placement_service/deactivate_placements.rb +118 -0
  56. data/examples/v201101/placement_service/get_all_placements.rb +93 -0
  57. data/examples/v201101/placement_service/get_placement.rb +74 -0
  58. data/examples/v201101/placement_service/get_placements_by_statement.rb +86 -0
  59. data/examples/v201101/placement_service/update_placements.rb +96 -0
  60. data/examples/v201101/publisher_query_language_service/get_all_cities.rb +85 -0
  61. data/examples/v201101/publisher_query_language_service/get_all_countries.rb +85 -0
  62. data/examples/v201101/publisher_query_language_service/get_all_metros.rb +85 -0
  63. data/examples/v201101/publisher_query_language_service/get_all_regions.rb +85 -0
  64. data/examples/v201101/report_service/download_report.rb +81 -0
  65. data/examples/v201101/report_service/run_delivery_report.rb +89 -0
  66. data/examples/v201101/report_service/run_inventory_report.rb +90 -0
  67. data/examples/v201101/report_service/run_sales_report.rb +89 -0
  68. data/examples/v201101/user_service/create_users.rb +89 -0
  69. data/examples/v201101/user_service/deactivate_users.rb +99 -0
  70. data/examples/v201101/user_service/get_all_roles.rb +73 -0
  71. data/examples/v201101/user_service/get_all_users.rb +92 -0
  72. data/examples/v201101/user_service/get_user.rb +73 -0
  73. data/examples/v201101/user_service/get_users_by_statement.rb +79 -0
  74. data/examples/v201101/user_service/update_users.rb +89 -0
  75. data/lib/dfp_api.rb +142 -0
  76. data/lib/dfp_api/api_config.rb +126 -0
  77. data/lib/dfp_api/credential_handler.rb +60 -0
  78. data/lib/dfp_api/errors.rb +59 -0
  79. data/lib/dfp_api/extensions.rb +54 -0
  80. data/lib/dfp_api/v201101/company_service.rb +52 -0
  81. data/lib/dfp_api/v201101/company_service_registry.rb +37 -0
  82. data/lib/dfp_api/v201101/creative_service.rb +52 -0
  83. data/lib/dfp_api/v201101/creative_service_registry.rb +37 -0
  84. data/lib/dfp_api/v201101/custom_targeting_service.rb +60 -0
  85. data/lib/dfp_api/v201101/custom_targeting_service_registry.rb +37 -0
  86. data/lib/dfp_api/v201101/forecast_service.rb +36 -0
  87. data/lib/dfp_api/v201101/forecast_service_registry.rb +37 -0
  88. data/lib/dfp_api/v201101/inventory_service.rb +56 -0
  89. data/lib/dfp_api/v201101/inventory_service_registry.rb +37 -0
  90. data/lib/dfp_api/v201101/line_item_creative_association_service.rb +56 -0
  91. data/lib/dfp_api/v201101/line_item_creative_association_service_registry.rb +37 -0
  92. data/lib/dfp_api/v201101/line_item_service.rb +56 -0
  93. data/lib/dfp_api/v201101/line_item_service_registry.rb +37 -0
  94. data/lib/dfp_api/v201101/network_service.rb +40 -0
  95. data/lib/dfp_api/v201101/network_service_registry.rb +37 -0
  96. data/lib/dfp_api/v201101/order_service.rb +56 -0
  97. data/lib/dfp_api/v201101/order_service_registry.rb +37 -0
  98. data/lib/dfp_api/v201101/placement_service.rb +56 -0
  99. data/lib/dfp_api/v201101/placement_service_registry.rb +37 -0
  100. data/lib/dfp_api/v201101/publisher_query_language_service.rb +32 -0
  101. data/lib/dfp_api/v201101/publisher_query_language_service_registry.rb +37 -0
  102. data/lib/dfp_api/v201101/report_service.rb +40 -0
  103. data/lib/dfp_api/v201101/report_service_registry.rb +37 -0
  104. data/lib/dfp_api/v201101/user_service.rb +60 -0
  105. data/lib/dfp_api/v201101/user_service_registry.rb +37 -0
  106. metadata +204 -0
@@ -0,0 +1,103 @@
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 forecast for a prospective line item. To determine which
21
+ # placements exist, run get_all_placements.rb.
22
+ #
23
+ # Tags: ForecastService.getForecast
24
+
25
+ require 'rubygems'
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201101
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 prospective line item.
51
+ line_item = {
52
+ :line_item_type => 'SPONSORSHIP',
53
+ :targeting => targeting,
54
+ # Set the size of creatives that can be associated with this line item.
55
+ :creative_sizes =>
56
+ {:width => 300, :height => 250, :is_aspect_ratio => false},
57
+ # Set the line item's time to be now until the projected end date time.
58
+ :start_date_time_type => 'IMMEDIATELY',
59
+ :end_date_time => Time.utc(2012, 01, 01),
60
+ # Set the line item to use 50% of the impressions.
61
+ :unit_type => 'IMPRESSIONS',
62
+ :units_bought => 50,
63
+ # Set the cost type to match the unit type.
64
+ :cost_type => 'CPM'
65
+ }
66
+
67
+ # Get forecast for the line item.
68
+ forecast = forecast_service.get_forecast(line_item)
69
+
70
+ if forecast
71
+ # Display results.
72
+ matched = forecast[:matched_units]
73
+ available_percent = forecast[:available_units] * 100.0 / matched
74
+ unit_type = forecast[:unit_type].to_s.downcase
75
+ puts "%.2f %s matched." % [matched, unit_type]
76
+ puts "%.2f%% %s available." % [available_percent, unit_type]
77
+ if forecast[:possible_units]
78
+ possible_percent = forecast[:possible_units] * 100.0 / matched
79
+ puts "%.2f%% %s possible." % [possible_percent, unit_type]
80
+ end
81
+ end
82
+ end
83
+
84
+ if __FILE__ == $0
85
+ begin
86
+ get_forecast()
87
+
88
+ # HTTP errors.
89
+ rescue AdsCommon::Errors::HttpError => e
90
+ puts "HTTP Error: %s" % e
91
+
92
+ # API errors.
93
+ rescue DfpApi::Errors::ApiException => e
94
+ puts "Message: %s" % e.message
95
+ puts 'Errors:'
96
+ e.errors.each_with_index do |error, index|
97
+ puts "\tError [%d]:" % (index + 1)
98
+ error.each do |field, value|
99
+ puts "\t\t%s: %s" % [field, value]
100
+ end
101
+ end
102
+ end
103
+ end
@@ -0,0 +1,80 @@
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 forecast for an existing line item. To determine which
21
+ # line items exist, run get_all_line_items.rb.
22
+ #
23
+ # Tags: ForecastService.getForecastById
24
+
25
+ require 'rubygems'
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201101
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,98 @@
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 ad units under a the effective root ad unit. To
21
+ # determine which ad units exist, run get_inventory_tree.rb or
22
+ # get_all_ad_units.rb.
23
+ #
24
+ # Tags: InventoryService.createAdUnits
25
+
26
+ require 'rubygems'
27
+ require 'dfp_api'
28
+
29
+ API_VERSION = :v201101
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 an array to store local ad unit objects.
54
+ ad_units = Array.new
55
+ ITEM_COUNT.times do |index|
56
+ ad_units << {
57
+ :name => "Ad_Unit_%d" % index,
58
+ :parent_id => effective_root_ad_unit_id,
59
+ :description => 'Ad unit description.',
60
+ :target_window => 'BLANK',
61
+ # Set the size of possible creatives that can match this ad unit.
62
+ :sizes => [{:width => 300, :height => 250, :is_aspect_ratio => false}]
63
+ }
64
+ end
65
+
66
+ # Create the ad units on the server.
67
+ return_ad_units = inventory_service.create_ad_units(ad_units)
68
+
69
+ if return_ad_units
70
+ return_ad_units.each do |ad_unit|
71
+ puts "Ad unit with ID: %d, name: %s and status: %s was created." %
72
+ [ad_unit[:id], ad_unit[:name], ad_unit[:status]]
73
+ end
74
+ else
75
+ raise 'No ad units were created.'
76
+ end
77
+ end
78
+
79
+ if __FILE__ == $0
80
+ begin
81
+ create_ad_units()
82
+
83
+ # HTTP errors.
84
+ rescue AdsCommon::Errors::HttpError => e
85
+ puts "HTTP Error: %s" % e
86
+
87
+ # API errors.
88
+ rescue DfpApi::Errors::ApiException => e
89
+ puts "Message: %s" % e.message
90
+ puts 'Errors:'
91
+ e.errors.each_with_index do |error, index|
92
+ puts "\tError [%d]:" % (index + 1)
93
+ error.each do |field, value|
94
+ puts "\t\t%s: %s" % [field, value]
95
+ end
96
+ end
97
+ end
98
+ end
@@ -0,0 +1,119 @@
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 deactivates all active ad units. To determine which ad units
21
+ # exist, run get_all_ad_units.rb or get_inventory_tree.rb.
22
+ #
23
+ # Tags: InventoryService.getLineItemsByStatement,
24
+ # InventoryService.performAdUnitAction
25
+
26
+ require 'rubygems'
27
+ require 'dfp_api'
28
+
29
+ API_VERSION = :v201101
30
+ PAGE_SIZE = 500
31
+
32
+ def deactivate_ad_units()
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 InventoryService.
41
+ inventory_service = dfp.service(:InventoryService, API_VERSION)
42
+
43
+ # Create statement text to select active ad units.
44
+ statement_text = 'WHERE status = :status'
45
+ statement = {
46
+ :values => [
47
+ {:key => 'status',
48
+ :value => {:value => 'ACTIVE', :xsi_type => 'TextValue'}}
49
+ ]
50
+ }
51
+
52
+ # Define initial values.
53
+ offset = 0
54
+ page = Hash.new
55
+ ad_unit_ids = Array.new
56
+
57
+ begin
58
+ # Create a statement to get one page with current offset.
59
+ statement[:query] = statement_text +
60
+ " LIMIT %d OFFSET %d" % [PAGE_SIZE, offset]
61
+
62
+ # Get ad units by statement.
63
+ page = inventory_service.get_ad_units_by_statement(statement)
64
+
65
+ if page[:results]
66
+ # Increase query offset by page size.
67
+ offset += PAGE_SIZE
68
+
69
+ page[:results].each do |ad_unit|
70
+ puts ("%d) Ad unit with ID: %d, status: %s and name: %s will be " +
71
+ "deactivated.") % [ad_unit_ids.size, ad_unit[:id],
72
+ ad_unit[:status], ad_unit[:name]]
73
+ ad_unit_ids << ad_unit[:id]
74
+ end
75
+ end
76
+ end while offset < page[:total_result_set_size]
77
+
78
+ puts "Number of ad units to be deactivated: %d" % ad_unit_ids.size
79
+
80
+ if !ad_unit_ids.empty?
81
+ # Modify statement for action. Note, the values are still present.
82
+ statement[:query] = statement_text + " AND id IN (%s)" %
83
+ ad_unit_ids.join(', ')
84
+
85
+ # Perform action.
86
+ result = inventory_service.perform_ad_unit_action(
87
+ {:xsi_type => 'DeactivateAdUnits'}, statement)
88
+
89
+ # Display results.
90
+ if result and result[:num_changes] > 0
91
+ puts "Number of ad units deactivated: %d" % result[:num_changes]
92
+ else
93
+ puts 'No ad units were deactivated.'
94
+ end
95
+ else
96
+ puts 'No ad units found to deactivate.'
97
+ end
98
+ end
99
+
100
+ if __FILE__ == $0
101
+ begin
102
+ deactivate_ad_units()
103
+
104
+ # HTTP errors.
105
+ rescue AdsCommon::Errors::HttpError => e
106
+ puts "HTTP Error: %s" % e
107
+
108
+ # API errors.
109
+ rescue DfpApi::Errors::ApiException => e
110
+ puts "Message: %s" % e.message
111
+ puts 'Errors:'
112
+ e.errors.each_with_index do |error, index|
113
+ puts "\tError [%d]:" % (index + 1)
114
+ error.each do |field, value|
115
+ puts "\t\t%s: %s" % [field, value]
116
+ end
117
+ end
118
+ end
119
+ end
@@ -0,0 +1,72 @@
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 an ad unit by its ID. To determine which ad units
21
+ # exist, run get_inventory_tree.rb or get_all_ad_units.rb.
22
+ #
23
+ # Tags: InventoryService.getAdUnit
24
+
25
+ require 'rubygems'
26
+ require 'dfp_api'
27
+
28
+ API_VERSION = :v201101
29
+
30
+ def get_ad_unit()
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 InventoryService.
39
+ inventory_service = dfp.service(:InventoryService, API_VERSION)
40
+
41
+ # Set the ID of the ad unit to get.
42
+ ad_unit_id = 'INSERT_AD_UNIT_ID_HERE'.to_i
43
+
44
+ # Get the ad unit.
45
+ ad_unit = inventory_service.get_ad_unit(ad_unit_id)
46
+
47
+ if ad_unit
48
+ puts "Ad unit with ID: %d, name: %s and status: %s was found." %
49
+ [ad_unit[:id], ad_unit[:name], ad_unit[:status]]
50
+ end
51
+ end
52
+
53
+ if __FILE__ == $0
54
+ begin
55
+ get_ad_unit()
56
+
57
+ # HTTP errors.
58
+ rescue AdsCommon::Errors::HttpError => e
59
+ puts "HTTP Error: %s" % e
60
+
61
+ # API errors.
62
+ rescue DfpApi::Errors::ApiException => e
63
+ puts "Message: %s" % e.message
64
+ puts 'Errors:'
65
+ e.errors.each_with_index do |error, index|
66
+ puts "\tError [%d]:" % (index + 1)
67
+ error.each do |field, value|
68
+ puts "\t\t%s: %s" % [field, value]
69
+ end
70
+ end
71
+ end
72
+ end