From a5aa4fb29e9bd0b68930b47d679a1b559b1aac6f Mon Sep 17 00:00:00 2001 From: Terry Mancey Date: Tue, 7 Jul 2020 08:41:37 +0100 Subject: [PATCH] Fixes state level ads being shown on version without state level targeting --- .../data/resources/catalog-schema.json | 53 +++++++++++++------ vendor/bat-native-ads/data/test/catalog.json | 12 +++-- .../src/bat/ads/internal/ads_serve.cc | 2 +- .../src/bat/ads/internal/catalog_state.cc | 2 +- .../ad_conversions_database_table_unittest.cc | 2 +- ...d_notifications_database_table_unittest.cc | 2 +- .../subdivision_targeting_frequency_cap.cc | 21 +++++++- .../subdivision_targeting_frequency_cap.h | 3 ++ ...vision_targeting_frequency_cap_unittest.cc | 8 +-- .../src/bat/ads/internal/static_values.h | 2 +- 10 files changed, 77 insertions(+), 30 deletions(-) diff --git a/vendor/bat-native-ads/data/resources/catalog-schema.json b/vendor/bat-native-ads/data/resources/catalog-schema.json index 0d3c0aa0c33b..edd9695b22d7 100755 --- a/vendor/bat-native-ads/data/resources/catalog-schema.json +++ b/vendor/bat-native-ads/data/resources/catalog-schema.json @@ -126,7 +126,8 @@ "totalMax", "segments", "creatives", - "oses" + "oses", + "channels" ], "properties": { "creativeSetId": { @@ -163,6 +164,7 @@ }, "segments": { "type": "array", + "minItems": 1, "items": { "type": "object", "additionalProperties": false, @@ -202,6 +204,12 @@ } } }, + "channels": { + "type": "array", + "items": { + "type": "string" + } + }, "creatives": { "type": "array", "items": { @@ -242,23 +250,36 @@ }, "payload": { "type": "object", - "additionalProperties": false, - "required": [ - "targetUrl", - "body", - "title" - ], - "properties": { - "targetUrl": { - "type": "string" - }, - "body": { - "type": "string" + "oneOf": [ + { + "properties": { + "targetUrl": { + "type": "string" + }, + "body": { + "type": "string" + }, + "title": { + "type": "string" + } + }, + "additionalProperties": false }, - "title": { - "type": "string" + { + "properties": { + "creativeUrl": { + "type": "string" + }, + "size": { + "type": "string" + }, + "targetUrl": { + "type": "string" + } + }, + "additionalProperties": false } - } + ] } } } diff --git a/vendor/bat-native-ads/data/test/catalog.json b/vendor/bat-native-ads/data/test/catalog.json index 44ebb4987a9b..c2e4566f11c0 100644 --- a/vendor/bat-native-ads/data/test/catalog.json +++ b/vendor/bat-native-ads/data/test/catalog.json @@ -1,5 +1,5 @@ { - "version": 1, + "version": 3, "issuers": [ { "name": "confirmation", @@ -60,12 +60,15 @@ "type": "postview" } ], + "channels": [ + ], "creativeSetId": "340c927f-696e-4060-9933-3eafc56c3f31", "perDay": 5, "totalMax": 100 } ], - "dayParts": [], + "dayParts": [ + ], "geoTargets": [ { "code": "US", @@ -113,12 +116,15 @@ "type": "postclick" } ], + "channels": [ + ], "creativeSetId": "3e2e503a-dd38-42d1-9e26-1e5dbb66aada", "perDay": 5, "totalMax": 100 } ], - "dayParts": [], + "dayParts": [ + ], "geoTargets": [ { "code": "US", diff --git a/vendor/bat-native-ads/src/bat/ads/internal/ads_serve.cc b/vendor/bat-native-ads/src/bat/ads/internal/ads_serve.cc index 86f5b66cbc13..d09a13e1a475 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/ads_serve.cc +++ b/vendor/bat-native-ads/src/bat/ads/internal/ads_serve.cc @@ -36,7 +36,7 @@ void AdsServe::DownloadCatalog() { } BLOG(1, "Download catalog"); - BLOG(2, "GET /v2/catalog"); + BLOG(2, "GET " << CATALOG_PATH); auto callback = std::bind(&AdsServe::OnCatalogDownloaded, this, url_, _1, _2, _3); diff --git a/vendor/bat-native-ads/src/bat/ads/internal/catalog_state.cc b/vendor/bat-native-ads/src/bat/ads/internal/catalog_state.cc index 73da8a53711d..8e24ab220232 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/catalog_state.cc +++ b/vendor/bat-native-ads/src/bat/ads/internal/catalog_state.cc @@ -44,7 +44,7 @@ Result CatalogState::FromJson( new_catalog_id = catalog["catalogId"].GetString(); new_version = catalog["version"].GetUint64(); - if (new_version != 1) { + if (new_version != 3) { return SUCCESS; } diff --git a/vendor/bat-native-ads/src/bat/ads/internal/database/tables/ad_conversions_database_table_unittest.cc b/vendor/bat-native-ads/src/bat/ads/internal/database/tables/ad_conversions_database_table_unittest.cc index 60f0ca5fa054..0f570784542f 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/database/tables/ad_conversions_database_table_unittest.cc +++ b/vendor/bat-native-ads/src/bat/ads/internal/database/tables/ad_conversions_database_table_unittest.cc @@ -316,7 +316,7 @@ TEST_F(BatAdsAdConversionsDatabaseTableTest, const URLEndpoints endpoints = { { - "/v2/catalog", { + "/v3/catalog", { { net::HTTP_OK, "/catalog.json" } diff --git a/vendor/bat-native-ads/src/bat/ads/internal/database/tables/creative_ad_notifications_database_table_unittest.cc b/vendor/bat-native-ads/src/bat/ads/internal/database/tables/creative_ad_notifications_database_table_unittest.cc index d0b6486d27f5..2364a93e9663 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/database/tables/creative_ad_notifications_database_table_unittest.cc +++ b/vendor/bat-native-ads/src/bat/ads/internal/database/tables/creative_ad_notifications_database_table_unittest.cc @@ -792,7 +792,7 @@ TEST_F(BatAdsCreativeAdNotificationsDatabaseTableTest, const URLEndpoints endpoints = { { - "/v2/catalog", { + "/v3/catalog", { { net::HTTP_OK, "/catalog.json" } diff --git a/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.cc b/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.cc index 90ab5f60a982..9ef251f16682 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.cc +++ b/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.cc @@ -49,11 +49,11 @@ bool SubdivisionTargetingFrequencyCap::DoesRespectCap( if (!ads_->get_subdivision_targeting()->ShouldAllowAdsSubdivisionTargeting( locale)) { - return true; + return !DoesAdTargetSubdivision(ad); } if (ads_->get_subdivision_targeting()->IsDisabled()) { - return true; + return !DoesAdTargetSubdivision(ad); } const std::string subdivision_targeting_code = @@ -80,6 +80,23 @@ bool SubdivisionTargetingFrequencyCap::DoesAdSupportSubdivisionTargetingCode( return true; } +bool SubdivisionTargetingFrequencyCap::DoesAdTargetSubdivision( + const CreativeAdInfo& ad) const { + const auto iter = std::find_if(ad.geo_targets.begin(), ad.geo_targets.end(), + [&](const std::string& geo_target) { + const std::vector components = base::SplitString( + geo_target, "-", base::KEEP_WHITESPACE, base::SPLIT_WANT_ALL); + + return components.size() == 2; + }); + + if (iter == ad.geo_targets.end()) { + return false; + } + + return true; +} + std::string SubdivisionTargetingFrequencyCap::GetCountryCode( const std::string& subdivision_targeting_code) const { const std::vector components = base::SplitString( diff --git a/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.h b/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.h index 0ad3ba3d2e5e..400a6a5f1327 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.h +++ b/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap.h @@ -44,6 +44,9 @@ class SubdivisionTargetingFrequencyCap : public ExclusionRule { const CreativeAdInfo& ad, const std::string& subdivision_targeting_code) const; + bool DoesAdTargetSubdivision( + const CreativeAdInfo& ad) const; + std::string GetCountryCode( const std::string& subdivision_targeting_code) const; }; diff --git a/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap_unittest.cc b/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap_unittest.cc index 29e119097dd3..5d03d357271e 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap_unittest.cc +++ b/vendor/bat-native-ads/src/bat/ads/internal/frequency_capping/exclusion_rules/subdivision_targeting_frequency_cap_unittest.cc @@ -194,7 +194,7 @@ TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, } TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, - AllowAdIfSubdivisionTargetingIsNotSupportedForSubdivisionGeoTarget) { + DoNotAllowAdIfSubdivisionTargetingIsNotSupportedForSubdivisionGeoTarget) { // Arrange ON_CALL(*locale_helper_mock_, GetLocale()) .WillByDefault(Return("en-GB")); @@ -207,7 +207,7 @@ TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, const bool should_exclude = frequency_cap_->ShouldExclude(ad); // Assert - EXPECT_FALSE(should_exclude); + EXPECT_TRUE(should_exclude); } TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, @@ -228,7 +228,7 @@ TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, } TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, - AllowAdIfSubdivisionTargetingIsDisabledForSubdivisionGeoTarget) { + DoNotAllowAdIfSubdivisionTargetingIsDisabledForSubdivisionGeoTarget) { // Arrange ON_CALL(*ads_client_mock_, GetAdsSubdivisionTargetingCode()) .WillByDefault(Return("DISABLED")); @@ -241,7 +241,7 @@ TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, const bool should_exclude = frequency_cap_->ShouldExclude(ad); // Assert - EXPECT_FALSE(should_exclude); + EXPECT_TRUE(should_exclude); } TEST_F(BatAdsSubdivisionTargetingFrequencyCapTest, diff --git a/vendor/bat-native-ads/src/bat/ads/internal/static_values.h b/vendor/bat-native-ads/src/bat/ads/internal/static_values.h index ae6efa3eaadf..1735978d539a 100644 --- a/vendor/bat-native-ads/src/bat/ads/internal/static_values.h +++ b/vendor/bat-native-ads/src/bat/ads/internal/static_values.h @@ -19,7 +19,7 @@ namespace ads { #define STAGING_SERVER "https://ads-serve.bravesoftware.com" #define DEVELOPMENT_SERVER "https://ads-serve.brave.software" -#define CATALOG_PATH "/v2/catalog" +#define CATALOG_PATH "/v3/catalog" #define GETSTATE_PATH "/v5/getstate" const int kIdleThresholdInSeconds = 15;