Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Prebid v2.0.2 #656

Open
wants to merge 92 commits into
base: ci_backup_20240402
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
92 commits
Select commit Hold shift + click to select a range
48e6275
DOOH support (#2758)
minaguib Sep 20, 2023
db87119
Record tmax timeout error in adapter error metric (#3104)
onkarvhanumante Sep 20, 2023
55302c6
Cleanup Prometheus Type Conversions (#3106)
SyntaxNode Sep 20, 2023
b9c2614
make case insensitive comparison in auction request (#3113)
gargcreation1992 Sep 25, 2023
a91e40c
Silvermob: host validation (us, eu, apac) (#3110)
freemmy Sep 26, 2023
63170b8
make bidderInfo endpoint case insensitive (#3136)
gargcreation1992 Sep 26, 2023
bc81af5
extract directory name only if file is not removed and file is in ada…
onkarvhanumante Sep 26, 2023
00bdbef
Support case insensitive bidder name in ext.prebid.storedbidresponse.…
onkarvhanumante Sep 26, 2023
940355c
Support case insensitive bidder name in adjustment factors (#3140)
onkarvhanumante Sep 26, 2023
27498c8
Support case insensitive bidder name in ext.prebid.data.eidpermission…
onkarvhanumante Sep 26, 2023
6738217
Remove Adapter: RhythmOne (#3129)
SyntaxNode Sep 26, 2023
18edf18
make NormalizeBidderName to do faster lookup (#3138)
gargcreation1992 Sep 26, 2023
d10ccf6
Remove Adapter: Applogy (#3130)
SyntaxNode Sep 26, 2023
aff482f
Remove Adapter: Define Media (#3132)
SyntaxNode Sep 26, 2023
10d854c
Remove Adapter: Kubient (#3133)
SyntaxNode Sep 26, 2023
03779e3
Remove Adapter: NinthDecimal (#3142)
SyntaxNode Sep 26, 2023
e3cf3c3
Remove Adapter: Yeahmobi (#3143)
SyntaxNode Sep 26, 2023
f2230c8
Remove Adapter: engageBDR (#3131)
SyntaxNode Sep 26, 2023
0d96c9d
Remove Adapter: Nano Interactive (#3134)
SyntaxNode Sep 26, 2023
efdda05
Remove Config Backwards Compatibility: File System Stored Requests (#…
bsardo Sep 27, 2023
0c8f79b
Remove Config Backwards Compatibility: Enable Events (#3135)
bsardo Sep 27, 2023
fc36944
Remove Config Backwards Compatibility: Enable GZIP (#3125)
bsardo Sep 27, 2023
f879f63
Remove Config Backwards Compatibility: DB Connection Info (#3146)
bsardo Sep 28, 2023
0d488ee
ImproveDigital: updates (#3077)
ishihanvcs Sep 29, 2023
6a36178
[ORBIDDER] add user sync redirect url (#3118)
arneschulz1984 Sep 29, 2023
4ad946b
Adnuntius: Add Price Type (#3084)
mikael-lundin Sep 29, 2023
9e14c09
Rubicon: Remove eids logic (#3111)
SerhiiNahornyi Sep 29, 2023
061aa84
Adapter alias - syncer changes (#3082)
onkarvhanumante Sep 29, 2023
1a5f12c
Remove Config Backwards Compatibility: Host GDPR Options (#3153)
bsardo Sep 29, 2023
5cc92ae
Remove Config Backwards Compatibility: Account GDPR Purpose (#3154)
bsardo Sep 29, 2023
1360786
Remove Deprecated Config: Account Blacklist (#3156)
SyntaxNode Oct 2, 2023
a2e387f
Remove Config Backwards Compatibility: Account GDPR/CCPA Integration …
bsardo Oct 3, 2023
781dc7b
Remove Config Backwards Compatibility: User Sync URL (#3163)
SyntaxNode Oct 4, 2023
134e9aa
Analytics activities (#3024)
VeronikaSolovei9 Oct 4, 2023
324a973
update lunamedia contact info (#3137)
bretg Oct 5, 2023
8cdfe48
enable adapter alias feature (#3179)
gargcreation1992 Oct 5, 2023
23bc394
New Adapter: smartx (#3109)
fkoch-sc Oct 9, 2023
1944dbb
Adapter Name Case Insensitive: EID Permissions (#3187)
SyntaxNode Oct 9, 2023
e76b4b3
OneTag: ORTB 2.6 initial support (#3128)
EmanueleSimonelli Oct 10, 2023
c8f3b2d
Adapter Name Case Insensitive: SetUID Endpoint (#3186)
SyntaxNode Oct 10, 2023
81c78ff
pubmatic: add fledge support (#3174)
pm-nilesh-chate Oct 11, 2023
3c7d852
New Adapter: Edge226 (#3105)
Edge226Ads Oct 16, 2023
6f4bb59
New Adapter: Teads (#3112)
github-maxime-liege Oct 16, 2023
dff9b3b
Updated User Sync Support and GPP Support Flag (#3181)
vrtcal-dev Oct 16, 2023
987e640
make event endpoint case insensitive (#3199)
gargcreation1992 Oct 16, 2023
05e06bb
New Adapter: LemmaDigital (#3157)
lm-ved Oct 16, 2023
2dbf671
minduration non-required (#3185)
ikagotso Oct 16, 2023
c45ab81
add supportCORS to orbidder user sync config (#3193)
arneschulz1984 Oct 16, 2023
9d216fb
Adapter Name Case Insensitive: /vtrack endpoint (#3196)
onkarvhanumante Oct 16, 2023
5b44d36
Prometheus metrics: bidder name should be in lowercase (#3198)
onkarvhanumante Oct 16, 2023
6c6aa9a
InfluxDB metrics : bidder name should be in lowercase (#3209)
onkarvhanumante Oct 16, 2023
eea6ffe
migrate adform alias to use new pattern (#3180)
gargcreation1992 Oct 17, 2023
293cadc
migrate copper alias to use new pattern (#3182)
gargcreation1992 Oct 17, 2023
1384564
update cookie sync endpoint to be case insensitive (#3103)
gargcreation1992 Oct 17, 2023
b3e5d1d
Adapter Name Case Insensitive: user.ext.prebid.buyeruids (#3152)
Sonali-More-Xandr Oct 17, 2023
f152b0d
Adapter Name Case Insensitive: Bid Adjustment Factors (#3210)
AlexBVolcy Oct 17, 2023
17109ca
Welcome Back: yeahmobi (#3228)
SyntaxNode Oct 18, 2023
11ef54d
Adapter Name Case Insensitive: First Party Data (#3211)
SyntaxNode Oct 18, 2023
bde7bcf
Adapter Name Case Insensitive: ext.prebid.multibid (#3217)
guscarreon Oct 18, 2023
f4425b6
migrate janet alias to use new pattern (#3189)
gargcreation1992 Oct 18, 2023
83c7946
migrate janet alias to use new pattern (#3190)
gargcreation1992 Oct 18, 2023
32ddaca
migrate streamkey alias to use new pattern (#3191)
gargcreation1992 Oct 18, 2023
9bfe196
migrate viewdeos alias to use new pattern (#3192)
gargcreation1992 Oct 18, 2023
91881fe
migrate limelight aliases to follow new pattern (#3183)
onkarvhanumante Oct 18, 2023
ac7a0d4
migrate apacdex aliases to use new pattern (#3184)
onkarvhanumante Oct 18, 2023
bc77035
Update release workflow to support major version release (#3235)
onkarvhanumante Oct 18, 2023
8131a14
New Adapter: IQX (#3164)
IQzoneIT Oct 19, 2023
e8d93cc
HuaweiAds: Fixing the fill rate issue (#3219)
ahmetfaruk59 Oct 19, 2023
34ddf1a
DXKulture adapter (#3176)
bev-devops Oct 19, 2023
6f630fd
JSON Serialization: Change Libraries (#3225)
bsardo Oct 19, 2023
cd03a0f
Restore Alias User Syncs (#3244)
SyntaxNode Oct 19, 2023
50ad642
Revert "Remove Adapter: Define Media" (#3242)
dennisjay Oct 19, 2023
53e0adc
Adapter Name Case Insensitive: Stored Bid Responses (#3197)
VeronikaSolovei9 Oct 20, 2023
6b98a81
Adapter Name Case Insensitive: alternate bidder codes (#3229)
guscarreon Oct 20, 2023
ec729e6
Increment Package Version To V2 (#3245)
SyntaxNode Oct 20, 2023
2540dd8
RTBHouse: native support (#3212)
piotrj-rtbh Oct 30, 2023
8e9f3f3
Rubicon: Add `imp[].ext.rp.rtb.formats` logic (#3255)
SerhiiNahornyi Oct 30, 2023
3834c22
Revert "Rubicon: Add `imp[].ext.rp.rtb.formats` logic (#3255)" (#3268)
Sonali-More-Xandr Oct 30, 2023
72463be
Revert "RTBHouse: native support (#3212)" (#3271)
bsardo Oct 30, 2023
b200357
Increment to V2 in Dockerfile and Makefile (#3272)
guscarreon Oct 31, 2023
0894a0a
adapter code coverage fix for master (#631)
Ankit-Pinge Nov 2, 2023
c527f01
OTT-1410: TEMPORARY: removed warning message when module is not enabl…
ashishshinde-pubm Nov 6, 2023
5941d46
Fix: BidderInfo OpenRTB field data lost on start up (#3178)
ashishshinde-pubm Nov 13, 2023
9099264
Fix for null string unmarshal error (#3284)
VeronikaSolovei9 Nov 13, 2023
f52dbb1
Fix: use bidder info fs config as base when merging overrides (#3289)
bsardo Nov 14, 2023
180eb41
Fix: Revert JSON lib used to prepare /bidders/params response (#3300)
bsardo Nov 15, 2023
5e40322
Merge branch 'master' into prebid_v2.0.0
Pubmatic-Supriya-Patil Nov 24, 2023
b6db403
Merge remote-tracking branch 'origin/ci' into prebid_v2.0.0
Pubmatic-Supriya-Patil Nov 27, 2023
f983e9f
Merge branch 'prebid_v2.0.0' into prebid_v2.0.1
Pubmatic-Supriya-Patil Nov 28, 2023
7c7a9a0
Merge branch 'prebid_v2.0.1' into prebid_v2.0.2
Pubmatic-Supriya-Patil Nov 28, 2023
f9a6865
Added missing changes in merge
Pubmatic-Supriya-Patil Nov 29, 2023
41054c2
Updated module name to v2
Pubmatic-Supriya-Patil Nov 30, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
14 changes: 7 additions & 7 deletions .github/workflows/adapter-code-coverage.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,9 @@ jobs:
result-encoding: string
script: |
const utils = require('./.github/workflows/helpers/pull-request-utils.js')
function directoryExtractor(filepath) {
// extract directory name from filepath of the form adapters/<adapter-name>/*.go
if (filepath.startsWith("adapters/") && filepath.split("/").length > 2) {
function directoryExtractor(filepath, status) {
// extract directory name only if file is not removed and file is in adapters directory
if (status != "removed" && filepath.startsWith("adapters/") && filepath.split("/").length > 2) {
return filepath.split("/")[1]
}
return ""
Expand All @@ -41,7 +41,7 @@ jobs:

- name: Run coverage tests
id: run_coverage
if: ${{ steps.get_directories.outputs.result }} != ""
if: steps.get_directories.outputs.result != ''
run: |
git config --global url."https://${USERNAME}:${TOKEN}@git.pubmatic.com".insteadOf "https://git.pubmatic.com"

Expand Down Expand Up @@ -81,7 +81,7 @@ jobs:
repository: PubMatic-OpenWrap/prebid-server

- name: Commit coverage files to coverage-preview branch
if: ${{ steps.run_coverage.outputs.coverage_dir }} != ""
if: steps.run_coverage.outputs.coverage_dir != ''
id: commit_coverage
run: |
directory=.github/preview/${{ github.run_id }}_$(date +%s)
Expand All @@ -95,11 +95,11 @@ jobs:
echo "remote_coverage_preview_dir=${directory}" >> $GITHUB_OUTPUT

- name: Checkout master branch
if: ${{ steps.get_directories.outputs.result }} != ""
if: steps.get_directories.outputs.result != ''
run: git checkout master

- name: Add coverage summary to pull request
if: ${{ steps.run_coverage.outputs.coverage_dir }} != "" && ${{ steps.commit_coverage.outputs.remote_coverage_preview_dir }} != ""
if: steps.run_coverage.outputs.coverage_dir != '' && steps.commit_coverage.outputs.remote_coverage_preview_dir != ''
uses: actions/github-script@v6
with:
script: |
Expand Down
4 changes: 2 additions & 2 deletions .github/workflows/helpers/pull-request-utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -213,8 +213,8 @@ class diffHelper {
})

const directories = []
for (const { filename } of data) {
const directory = directoryExtractor(filename)
for (const { filename, status } of data) {
const directory = directoryExtractor(filename, status)
if (directory != "" && !directories.includes(directory)) {
directories.push(directory)
}
Expand Down
18 changes: 13 additions & 5 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,12 @@ on:
releaseType:
type: choice
options:
- major
- minor
- patch
default: minor
required: true
description: 'minor: v0.X.0, patch: v0.0.X'
description: 'major: vX.0.0, minor: v0.X.0, patch: v0.0.X'
debug:
type: boolean
default: true
Expand Down Expand Up @@ -78,11 +79,18 @@ jobs:

nextTag=''
releaseType=${{ inputs.releaseType }}
if [ $releaseType == "minor" ]; then
# increment minor version and reset patch version
nextTag=$(echo "${currentTag}" | awk -F. '{OFS="."; $2+=1; $3=0; print $0}')
if [ $releaseType == "major" ]; then
# PBS-GO skipped the v1.0.0 major release - https://github.com/prebid/prebid-server/issues/3068
# If the current tag is v0.x.x, the script sets the next release tag to v2.0.0
# Otherwise, the script increments the major version by 1 and sets the minor and patch versions to zero
# For example, v2.x.x will be incremented to v3.0.0
major=$(echo "${currentTag}" | awk -F. '{gsub(/^v/, "", $1); if($1 == 0) $1=2; else $1+=1; print $1}')
nextTag="v${major}.0.0"
elif [ $releaseType == "minor" ]; then
# Increment minor version and reset patch version
nextTag=$(echo "${currentTag}" | awk -F. '{OFS="."; $2+=1; $3=0; print $0}')
else
# increment patch version
# Increment patch version
nextTag=$(echo "${currentTag}" | awk -F. '{OFS="."; $3+=1; print $0}')
fi

Expand Down
4 changes: 2 additions & 2 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,8 @@ vendor

# build artifacts
prebid-server
build
debug
/build
/debug
__debug_bin

# config files
Expand Down
2 changes: 1 addition & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ RUN go mod tidy
RUN go mod vendor
ARG TEST="true"
RUN if [ "$TEST" != "false" ]; then ./validate.sh ; fi
RUN go build -mod=vendor -ldflags "-X github.com/prebid/prebid-server/version.Ver=`git describe --tags | sed 's/^v//'` -X github.com/prebid/prebid-server/version.Rev=`git rev-parse HEAD`" .
RUN go build -mod=vendor -ldflags "-X github.com/prebid/prebid-server/v2/version.Ver=`git describe --tags | sed 's/^v//'` -X github.com/prebid/prebid-server/v2/version.Rev=`git rev-parse HEAD`" .

FROM ubuntu:20.04 AS release
LABEL maintainer="[email protected]"
Expand Down
10 changes: 5 additions & 5 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ test: deps
ifeq "$(adapter)" ""
./validate.sh
else
go test github.com/prebid/prebid-server/adapters/$(adapter) -bench=.
go test github.com/prebid/prebid-server/v2/adapters/$(adapter) -bench=.
endif

# build-modules generates modules/builder.go file which provides a list of all available modules
Expand Down Expand Up @@ -43,16 +43,16 @@ mockgeninstall:
mockgendb:
mkdir -p modules/pubmatic/openwrap/database/mock modules/pubmatic/openwrap/database/mock_driver
mockgen database/sql/driver Driver,Connector,Conn,DriverContext > modules/pubmatic/openwrap/database/mock_driver/mock.go
mockgen github.com/PubMatic-OpenWrap/prebid-server/modules/pubmatic/openwrap/database Database > modules/pubmatic/openwrap/database/mock/mock.go
mockgen github.com/PubMatic-OpenWrap/prebid-server/v2/modules/pubmatic/openwrap/database Database > modules/pubmatic/openwrap/database/mock/mock.go

mockgencache:
mkdir -p modules/pubmatic/openwrap/cache/mock
mockgen github.com/PubMatic-OpenWrap/prebid-server/modules/pubmatic/openwrap/cache Cache > modules/pubmatic/openwrap/cache/mock/mock.go
mockgen github.com/PubMatic-OpenWrap/prebid-server/v2/modules/pubmatic/openwrap/cache Cache > modules/pubmatic/openwrap/cache/mock/mock.go

mockgenmetrics:
mkdir -p modules/pubmatic/openwrap/metrics/mock
mockgen github.com/PubMatic-OpenWrap/prebid-server/modules/pubmatic/openwrap/metrics MetricsEngine > modules/pubmatic/openwrap/metrics/mock/mock.go
mockgen github.com/PubMatic-OpenWrap/prebid-server/v2/modules/pubmatic/openwrap/metrics MetricsEngine > modules/pubmatic/openwrap/metrics/mock/mock.go

mockgenlogger:
mkdir -p analytics/pubmatic/mhttp/mock
mockgen github.com/PubMatic-OpenWrap/prebid-server/analytics/pubmatic/mhttp HttpCallInterface,MultiHttpContextInterface > analytics/pubmatic/mhttp/mock/mock.go
mockgen github.com/PubMatic-OpenWrap/prebid-server/v2/analytics/pubmatic/mhttp HttpCallInterface,MultiHttpContextInterface > analytics/pubmatic/mhttp/mock/mock.go
170 changes: 15 additions & 155 deletions account/account.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,32 +2,27 @@ package account

import (
"context"
"encoding/json"
"fmt"
"github.com/buger/jsonparser"

"github.com/prebid/go-gdpr/consentconstants"
"github.com/prebid/prebid-server/config"
"github.com/prebid/prebid-server/errortypes"
"github.com/prebid/prebid-server/metrics"
"github.com/prebid/prebid-server/openrtb_ext"
"github.com/prebid/prebid-server/stored_requests"
"github.com/prebid/prebid-server/util/iputil"
jsonpatch "gopkg.in/evanphx/json-patch.v4"

"github.com/prebid/prebid-server/v2/config"
"github.com/prebid/prebid-server/v2/errortypes"
"github.com/prebid/prebid-server/v2/metrics"
"github.com/prebid/prebid-server/v2/openrtb_ext"
"github.com/prebid/prebid-server/v2/stored_requests"
"github.com/prebid/prebid-server/v2/util/iputil"
"github.com/prebid/prebid-server/v2/util/jsonutil"
)

// GetAccount looks up the config.Account object referenced by the given accountID, with access rules applied
func GetAccount(ctx context.Context, cfg *config.Configuration, fetcher stored_requests.AccountFetcher, accountID string, me metrics.MetricsEngine) (account *config.Account, errs []error) {
// Check BlacklistedAcctMap until we have deprecated it
if _, found := cfg.BlacklistedAcctMap[accountID]; found {
return nil, []error{&errortypes.BlacklistedAcct{
Message: fmt.Sprintf("Prebid-server has disabled Account ID: %s, please reach out to the prebid server host.", accountID),
}}
}
if cfg.AccountRequired && accountID == metrics.PublisherUnknown {
return nil, []error{&errortypes.AcctRequired{
Message: fmt.Sprintf("Prebid-server has been configured to discard requests without a valid Account ID. Please reach out to the prebid server host."),
}}
}

if accountJSON, accErrs := fetcher.FetchAccount(ctx, cfg.AccountDefaultsJSON(), accountID); len(accErrs) > 0 || accountJSON == nil {
// accountID does not reference a valid account
for _, e := range accErrs {
Expand All @@ -49,45 +44,12 @@ func GetAccount(ctx context.Context, cfg *config.Configuration, fetcher stored_r
} else {
// accountID resolved to a valid account, merge with AccountDefaults for a complete config
account = &config.Account{}
err := json.Unmarshal(accountJSON, account)

// this logic exists for backwards compatibility. If the initial unmarshal fails above, we attempt to
// resolve it by converting the GDPR enforce purpose fields and then attempting an unmarshal again before
// declaring a malformed account error.
// unmarshal fetched account to determine if it is well-formed
var deprecatedPurposeFields []string
if _, ok := err.(*json.UnmarshalTypeError); ok {
// attempt to convert deprecated GDPR enforce purpose fields to resolve issue
accountJSON, err, deprecatedPurposeFields = ConvertGDPREnforcePurposeFields(accountJSON)
// unmarshal again to check if unmarshal error still exists after GDPR field conversion
err = json.Unmarshal(accountJSON, account)

if _, ok := err.(*json.UnmarshalTypeError); ok {
return nil, []error{&errortypes.MalformedAcct{
Message: fmt.Sprintf("The prebid-server account config for account id \"%s\" is malformed. Please reach out to the prebid server host.", accountID),
}}
}
}
usingGDPRChannelEnabled := useGDPRChannelEnabled(account)
usingCCPAChannelEnabled := useCCPAChannelEnabled(account)

if usingGDPRChannelEnabled {
me.RecordAccountGDPRChannelEnabledWarning(accountID)
}
if usingCCPAChannelEnabled {
me.RecordAccountCCPAChannelEnabledWarning(accountID)
}
for _, purposeName := range deprecatedPurposeFields {
me.RecordAccountGDPRPurposeWarning(accountID, purposeName)
}
if len(deprecatedPurposeFields) > 0 || usingGDPRChannelEnabled || usingCCPAChannelEnabled {
me.RecordAccountUpgradeStatus(accountID)
if err := jsonutil.UnmarshalValid(accountJSON, account); err != nil {
return nil, []error{&errortypes.MalformedAcct{
Message: fmt.Sprintf("The prebid-server account config for account id \"%s\" is malformed. Please reach out to the prebid server host.", accountID),
}}
}

if err != nil {
errs = append(errs, err)
return nil, errs
}
// Fill in ID if needed, so it can be left out of account definition
if len(account.ID) == 0 {
account.ID = accountID
Expand All @@ -97,7 +59,7 @@ func GetAccount(ctx context.Context, cfg *config.Configuration, fetcher stored_r
setDerivedConfig(account)
}
if account.Disabled {
errs = append(errs, &errortypes.BlacklistedAcct{
errs = append(errs, &errortypes.AccountDisabled{
Message: fmt.Sprintf("Prebid-server has disabled Account ID: %s, please reach out to the prebid server host.", accountID),
})
return nil, errs
Expand All @@ -111,9 +73,6 @@ func GetAccount(ctx context.Context, cfg *config.Configuration, fetcher stored_r
account.Privacy.IPv4Config.AnonKeepBits = iputil.IPv4DefaultMaskingBitSize
}

// set the value of events.enabled field based on deprecated events_enabled field and ensure backward compatibility
deprecateEventsEnabledField(account)

return account, nil
}

Expand Down Expand Up @@ -178,102 +137,3 @@ func setDerivedConfig(account *config.Account) {
}
}
}

// PatchAccount represents the GDPR portion of a publisher account configuration that can be mutated
// for backwards compatibility reasons
type PatchAccount struct {
GDPR map[string]*PatchAccountGDPRPurpose `json:"gdpr"`
}

// PatchAccountGDPRPurpose represents account-specific GDPR purpose configuration data that can be mutated
// for backwards compatibility reasons
type PatchAccountGDPRPurpose struct {
EnforceAlgo string `json:"enforce_algo,omitempty"`
EnforcePurpose *bool `json:"enforce_purpose,omitempty"`
}

// ConvertGDPREnforcePurposeFields is responsible for ensuring account GDPR config backwards compatibility
// given the recent type change of gdpr.purpose{1-10}.enforce_purpose from a string to a bool. This function
// iterates over each GDPR purpose config and sets enforce_purpose and enforce_algo to the appropriate
// bool and string values respectively if enforce_purpose is a string and enforce_algo is not set
func ConvertGDPREnforcePurposeFields(config []byte) (newConfig []byte, err error, deprecatedPurposeFields []string) {
gdprJSON, _, _, err := jsonparser.Get(config, "gdpr")
if err != nil && err == jsonparser.KeyPathNotFoundError {
return config, nil, deprecatedPurposeFields
}
if err != nil {
return nil, err, deprecatedPurposeFields
}

newAccount := PatchAccount{
GDPR: map[string]*PatchAccountGDPRPurpose{},
}

for i := 1; i <= 10; i++ {
purposeName := fmt.Sprintf("purpose%d", i)

enforcePurpose, purposeDataType, _, err := jsonparser.Get(gdprJSON, purposeName, "enforce_purpose")
if err != nil && err == jsonparser.KeyPathNotFoundError {
continue
}
if err != nil {
return nil, err, deprecatedPurposeFields
}
if purposeDataType != jsonparser.String {
continue
} else {
deprecatedPurposeFields = append(deprecatedPurposeFields, purposeName)
}

_, _, _, err = jsonparser.Get(gdprJSON, purposeName, "enforce_algo")
if err != nil && err != jsonparser.KeyPathNotFoundError {
return nil, err, deprecatedPurposeFields
}
if err == nil {
continue
}

newEnforcePurpose := false
if string(enforcePurpose) == "full" {
newEnforcePurpose = true
}

newAccount.GDPR[purposeName] = &PatchAccountGDPRPurpose{
EnforceAlgo: "full",
EnforcePurpose: &newEnforcePurpose,
}
}

patchConfig, err := json.Marshal(newAccount)
if err != nil {
return nil, err, deprecatedPurposeFields
}

newConfig, err = jsonpatch.MergePatch(config, patchConfig)
if err != nil {
return nil, err, deprecatedPurposeFields
}

return newConfig, nil, deprecatedPurposeFields
}

func useGDPRChannelEnabled(account *config.Account) bool {
return account.GDPR.ChannelEnabled.IsSet() && !account.GDPR.IntegrationEnabled.IsSet()
}

func useCCPAChannelEnabled(account *config.Account) bool {
return account.CCPA.ChannelEnabled.IsSet() && !account.CCPA.IntegrationEnabled.IsSet()
}

// deprecateEventsEnabledField is responsible for ensuring backwards compatibility of "events_enabled" field.
// This function favors "events.enabled" field over deprecated "events_enabled" field, if values for both are set.
// If only deprecated "events_enabled" field is set then it sets the same value to "events.enabled" field.
func deprecateEventsEnabledField(account *config.Account) {
if account != nil {
if account.Events.Enabled == nil {
account.Events.Enabled = account.EventsEnabled
}
// assign the old value to the new value so old and new are always the same even though the new value is what is used in the application code.
account.EventsEnabled = account.Events.Enabled
}
}
Loading
Loading