google-dfp-api 0.9.4 → 0.9.5
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.
- data/ChangeLog +4 -0
- data/README.md +1 -3
- data/dfp_api.yml +1 -9
- data/examples/v201408/report_service/run_sales_report.rb +3 -3
- data/examples/v201411/report_service/run_sales_report.rb +3 -3
- data/examples/v201502/report_service/run_sales_report.rb +3 -3
- data/examples/{v201405 → v201505}/activity_group_service/create_activity_groups.rb +1 -1
- data/examples/{v201405 → v201505}/activity_group_service/get_active_activity_groups.rb +18 -27
- data/examples/{v201405 → v201505}/activity_group_service/get_all_activity_groups.rb +13 -23
- data/examples/{v201405 → v201505}/activity_group_service/update_activity_groups.rb +11 -9
- data/examples/{v201405 → v201505}/activity_service/create_activities.rb +1 -1
- data/examples/{v201405 → v201505}/activity_service/get_active_activities.rb +15 -27
- data/examples/{v201405 → v201505}/activity_service/get_all_activities.rb +10 -21
- data/examples/{v201405 → v201505}/activity_service/update_activities.rb +9 -7
- data/examples/{v201405 → v201505}/audience_segment_service/create_audience_segments.rb +1 -1
- data/examples/{v201405 → v201505}/audience_segment_service/get_all_audience_segments.rb +10 -19
- data/examples/{v201405 → v201505}/audience_segment_service/get_first_party_audience_segments.rb +14 -21
- data/examples/{v201405 → v201505}/audience_segment_service/populate_first_party_audience_segments.rb +16 -14
- data/examples/{v201405 → v201505}/audience_segment_service/update_audience_segments.rb +12 -11
- data/examples/{v201405 → v201505}/common/error_handling.rb +1 -1
- data/examples/{v201405 → v201505}/common/oauth2_jwt_handling.rb +9 -17
- data/examples/{v201405 → v201505}/common/setup_oauth2.rb +1 -1
- data/examples/{v201405 → v201505}/company_service/create_companies.rb +1 -1
- data/examples/{v201405 → v201505}/company_service/get_all_companies.rb +10 -18
- data/examples/{v201405 → v201505}/company_service/get_companies_by_statement.rb +21 -16
- data/examples/{v201405 → v201505}/company_service/update_companies.rb +13 -10
- data/examples/{v201405 → v201505}/contact_service/create_contacts.rb +1 -1
- data/examples/{v201405 → v201505}/contact_service/get_all_contacts.rb +11 -19
- data/examples/{v201405 → v201505}/contact_service/get_uninvited_contacts.rb +18 -22
- data/examples/{v201405 → v201505}/contact_service/update_contacts.rb +9 -7
- data/examples/{v201405 → v201505}/content_metadata_key_hierarchy_service/create_content_metadata_key_hierarchies.rb +1 -1
- data/examples/{v201405 → v201505}/content_metadata_key_hierarchy_service/delete_content_metadata_key_hierarchies.rb +11 -8
- data/examples/{v201405 → v201505}/content_metadata_key_hierarchy_service/get_all_content_metadata_key_hierarchies.rb +8 -18
- data/examples/{v201405 → v201505}/content_metadata_key_hierarchy_service/update_content_metadata_key_hierarchies.rb +9 -7
- data/examples/{v201405 → v201505}/content_service/get_all_content.rb +9 -18
- data/examples/{v201405 → v201505}/content_service/get_content_by_category.rb +18 -28
- data/examples/{v201405 → v201505}/creative_service/copy_image_creatives.rb +7 -7
- data/examples/{v201405 → v201505}/creative_service/create_creative_from_template.rb +1 -1
- data/examples/{v201405 → v201505}/creative_service/create_creatives.rb +1 -1
- data/examples/{v201405 → v201505}/creative_service/create_custom_creative.rb +1 -1
- data/examples/{v201405 → v201505}/creative_service/get_all_creatives.rb +8 -17
- data/examples/{v201405 → v201505}/creative_service/get_creatives_by_statement.rb +18 -13
- data/examples/{v201405 → v201505}/creative_service/update_creatives.rb +16 -11
- data/examples/{v201405 → v201505}/creative_set_service/associate_creative_set_to_line_item.rb +1 -1
- data/examples/{v201405 → v201505}/creative_set_service/create_creative_set.rb +1 -1
- data/examples/{v201405 → v201505}/creative_set_service/get_all_creative_sets.rb +9 -17
- data/examples/{v201405 → v201505}/creative_set_service/get_creative_sets_by_statement.rb +20 -14
- data/examples/{v201405 → v201505}/creative_set_service/update_creative_sets.rb +10 -7
- data/examples/{v201405 → v201505}/creative_template_service/get_all_creative_templates.rb +9 -17
- data/examples/{v201405/creative_template_service/get_creative_templates_by_statement.rb → v201505/creative_template_service/get_system_defined_creative_templates.rb} +24 -13
- data/examples/{v201405 → v201505}/creative_wrapper_service/create_creative_wrappers.rb +1 -1
- data/examples/{v201405 → v201505}/creative_wrapper_service/deactivate_creative_wrapper.rb +9 -7
- data/examples/{v201405 → v201505}/creative_wrapper_service/get_all_creative_wrappers.rb +10 -18
- data/examples/{v201405 → v201505}/creative_wrapper_service/get_creative_wrappers_by_statement.rb +17 -12
- data/examples/{v201405 → v201505}/creative_wrapper_service/update_creative_wrappers.rb +10 -7
- data/examples/{v201405 → v201505}/custom_field_service/create_custom_field_options.rb +1 -1
- data/examples/{v201405 → v201505}/custom_field_service/create_custom_fields.rb +1 -1
- data/examples/{v201405 → v201505}/custom_field_service/deactivate_all_line_item_custom_fields.rb +13 -23
- data/examples/{v201405 → v201505}/custom_field_service/get_all_custom_fields.rb +11 -19
- data/examples/{v201405 → v201505}/custom_field_service/get_all_line_item_custom_fields.rb +19 -14
- data/examples/{v201405 → v201505}/custom_field_service/set_line_item_custom_field_value.rb +24 -19
- data/examples/{v201405 → v201505}/custom_field_service/update_custom_fields.rb +10 -7
- data/examples/{v201405 → v201505}/custom_targeting_service/create_custom_targeting_keys_and_values.rb +1 -1
- data/examples/{v201405 → v201505}/custom_targeting_service/delete_custom_targeting_keys.rb +16 -20
- data/examples/{v201405 → v201505}/custom_targeting_service/delete_custom_targeting_values.rb +23 -21
- data/examples/{v201405 → v201505}/custom_targeting_service/get_all_custom_targeting_keys_and_values.rb +15 -36
- data/examples/{v201405 → v201505}/custom_targeting_service/get_custom_targeting_keys_by_statement.rb +20 -16
- data/examples/{v201405 → v201505}/custom_targeting_service/get_custom_targeting_values_by_statement.rb +19 -15
- data/examples/{v201405 → v201505}/custom_targeting_service/update_custom_targeting_keys.rb +4 -3
- data/examples/{v201405 → v201505}/custom_targeting_service/update_custom_targeting_values.rb +34 -30
- data/examples/{v201405/forecast_service/get_forecast.rb → v201505/forecast_service/get_availability_forecast.rb} +38 -16
- data/examples/{v201405/forecast_service/get_forecast_by_id.rb → v201505/forecast_service/get_availability_forecast_for_line_item.rb} +18 -11
- data/examples/v201505/forecast_service/get_delivery_forecast_for_line_items.rb +81 -0
- data/examples/{v201405 → v201505}/inventory_service/create_ad_units.rb +1 -1
- data/examples/{v201405 → v201505}/inventory_service/create_mobile_ad_unit.rb +1 -1
- data/examples/{v201405 → v201505}/inventory_service/create_video_ad_unit.rb +1 -1
- data/examples/{v201405 → v201505}/inventory_service/deactivate_ad_units.rb +19 -23
- data/examples/{v201405 → v201505}/inventory_service/get_ad_unit_sizes.rb +7 -14
- data/examples/{v201405 → v201505}/inventory_service/get_ad_units_by_statement.rb +18 -13
- data/examples/{v201405 → v201505}/inventory_service/get_all_ad_units.rb +8 -17
- data/examples/{v201405 → v201505}/inventory_service/update_ad_units.rb +23 -11
- data/examples/{v201405 → v201505}/label_service/create_labels.rb +1 -1
- data/examples/{v201405 → v201505}/label_service/deactivate_labels.rb +15 -22
- data/examples/{v201405 → v201505}/label_service/get_all_labels.rb +9 -18
- data/examples/{v201405 → v201505}/label_service/get_labels_by_statement.rb +16 -11
- data/examples/{v201405 → v201505}/label_service/update_labels.rb +24 -26
- data/examples/{v201405 → v201505}/line_item_creative_association_service/create_licas.rb +1 -1
- data/examples/{v201405 → v201505}/line_item_creative_association_service/deactivate_licas.rb +15 -24
- data/examples/{v201405 → v201505}/line_item_creative_association_service/get_all_licas.rb +8 -17
- data/examples/{v201405 → v201505}/line_item_creative_association_service/get_licas_by_statement.rb +10 -8
- data/examples/{v201405 → v201505}/line_item_creative_association_service/update_licas.rb +16 -7
- data/examples/{v201405 → v201505}/line_item_service/activate_line_items.rb +13 -21
- data/examples/{v201405 → v201505}/line_item_service/create_line_items.rb +11 -4
- data/examples/{v201405 → v201505}/line_item_service/create_video_line_item.rb +13 -3
- data/examples/{v201405 → v201505}/line_item_service/get_all_line_items.rb +9 -17
- data/examples/{v201405 → v201505}/line_item_service/get_line_items_by_statement.rb +19 -17
- data/examples/{v201405 → v201505}/line_item_service/get_recently_updated_line_items.rb +19 -13
- data/examples/{v201405 → v201505}/line_item_service/target_custom_criteria.rb +9 -7
- data/examples/{v201405 → v201505}/line_item_service/update_line_items.rb +9 -9
- data/examples/{v201405 → v201505}/network_service/get_all_networks.rb +1 -1
- data/examples/{v201405 → v201505}/network_service/get_current_network.rb +1 -1
- data/examples/{v201405 → v201505}/network_service/make_test_network.rb +1 -1
- data/examples/{v201405 → v201505}/order_service/approve_orders.rb +16 -24
- data/examples/{v201405 → v201505}/order_service/create_orders.rb +1 -1
- data/examples/{v201405 → v201505}/order_service/get_all_orders.rb +8 -17
- data/examples/{v201405 → v201505}/order_service/get_orders_by_statement.rb +18 -14
- data/examples/{v201405 → v201505}/order_service/update_orders.rb +15 -7
- data/examples/{v201405 → v201505}/placement_service/create_placements.rb +4 -2
- data/examples/{v201405 → v201505}/placement_service/deactivate_placements.rb +14 -22
- data/examples/{v201405 → v201505}/placement_service/get_all_placements.rb +9 -17
- data/examples/{v201405 → v201505}/placement_service/get_placements_by_statement.rb +18 -13
- data/examples/{v201405 → v201505}/placement_service/update_placements.rb +16 -6
- data/examples/{v201405 → v201505}/publisher_query_language_service/fetch_match_tables.rb +8 -11
- data/examples/{v201405 → v201505}/publisher_query_language_service/get_all_line_items.rb +8 -9
- data/examples/{v201405 → v201505}/publisher_query_language_service/get_geo_targets.rb +10 -10
- data/examples/{v201405 → v201505}/publisher_query_language_service/get_line_items_named_like.rb +10 -10
- data/examples/{v201405 → v201505}/report_service/display_report.rb +1 -1
- data/examples/{v201405 → v201505}/report_service/download_report.rb +1 -1
- data/examples/{v201405 → v201505}/report_service/run_delivery_report.rb +6 -5
- data/examples/{v201405 → v201505}/report_service/run_inventory_report.rb +6 -5
- data/examples/{v201405 → v201505}/report_service/run_reach_report.rb +6 -5
- data/examples/{v201405/report_service/run_merged_delivery_report.rb → v201505/report_service/run_report_with_custom_fields.rb} +17 -18
- data/examples/{v201405 → v201505}/report_service/run_sales_report.rb +6 -5
- data/examples/{v201405 → v201505}/suggested_ad_unit_service/approve_all_suggested_ad_units.rb +25 -21
- data/examples/{v201405 → v201505}/suggested_ad_unit_service/get_all_suggested_ad_units.rb +9 -18
- data/examples/{v201405 → v201505}/suggested_ad_unit_service/get_suggested_ad_units_by_statement.rb +24 -21
- data/examples/{v201405 → v201505}/team_service/create_teams.rb +1 -1
- data/examples/{v201405 → v201505}/team_service/get_all_teams.rb +8 -17
- data/examples/{v201405 → v201505}/team_service/get_teams_by_statement.rb +15 -11
- data/examples/{v201405 → v201505}/team_service/update_teams.rb +4 -3
- data/examples/{v201405 → v201505}/user_service/create_users.rb +1 -1
- data/examples/{v201405 → v201505}/user_service/deactivate_users.rb +7 -7
- data/examples/{v201405 → v201505}/user_service/get_all_roles.rb +1 -1
- data/examples/{v201405 → v201505}/user_service/get_all_users.rb +8 -18
- data/examples/{v201405 → v201505}/user_service/get_current_user.rb +1 -1
- data/examples/{v201405 → v201505}/user_service/get_users_by_statement.rb +17 -12
- data/examples/{v201405 → v201505}/user_service/update_users.rb +15 -6
- data/examples/{v201405 → v201505}/user_team_association_service/create_user_team_associations.rb +1 -1
- data/examples/{v201405 → v201505}/user_team_association_service/delete_user_team_associations.rb +13 -21
- data/examples/{v201405 → v201505}/user_team_association_service/get_all_user_team_associations.rb +10 -17
- data/examples/{v201405 → v201505}/user_team_association_service/get_user_team_associations_by_statement.rb +20 -16
- data/examples/{v201405 → v201505}/user_team_association_service/update_user_team_associations.rb +8 -7
- data/lib/dfp_api/api_config.rb +27 -4
- data/lib/dfp_api/v201505/activity_group_service.rb +42 -0
- data/lib/dfp_api/v201505/activity_group_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/activity_service.rb +42 -0
- data/lib/dfp_api/v201505/activity_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/ad_exclusion_rule_service.rb +46 -0
- data/lib/dfp_api/v201505/ad_exclusion_rule_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/ad_rule_service.rb +46 -0
- data/lib/dfp_api/v201505/ad_rule_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/audience_segment_service.rb +46 -0
- data/lib/dfp_api/v201505/audience_segment_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/base_rate_service.rb +46 -0
- data/lib/dfp_api/v201505/base_rate_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/company_service.rb +42 -0
- data/lib/dfp_api/v201505/company_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/contact_service.rb +42 -0
- data/lib/dfp_api/v201505/contact_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/content_bundle_service.rb +46 -0
- data/lib/dfp_api/v201505/content_bundle_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/content_metadata_key_hierarchy_service.rb +46 -0
- data/lib/dfp_api/v201505/content_metadata_key_hierarchy_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/content_service.rb +38 -0
- data/lib/dfp_api/v201505/content_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/creative_service.rb +42 -0
- data/lib/dfp_api/v201505/creative_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/creative_set_service.rb +42 -0
- data/lib/dfp_api/v201505/creative_set_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/creative_template_service.rb +34 -0
- data/lib/dfp_api/v201505/creative_template_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/creative_wrapper_service.rb +46 -0
- data/lib/dfp_api/v201505/creative_wrapper_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/custom_field_service.rb +58 -0
- data/lib/dfp_api/v201505/custom_field_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/custom_targeting_service.rb +62 -0
- data/lib/dfp_api/v201505/custom_targeting_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/exchange_rate_service.rb +46 -0
- data/lib/dfp_api/v201505/exchange_rate_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/forecast_service.rb +46 -0
- data/lib/dfp_api/v201505/forecast_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/inventory_service.rb +50 -0
- data/lib/dfp_api/v201505/inventory_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/label_service.rb +46 -0
- data/lib/dfp_api/v201505/label_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/line_item_creative_association_service.rb +50 -0
- data/lib/dfp_api/v201505/line_item_creative_association_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/line_item_service.rb +46 -0
- data/lib/dfp_api/v201505/line_item_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/line_item_template_service.rb +34 -0
- data/lib/dfp_api/v201505/line_item_template_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/live_stream_event_service.rb +46 -0
- data/lib/dfp_api/v201505/live_stream_event_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/network_service.rb +46 -0
- data/lib/dfp_api/v201505/network_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/order_service.rb +46 -0
- data/lib/dfp_api/v201505/order_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/package_service.rb +46 -0
- data/lib/dfp_api/v201505/package_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/placement_service.rb +46 -0
- data/lib/dfp_api/v201505/placement_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/premium_rate_service.rb +42 -0
- data/lib/dfp_api/v201505/premium_rate_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/product_package_item_service.rb +46 -0
- data/lib/dfp_api/v201505/product_package_item_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/product_package_service.rb +46 -0
- data/lib/dfp_api/v201505/product_package_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/product_service.rb +42 -0
- data/lib/dfp_api/v201505/product_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/product_template_service.rb +46 -0
- data/lib/dfp_api/v201505/product_template_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/proposal_line_item_service.rb +46 -0
- data/lib/dfp_api/v201505/proposal_line_item_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/proposal_service.rb +46 -0
- data/lib/dfp_api/v201505/proposal_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/publisher_query_language_service.rb +34 -0
- data/lib/dfp_api/v201505/publisher_query_language_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/rate_card_service.rb +46 -0
- data/lib/dfp_api/v201505/rate_card_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/reconciliation_order_report_service.rb +38 -0
- data/lib/dfp_api/v201505/reconciliation_order_report_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/reconciliation_report_row_service.rb +38 -0
- data/lib/dfp_api/v201505/reconciliation_report_row_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/reconciliation_report_service.rb +38 -0
- data/lib/dfp_api/v201505/reconciliation_report_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/report_service.rb +46 -0
- data/lib/dfp_api/v201505/report_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/shared_ad_unit_service.rb +38 -0
- data/lib/dfp_api/v201505/shared_ad_unit_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/suggested_ad_unit_service.rb +38 -0
- data/lib/dfp_api/v201505/suggested_ad_unit_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/team_service.rb +42 -0
- data/lib/dfp_api/v201505/team_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/user_service.rb +54 -0
- data/lib/dfp_api/v201505/user_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/user_team_association_service.rb +46 -0
- data/lib/dfp_api/v201505/user_team_association_service_registry.rb +45 -0
- data/lib/dfp_api/v201505/workflow_request_service.rb +38 -0
- data/lib/dfp_api/v201505/workflow_request_service_registry.rb +45 -0
- data/lib/dfp_api/version.rb +1 -1
- data/test/bugs/test_issue_00000016.rb +1 -1
- data/test/dfp_api/test_config.yml +6 -5
- data/test/dfp_api/test_dfp_api.rb +32 -32
- metadata +234 -140
- data/examples/v201405/creative_template_service/get_creative_template.rb +0 -74
- data/examples/v201405/report_service/run_report_with_custom_fields.rb +0 -135
- data/examples/v201405/suggested_ad_unit_service/get_suggested_ad_unit.rb +0 -75
|
@@ -23,9 +23,9 @@
|
|
|
23
23
|
# Tags: CreativeService.getCreativesByStatement
|
|
24
24
|
|
|
25
25
|
require 'dfp_api'
|
|
26
|
+
require 'dfp_api_statement'
|
|
26
27
|
|
|
27
|
-
API_VERSION = :
|
|
28
|
-
PAGE_SIZE = 500
|
|
28
|
+
API_VERSION = :v201505
|
|
29
29
|
|
|
30
30
|
def get_all_creatives()
|
|
31
31
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -38,32 +38,23 @@ def get_all_creatives()
|
|
|
38
38
|
# Get the CreativeService.
|
|
39
39
|
creative_service = dfp.service(:CreativeService, API_VERSION)
|
|
40
40
|
|
|
41
|
-
#
|
|
42
|
-
|
|
43
|
-
page = {}
|
|
41
|
+
# Create a statement to get one page with current offset.
|
|
42
|
+
statement = DfpApiStatement::FilterStatement.new('ORDER BY id ASC')
|
|
44
43
|
|
|
45
44
|
begin
|
|
46
|
-
# Create a statement to get one page with current offset.
|
|
47
|
-
statement = {:query => "LIMIT %d OFFSET %d" % [PAGE_SIZE, offset]}
|
|
48
|
-
|
|
49
45
|
# Get creatives by statement.
|
|
50
|
-
page = creative_service.get_creatives_by_statement(statement)
|
|
46
|
+
page = creative_service.get_creatives_by_statement(statement.toStatement())
|
|
51
47
|
|
|
52
48
|
if page[:results]
|
|
53
|
-
# Increase query offset by page size.
|
|
54
|
-
offset += PAGE_SIZE
|
|
55
|
-
|
|
56
|
-
# Get the start index for printout.
|
|
57
|
-
start_index = page[:start_index]
|
|
58
|
-
|
|
59
49
|
# Print details about each creative in results.
|
|
60
50
|
page[:results].each_with_index do |creative, index|
|
|
61
51
|
puts "%d) Creative ID: %d, name: %s, type: %s" %
|
|
62
|
-
[index +
|
|
52
|
+
[index + statement.offset, creative[:id],
|
|
63
53
|
creative[:name], creative[:creative_type]]
|
|
64
54
|
end
|
|
65
55
|
end
|
|
66
|
-
|
|
56
|
+
statement.offset += DfpApiStatement::SUGGESTED_PAGE_LIMIT
|
|
57
|
+
end while statement.offset < page[:total_result_set_size]
|
|
67
58
|
|
|
68
59
|
# Print a footer.
|
|
69
60
|
if page.include?(:total_result_set_size)
|
|
@@ -25,8 +25,9 @@
|
|
|
25
25
|
# Tags: CreativeService.getCreativesByStatement
|
|
26
26
|
|
|
27
27
|
require 'dfp_api'
|
|
28
|
+
require 'dfp_api_statement'
|
|
28
29
|
|
|
29
|
-
API_VERSION = :
|
|
30
|
+
API_VERSION = :v201505
|
|
30
31
|
|
|
31
32
|
def get_creatives_by_statement()
|
|
32
33
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -40,24 +41,28 @@ def get_creatives_by_statement()
|
|
|
40
41
|
creative_service = dfp.service(:CreativeService, API_VERSION)
|
|
41
42
|
|
|
42
43
|
# Create a statement to only select image creatives.
|
|
43
|
-
statement =
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
statement = DfpApiStatement::FilterStatement.new(
|
|
45
|
+
'WHERE creativeType = :creative_type ORDER BY id ASC',
|
|
46
|
+
[
|
|
46
47
|
{:key => 'creative_type',
|
|
47
48
|
:value => {:value => 'ImageCreative', :xsi_type => 'TextValue'}}
|
|
48
49
|
]
|
|
49
|
-
|
|
50
|
+
)
|
|
50
51
|
|
|
51
|
-
|
|
52
|
-
|
|
52
|
+
begin
|
|
53
|
+
# Get creatives by statement.
|
|
54
|
+
page = creative_service.get_creatives_by_statement(statement.toStatement())
|
|
53
55
|
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
56
|
+
if page[:results]
|
|
57
|
+
# Print details about each creative in results.
|
|
58
|
+
page[:results].each_with_index do |creative, index|
|
|
59
|
+
puts "%d) Creative ID: %d, name: %s, type: %s" %
|
|
60
|
+
[index + statement.offset,
|
|
61
|
+
creative[:id], creative[:name], creative[:creative_type]]
|
|
62
|
+
end
|
|
59
63
|
end
|
|
60
|
-
|
|
64
|
+
statement.offset += DfpApiStatement::SUGGESTED_PAGE_LIMIT
|
|
65
|
+
end while statement.offset < page[:total_result_set_size]
|
|
61
66
|
|
|
62
67
|
# Print a footer.
|
|
63
68
|
if page.include?(:total_result_set_size)
|
|
@@ -18,14 +18,15 @@
|
|
|
18
18
|
# See the License for the specific language governing permissions and
|
|
19
19
|
# limitations under the License.
|
|
20
20
|
#
|
|
21
|
-
# This example updates the destination URL of
|
|
22
|
-
#
|
|
21
|
+
# This example updates the destination URL of a single creative searching by ID.
|
|
22
|
+
# To determine which image creatives exist, run get_all_creatives.rb.
|
|
23
23
|
#
|
|
24
24
|
# Tags: CreativeService.getCreativesByStatement, CreativeService.updateCreatives
|
|
25
25
|
|
|
26
26
|
require 'dfp_api'
|
|
27
|
+
require 'dfp_api_statement'
|
|
27
28
|
|
|
28
|
-
API_VERSION = :
|
|
29
|
+
API_VERSION = :v201505
|
|
29
30
|
|
|
30
31
|
def update_creatives()
|
|
31
32
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -38,17 +39,21 @@ def update_creatives()
|
|
|
38
39
|
# Get the CreativeService.
|
|
39
40
|
creative_service = dfp.service(:CreativeService, API_VERSION)
|
|
40
41
|
|
|
42
|
+
# Specify creative ID to update.
|
|
43
|
+
creative_id = 'INSERT_CREATIVE_ID_HERE'.to_i
|
|
44
|
+
|
|
41
45
|
# Create a statement to get first 500 image creatives.
|
|
42
|
-
statement =
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
{:key => '
|
|
46
|
-
:value => {:value =>
|
|
47
|
-
]
|
|
48
|
-
|
|
46
|
+
statement = DfpApiStatement::FilterStatement.new(
|
|
47
|
+
'WHERE id = :id ORDER BY id ASC',
|
|
48
|
+
[
|
|
49
|
+
{:key => 'id',
|
|
50
|
+
:value => {:value => creative_id, :xsi_type => 'NumberValue'}}
|
|
51
|
+
],
|
|
52
|
+
1
|
|
53
|
+
)
|
|
49
54
|
|
|
50
55
|
# Get creatives by statement.
|
|
51
|
-
page = creative_service.get_creatives_by_statement(statement)
|
|
56
|
+
page = creative_service.get_creatives_by_statement(statement.toStatement())
|
|
52
57
|
|
|
53
58
|
if page[:results]
|
|
54
59
|
creatives = page[:results]
|
|
@@ -24,9 +24,9 @@
|
|
|
24
24
|
# Tags: CreativeSetService.getCreativeSetsByStatement
|
|
25
25
|
|
|
26
26
|
require 'dfp_api'
|
|
27
|
+
require 'dfp_api_statement'
|
|
27
28
|
|
|
28
|
-
API_VERSION = :
|
|
29
|
-
PAGE_SIZE = 500
|
|
29
|
+
API_VERSION = :v201505
|
|
30
30
|
|
|
31
31
|
def get_all_creative_sets()
|
|
32
32
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -39,32 +39,24 @@ def get_all_creative_sets()
|
|
|
39
39
|
# Get the CreativeSetService.
|
|
40
40
|
creative_set_service = dfp.service(:CreativeSetService, API_VERSION)
|
|
41
41
|
|
|
42
|
-
#
|
|
43
|
-
|
|
44
|
-
page = {}
|
|
42
|
+
# Create statement for one page with current offset.
|
|
43
|
+
statement = DfpApiStatement::FilterStatement.new('ORDER BY id ASC')
|
|
45
44
|
|
|
46
45
|
begin
|
|
47
|
-
# Create statement for one page with current offset.
|
|
48
|
-
statement = {:query => 'LIMIT %d OFFSET %d' % [PAGE_SIZE, offset]}
|
|
49
|
-
|
|
50
46
|
# Get creative sets by statement.
|
|
51
|
-
page = creative_set_service.get_creative_sets_by_statement(
|
|
47
|
+
page = creative_set_service.get_creative_sets_by_statement(
|
|
48
|
+
statement.toStatement())
|
|
52
49
|
|
|
53
50
|
if page[:results]
|
|
54
|
-
# Increase query offset by page size.
|
|
55
|
-
offset += PAGE_SIZE
|
|
56
|
-
|
|
57
|
-
# Get the start index for printout.
|
|
58
|
-
start_index = page[:start_index]
|
|
59
|
-
|
|
60
51
|
# Print details about each creative set in results page.
|
|
61
52
|
page[:results].each_with_index do |set, index|
|
|
62
53
|
puts ('%d) Creative set ID: %d, master creative ID: %d and companion ' +
|
|
63
|
-
'creative IDs: [%s]') % [index +
|
|
54
|
+
'creative IDs: [%s]') % [index + statement.offset, set[:id],
|
|
64
55
|
set[:master_creative_id], set[:companion_creative_ids].join(', ')]
|
|
65
56
|
end
|
|
66
57
|
end
|
|
67
|
-
|
|
58
|
+
statement.offset += DfpApiStatement::SUGGESTED_PAGE_LIMIT
|
|
59
|
+
end while statement.offset < page[:total_result_set_size]
|
|
68
60
|
|
|
69
61
|
# Print a footer
|
|
70
62
|
if page.include?(:total_result_set_size)
|
|
@@ -24,8 +24,9 @@
|
|
|
24
24
|
# Tags: CreativeSetService.getCreativeSetsByStatement
|
|
25
25
|
|
|
26
26
|
require 'dfp_api'
|
|
27
|
+
require 'dfp_api_statement'
|
|
27
28
|
|
|
28
|
-
API_VERSION = :
|
|
29
|
+
API_VERSION = :v201505
|
|
29
30
|
|
|
30
31
|
def get_creative_sets_by_statement()
|
|
31
32
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -42,25 +43,30 @@ def get_creative_sets_by_statement()
|
|
|
42
43
|
|
|
43
44
|
# Create a statement to get all creative sets that have the given master
|
|
44
45
|
# creative.
|
|
45
|
-
statement =
|
|
46
|
-
|
|
47
|
-
|
|
46
|
+
statement = DfpApiStatement::FilterStatement.new(
|
|
47
|
+
'WHERE masterCreativeId = :master_creative_id ORDER BY id ASC',
|
|
48
|
+
[
|
|
48
49
|
{:key => 'master_creative_id',
|
|
49
50
|
:value => {:value => master_creative_id, :xsi_type => 'NumberValue'}}
|
|
50
51
|
]
|
|
51
|
-
|
|
52
|
+
)
|
|
52
53
|
|
|
53
|
-
|
|
54
|
-
|
|
54
|
+
begin
|
|
55
|
+
# Get creative sets by statement.
|
|
56
|
+
page = creative_set_service.get_creative_sets_by_statement(
|
|
57
|
+
statement.toStatement())
|
|
55
58
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
59
|
+
if page and page[:results]
|
|
60
|
+
page[:results].each_with_index do |creative_set, index|
|
|
61
|
+
puts ('%d) Creative set ID: %d, master creative ID: %d and companion ' +
|
|
62
|
+
'creative IDs: [%s]') %
|
|
63
|
+
[index + statement.offset, creative_set[:id],
|
|
64
|
+
creative_set[:master_creative_id],
|
|
65
|
+
creative_set[:companion_creative_ids].join(', ')]
|
|
66
|
+
end
|
|
62
67
|
end
|
|
63
|
-
|
|
68
|
+
statement.offset += DfpApiStatement::SUGGESTED_PAGE_LIMIT
|
|
69
|
+
end while statement.offset < page[:total_result_set_size]
|
|
64
70
|
|
|
65
71
|
# Print a footer.
|
|
66
72
|
if page.include?(:total_result_set_size)
|
|
@@ -25,8 +25,9 @@
|
|
|
25
25
|
# Tags: CreativeSetService.updateCreativeSet
|
|
26
26
|
|
|
27
27
|
require 'dfp_api'
|
|
28
|
+
require 'dfp_api_statement'
|
|
28
29
|
|
|
29
|
-
API_VERSION = :
|
|
30
|
+
API_VERSION = :v201505
|
|
30
31
|
|
|
31
32
|
def update_creative_sets()
|
|
32
33
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -44,16 +45,18 @@ def update_creative_sets()
|
|
|
44
45
|
creative_set_service = dfp.service(:CreativeSetService, API_VERSION)
|
|
45
46
|
|
|
46
47
|
# Create a statement to only select a single creative set.
|
|
47
|
-
statement =
|
|
48
|
-
|
|
49
|
-
|
|
48
|
+
statement = DfpApiStatement::FilterStatement.new(
|
|
49
|
+
'WHERE id = :id'
|
|
50
|
+
[
|
|
50
51
|
{:key => 'id',
|
|
51
52
|
:value => {:value => creative_set_id, :xsi_type => 'NumberValue'}}
|
|
52
|
-
]
|
|
53
|
-
|
|
53
|
+
],
|
|
54
|
+
1
|
|
55
|
+
)
|
|
54
56
|
|
|
55
57
|
# Get creative sets by statement.
|
|
56
|
-
page = creative_set_service.get_creative_sets_by_statement(
|
|
58
|
+
page = creative_set_service.get_creative_sets_by_statement(
|
|
59
|
+
statement.toStatement())
|
|
57
60
|
|
|
58
61
|
if page[:results]
|
|
59
62
|
creative_sets = page[:results]
|
|
@@ -23,9 +23,9 @@
|
|
|
23
23
|
# Tags: CreativeTemplateService.getCreativeTemplatesByStatement
|
|
24
24
|
|
|
25
25
|
require 'dfp_api'
|
|
26
|
+
require 'dfp_api_statement'
|
|
26
27
|
|
|
27
|
-
API_VERSION = :
|
|
28
|
-
PAGE_SIZE = 500
|
|
28
|
+
API_VERSION = :v201505
|
|
29
29
|
|
|
30
30
|
def get_all_creative_templates()
|
|
31
31
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -38,33 +38,25 @@ def get_all_creative_templates()
|
|
|
38
38
|
# Get the CreativeTemplateService.
|
|
39
39
|
creative_template_service = dfp.service(:CreativeTemplateService, API_VERSION)
|
|
40
40
|
|
|
41
|
-
#
|
|
42
|
-
|
|
43
|
-
page = {}
|
|
41
|
+
# Create a statement to get one page with current offset.
|
|
42
|
+
statement = DfpApiStatement::FilterStatement.new(ORDER BY id ASC)
|
|
44
43
|
|
|
45
44
|
begin
|
|
46
|
-
# Create a statement to get one page with current offset.
|
|
47
|
-
statement = {:query => "LIMIT %d OFFSET %d" % [PAGE_SIZE, offset]}
|
|
48
45
|
|
|
49
46
|
# Get creative templates by statement.
|
|
50
|
-
page =
|
|
51
|
-
|
|
47
|
+
page = creative_template_service.get_creative_templates_by_statement(
|
|
48
|
+
statement.toStatement())
|
|
52
49
|
|
|
53
50
|
if page[:results]
|
|
54
|
-
# Increase query offset by page size.
|
|
55
|
-
offset += PAGE_SIZE
|
|
56
|
-
|
|
57
|
-
# Get the start index for printout.
|
|
58
|
-
start_index = page[:start_index]
|
|
59
|
-
|
|
60
51
|
# Print details about each creative template in results.
|
|
61
52
|
page[:results].each_with_index do |template, index|
|
|
62
53
|
puts "%d) Creative template ID: %d, name: %s, type: %s" %
|
|
63
|
-
[index +
|
|
54
|
+
[index + statement.offset, template[:id],
|
|
64
55
|
template[:name], template[:type]]
|
|
65
56
|
end
|
|
66
57
|
end
|
|
67
|
-
|
|
58
|
+
statement.offset += DfpApiStatement::SUGGESTED_PAGE_LIMIT
|
|
59
|
+
end while statement.offset < page[:total_result_set_size]
|
|
68
60
|
|
|
69
61
|
# Print a footer.
|
|
70
62
|
if page.include?(:total_result_set_size)
|
|
@@ -18,13 +18,14 @@
|
|
|
18
18
|
# See the License for the specific language governing permissions and
|
|
19
19
|
# limitations under the License.
|
|
20
20
|
#
|
|
21
|
-
# This example gets
|
|
21
|
+
# This example gets system defined creative templates.
|
|
22
22
|
#
|
|
23
23
|
# Tags: CreativeTemplateService.getCreativeTemplatesByStatement
|
|
24
24
|
|
|
25
25
|
require 'dfp_api'
|
|
26
|
+
require 'dfp_api_statement'
|
|
26
27
|
|
|
27
|
-
API_VERSION = :
|
|
28
|
+
API_VERSION = :v201505
|
|
28
29
|
|
|
29
30
|
def get_creative_templates_by_statement()
|
|
30
31
|
# Get DfpApi instance and load configuration from ~/dfp_api.yml.
|
|
@@ -37,20 +38,30 @@ def get_creative_templates_by_statement()
|
|
|
37
38
|
# Get the CreativeTemplateService.
|
|
38
39
|
creative_template_service = dfp.service(:CreativeTemplateService, API_VERSION)
|
|
39
40
|
|
|
40
|
-
# Create a statement to only select
|
|
41
|
-
statement =
|
|
41
|
+
# Create a statement to only select system defined creative_templates.
|
|
42
|
+
statement = DfpApiStatement::FilterStatement.new(
|
|
43
|
+
'WHERE type = :type ORDER BY id ASC',
|
|
44
|
+
[
|
|
45
|
+
{:key => 'type',
|
|
46
|
+
:value => {:value => 'SYSTEM_DEFINED', :xsi_type => 'TextValue'}}
|
|
47
|
+
]
|
|
48
|
+
)
|
|
42
49
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
50
|
+
begin
|
|
51
|
+
# Get creative templates by statement.
|
|
52
|
+
page = creative_template_service.get_creative_templates_by_statement(
|
|
53
|
+
statement.toStatement())
|
|
46
54
|
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
55
|
+
if page[:results]
|
|
56
|
+
# Print details about each creative template in results.
|
|
57
|
+
page[:results].each_with_index do |template, index|
|
|
58
|
+
puts "%d) Creative template ID: %d, name: %s, type: %s" %
|
|
59
|
+
[index + statement.offset,
|
|
60
|
+
template[:id], template[:name], template[:type]]
|
|
61
|
+
end
|
|
52
62
|
end
|
|
53
|
-
|
|
63
|
+
statement.offset += DfpApiStatement::SUGGESTED_PAGE_LIMIT
|
|
64
|
+
end while statement.offset < page[:total_result_set_size]
|
|
54
65
|
|
|
55
66
|
# Print a footer.
|
|
56
67
|
if page.include?(:total_result_set_size)
|