Skip to content

Commit

Permalink
New script to interactively upload preferences tr-upload-preferences (
Browse files Browse the repository at this point in the history
#368)

* Skeleton for uploading preferences

* More fixes

* More fixes

* tsc

* Updates

* Wokring script

* ignore

* ignore

* no slice

* readme

* readme

* updates

* adds ud

* ud

* ud

* more fixes

* fixme

* adds test
  • Loading branch information
michaelfarrell76 authored Dec 3, 2024
1 parent 47ea74a commit 7fefa49
Show file tree
Hide file tree
Showing 49 changed files with 3,718 additions and 177 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ transcend.yml
transcend-privacy-requests-cache.json
cron-identifiers.csv
manual-enrichment-identifiers.csv
preference-management-upload-receipts.json
build/
privacy-request-upload-receipts/

Expand Down
53 changes: 48 additions & 5 deletions .pnp.cjs

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions .prettierignore
Original file line number Diff line number Diff line change
Expand Up @@ -51,3 +51,4 @@ yarn.lock
.idea
.gitkeep
.yarn/
transcend-yml-schema-*.json
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
92 changes: 81 additions & 11 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -118,30 +118,35 @@
- [Authentication](#authentication-26)
- [Arguments](#arguments-26)
- [Usage](#usage-27)
- [tr-upload-consent-preferences](#tr-upload-consent-preferences)
- [tr-upload-preferences](#tr-upload-preferences)
- [Authentication](#authentication-27)
- [Authentication](#authentication-28)
- [Arguments](#arguments-27)
- [Usage](#usage-28)
- [tr-pull-consent-preferences](#tr-pull-consent-preferences)
- [Authentication](#authentication-28)
- [tr-upload-consent-preferences](#tr-upload-consent-preferences)
- [Authentication](#authentication-29)
- [Arguments](#arguments-28)
- [Usage](#usage-29)
- [tr-upload-data-flows-from-csv](#tr-upload-data-flows-from-csv)
- [Authentication](#authentication-29)
- [tr-pull-consent-preferences](#tr-pull-consent-preferences)
- [Authentication](#authentication-30)
- [Arguments](#arguments-29)
- [Usage](#usage-30)
- [tr-upload-cookies-from-csv](#tr-upload-cookies-from-csv)
- [Authentication](#authentication-30)
- [tr-upload-data-flows-from-csv](#tr-upload-data-flows-from-csv)
- [Authentication](#authentication-31)
- [Arguments](#arguments-30)
- [Usage](#usage-31)
- [tr-generate-api-keys](#tr-generate-api-keys)
- [Authentication](#authentication-31)
- [tr-upload-cookies-from-csv](#tr-upload-cookies-from-csv)
- [Authentication](#authentication-32)
- [Arguments](#arguments-31)
- [Usage](#usage-32)
- [tr-build-xdi-sync-endpoint](#tr-build-xdi-sync-endpoint)
- [Authentication](#authentication-32)
- [tr-generate-api-keys](#tr-generate-api-keys)
- [Authentication](#authentication-33)
- [Arguments](#arguments-32)
- [Usage](#usage-33)
- [tr-build-xdi-sync-endpoint](#tr-build-xdi-sync-endpoint)
- [Authentication](#authentication-34)
- [Arguments](#arguments-33)
- [Usage](#usage-34)
- [Prompt Manager](#prompt-manager)
- [Proxy usage](#proxy-usage)

Expand Down Expand Up @@ -2296,6 +2301,71 @@ Specify the backend URL, needed for US hosted backend infrastructure:
yarn tr-pull-datapoints --auth=$TRANSCEND_API_KEY --file=./datapoints.csv --transcendUrl=https://api.us.transcend.io
```

### tr-upload-preferences

This command allows for updating of preference management data to your Transcend Preference Store.

This command uses [inquirer](https://github.com/SBoudrias/Inquirer.js/) to prompt the user to
map the shape of the CSV to the shape of the Transcend API. There is no requirement for the
shape of the incoming CSV, as the script will handle the mapping process.

The script will also produce a JSON cache file, that allows for the mappings to be preserved between runs.
This can be useful if you have the same CSV shape that needs to be imported multiple times.
Once the mapping process is done once, it does not need to be done again.

Additionally, the JSON cache file will store the result of any preferences that fail to be uploaded so that the
script can be run multiple times if an issue happens.

#### Authentication

In order to use this cli, you will first need to generate an API key on the Transcend Admin Dashboard (https://app.transcend.io/infrastructure/api-keys).

The API key needs the following scopes:

- Modify User Stored Preferences
- View Managed Consent Database Admin API
- View Preference Store Settings

#### Authentication

In order to use this cli, you will first need to follow [this guide](https://docs.transcend.io/docs/consent/reference/managed-consent-database#authenticate-a-user's-consent) in order

#### Arguments

| Argument | Description | Type | Default | Required |
| -------------------- | ------------------------------------------------------------------------------------------------- | ------------------ | -------------------------------------------- | -------- |
| auth | The Transcend API key with the scopes necessary for the command. | string | N/A | true |
| partition | The partition key to download consent preferences to | string | N/A | true |
| sombraAuth | The sombra internal key, use for additional authentication when self-hosting sombra. | string | N/A | false |
| transcendUrl | URL of the Transcend backend. Use https://consent.us.transcend.io for US hosting. | string - URL | https://consent.transcend.io | false |
| file | Path to the CSV file to load preferences from | string - file-path | ./preferences.csv | false |
| dryRun | Whether to do a dry run only - will write results ti receiptFilepath without updating Transcend | boolean | false | false |
| skipWorkflowTriggers | Whether to skip workflow triggers when uploading to preference store | boolean | false | false |
| skipConflictUpdates | Whether to skip uploading of any records where the preference store and file have a hard conflict | boolean | false | false |
| isSilent | Whether to skip sending emails in workflows | boolean | true | false |
| attributes | Attributes to add to any DSR request if created | string | Tags:transcend-cli,Source:transcend-cli | false |
| receiptFilepath | Store resulting, continuing where left off | string - file-path | ./preference-management-upload-receipts.json | false |

#### Usage

Upload consent preferences to partition key `4d1c5daa-90b7-4d18-aa40-f86a43d2c726`

```sh
yarn tr-upload-preferences --auth=$TRANSCEND_API_KEY --partition=4d1c5daa-90b7-4d18-aa40-f86a43d2c726
```

Upload consent preferences with additional options

```sh
yarn tr-upload-preferences --auth=$TRANSCEND_API_KEY --partition=4d1c5daa-90b7-4d18-aa40-f86a43d2c726 --file=./preferences.csv --dryRun=true --skipWorkflowTriggers=true --skipConflictUpdates=true --isSilent=false --attributes="Tags:transcend-cli,Source:transcend-cli" --receiptFilepath=./preference-management-upload-receipts.json
```

Specifying the backend URL, needed for US hosted backend infrastructure.

```sh
yarn tr-upload-preferences --auth=$TRANSCEND_API_KEY --partition=4d1c5daa-90b7-4d18-aa40-f86a43d2c726 --transcendUrl=https://consent.us.transcend.io
```

### tr-upload-consent-preferences

This command allows for updating of consent preferences to the [Managed Consent Database](https://docs.transcend.io/docs/consent/reference/managed-consent-database).
Expand Down
9 changes: 6 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"author": "Transcend Inc.",
"name": "@transcend-io/cli",
"description": "Small package containing useful typescript utilities.",
"version": "6.9.0",
"version": "6.10.0",
"homepage": "https://github.com/transcend-io/cli",
"repository": {
"type": "git",
Expand Down Expand Up @@ -44,7 +44,8 @@
"tr-update-consent-manager": "./build/cli-update-consent-manager-to-latest.js",
"tr-upload-consent-preferences": "./build/cli-upload-consent-preferences.js",
"tr-upload-cookies-from-csv": "./build/cli-upload-cookies-from-csv.js",
"tr-upload-data-flows-from-csv": "./build/cli-upload-data-flows-from-csv.js"
"tr-upload-data-flows-from-csv": "./build/cli-upload-data-flows-from-csv.js",
"tr-upload-preferences": "./build/cli-upload-preferences.js"
},
"files": [
"build/**/*",
Expand All @@ -66,7 +67,7 @@
"@transcend-io/handlebars-utils": "^1.1.0",
"@transcend-io/internationalization": "^1.6.0",
"@transcend-io/persisted-state": "^1.0.4",
"@transcend-io/privacy-types": "^4.94.0",
"@transcend-io/privacy-types": "^4.98.0",
"@transcend-io/secret-value": "^1.2.0",
"@transcend-io/type-utils": "^1.5.0",
"bluebird": "^3.7.2",
Expand Down Expand Up @@ -99,6 +100,7 @@
"@types/chai": "^4.3.4",
"@types/cli-progress": "^3.11.0",
"@types/colors": "^1.2.1",
"@types/deep-equal-in-any-order": "1.0.1",
"@types/fuzzysearch": "^1.0.0",
"@types/global-agent": "^2.1.1",
"@types/inquirer": "^7.3.1",
Expand All @@ -115,6 +117,7 @@
"@typescript-eslint/parser": "^5.58.0",
"@yarnpkg/sdks": "^3.0.0-rc.42",
"chai": "^4.3.7",
"deep-equal-in-any-order": "^1.0.28",
"depcheck": "^1.4.3",
"eslint": "^8.38.0",
"eslint-config-airbnb-base": "^15.0.0",
Expand Down
2 changes: 1 addition & 1 deletion src/cli-request-upload.ts
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ async function main(): Promise<void> {
skipSendingReceipt: skipSendingReceipt === 'true',
emailIsVerified: emailIsVerified === 'true',
isTest: isTest === 'true',
dryRun: dryRun === 'true',
dryRun: dryRun !== 'false',
});
}

Expand Down
4 changes: 2 additions & 2 deletions src/cli-upload-consent-preferences.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import colors from 'colors';

import { logger } from './logger';
import { DEFAULT_TRANSCEND_CONSENT_API } from './constants';
import { uploadConsentPreferences } from './consent-manager/uploadConsentPreferences';
import { uploadConsents } from './consent-manager/uploadConsents';
import { ConsentPreferenceUpload } from './consent-manager/types';
import { readCsv } from './requests';

Expand Down Expand Up @@ -75,7 +75,7 @@ async function main(): Promise<void> {
const preferences = readCsv(file, ConsentPreferenceUpload);

// Upload cookies
await uploadConsentPreferences({
await uploadConsents({
base64EncryptionKey,
base64SigningKey,
preferences,
Expand Down
Loading

0 comments on commit 7fefa49

Please sign in to comment.