From 7fecc4ec94dbac19d364aa2a878f9139424c0b16 Mon Sep 17 00:00:00 2001 From: shafeeqd959 Date: Tue, 19 Dec 2023 17:03:18 +0530 Subject: [PATCH 01/31] added early access support in http client --- packages/contentstack-audit/README.md | 2 +- packages/contentstack-audit/package.json | 2 +- packages/contentstack-auth/package.json | 2 +- packages/contentstack-bootstrap/package.json | 2 +- packages/contentstack-branches/package.json | 2 +- .../contentstack-bulk-publish/package.json | 2 +- packages/contentstack-clone/package.json | 2 +- packages/contentstack-command/package.json | 2 +- packages/contentstack-config/README.md | 30 +++++------ packages/contentstack-config/package.json | 4 +- .../config/set/early-access-header.ts | 4 +- .../contentstack-export-to-csv/package.json | 2 +- packages/contentstack-export/package.json | 4 +- packages/contentstack-import/package.json | 2 +- packages/contentstack-launch/package.json | 4 +- .../contentstack-migrate-rte/package.json | 2 +- packages/contentstack-migration/package.json | 2 +- packages/contentstack-seed/package.json | 2 +- packages/contentstack-utilities/package.json | 4 +- .../src/http-client/client.ts | 52 ++++++++++++++++--- packages/contentstack/README.md | 44 ++++++++-------- packages/contentstack/package.json | 8 +-- 22 files changed, 108 insertions(+), 72 deletions(-) diff --git a/packages/contentstack-audit/README.md b/packages/contentstack-audit/README.md index 8bdbbb628d..ab0b78aee9 100644 --- a/packages/contentstack-audit/README.md +++ b/packages/contentstack-audit/README.md @@ -19,7 +19,7 @@ $ npm install -g @contentstack/cli-audit $ csdx COMMAND running command... $ csdx (--version|-v) -@contentstack/cli-audit/1.3.0 darwin-arm64 node-v20.8.0 +@contentstack/cli-audit/1.3.1 darwin-arm64 node-v20.8.0 $ csdx --help [COMMAND] USAGE $ csdx COMMAND diff --git a/packages/contentstack-audit/package.json b/packages/contentstack-audit/package.json index 1412682711..7bf6ff5380 100644 --- a/packages/contentstack-audit/package.json +++ b/packages/contentstack-audit/package.json @@ -19,7 +19,7 @@ ], "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "@oclif/plugin-help": "^5", "@oclif/plugin-plugins": "^4.1.9", "chalk": "^4.1.2", diff --git a/packages/contentstack-auth/package.json b/packages/contentstack-auth/package.json index ef27bae5b7..4af4afb1c6 100644 --- a/packages/contentstack-auth/package.json +++ b/packages/contentstack-auth/package.json @@ -23,7 +23,7 @@ }, "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "chalk": "^4.0.0", "debug": "^4.1.1", "inquirer": "8.2.4", diff --git a/packages/contentstack-bootstrap/package.json b/packages/contentstack-bootstrap/package.json index 5d7767b8f5..9b07d8bb3b 100644 --- a/packages/contentstack-bootstrap/package.json +++ b/packages/contentstack-bootstrap/package.json @@ -19,7 +19,7 @@ "dependencies": { "@contentstack/cli-cm-seed": "~1.7.0", "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "inquirer": "8.2.4", "mkdirp": "^1.0.4", "tar": "^6.1.13" diff --git a/packages/contentstack-branches/package.json b/packages/contentstack-branches/package.json index c085e73c4b..f9fe694229 100644 --- a/packages/contentstack-branches/package.json +++ b/packages/contentstack-branches/package.json @@ -6,7 +6,7 @@ "bugs": "https://github.com/contentstack/cli/issues", "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "@oclif/core": "^2.9.3", "async": "^3.2.4", "big-json": "^3.2.0", diff --git a/packages/contentstack-bulk-publish/package.json b/packages/contentstack-bulk-publish/package.json index 356739dc1c..f7c1d65b0b 100644 --- a/packages/contentstack-bulk-publish/package.json +++ b/packages/contentstack-bulk-publish/package.json @@ -6,7 +6,7 @@ "bugs": "https://github.com/contentstack/cli/issues", "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "bluebird": "^3.7.2", "chalk": "^4.1.2", "dotenv": "^16.1.4", diff --git a/packages/contentstack-clone/package.json b/packages/contentstack-clone/package.json index 7db139c301..e0d7614279 100644 --- a/packages/contentstack-clone/package.json +++ b/packages/contentstack-clone/package.json @@ -8,7 +8,7 @@ "@contentstack/cli-cm-export": "~1.10.2", "@contentstack/cli-cm-import": "~1.12.2", "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "@colors/colors": "^1.5.0", "async": "^3.2.4", "chalk": "^4.1.0", diff --git a/packages/contentstack-command/package.json b/packages/contentstack-command/package.json index c4150ff6ca..716ba3e8ac 100644 --- a/packages/contentstack-command/package.json +++ b/packages/contentstack-command/package.json @@ -17,7 +17,7 @@ "format": "eslint src/**/*.ts --fix" }, "dependencies": { - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "contentstack": "^3.10.1" }, "devDependencies": { diff --git a/packages/contentstack-config/README.md b/packages/contentstack-config/README.md index 3421b3e805..f9fd176b04 100644 --- a/packages/contentstack-config/README.md +++ b/packages/contentstack-config/README.md @@ -18,7 +18,7 @@ $ npm install -g @contentstack/cli-config $ csdx COMMAND running command... $ csdx (--version) -@contentstack/cli-config/1.5.0 darwin-arm64 node-v20.8.0 +@contentstack/cli-config/1.5.1 darwin-arm64 node-v20.8.0 $ csdx --help [COMMAND] USAGE $ csdx COMMAND @@ -60,14 +60,14 @@ _See code: [src/commands/config/get/base-branch.ts](https://github.com/contentst ## `csdx config:get:ea-header` -Display early access headers +Display Early Access Program headers ``` USAGE $ csdx config:get:ea-header DESCRIPTION - Display early access headers + Display Early Access Program headers ALIASES $ csdx config:get:ea-header @@ -78,14 +78,14 @@ EXAMPLES ## `csdx config:get:early-access-header` -Display early access headers +Display Early Access Program headers ``` USAGE $ csdx config:get:early-access-header DESCRIPTION - Display early access headers + Display Early Access Program headers ALIASES $ csdx config:get:ea-header @@ -138,7 +138,7 @@ _See code: [src/commands/config/remove/base-branch.ts](https://github.com/conten ## `csdx config:remove:ea-header` -Remove early access header +Remove Early Access Program header ``` USAGE @@ -149,7 +149,7 @@ FLAGS --header-alias= Early access header alias DESCRIPTION - Remove early access header + Remove Early Access Program header ALIASES $ csdx config:remove:ea-header @@ -162,7 +162,7 @@ EXAMPLES ## `csdx config:remove:early-access-header` -Remove early access header +Remove Early Access Program header ``` USAGE @@ -173,7 +173,7 @@ FLAGS --header-alias= Early access header alias DESCRIPTION - Remove early access header + Remove Early Access Program header ALIASES $ csdx config:remove:ea-header @@ -211,7 +211,7 @@ _See code: [src/commands/config/set/base-branch.ts](https://github.com/contentst ## `csdx config:set:ea-header` -Set early access header +Set Early Access Program header ``` USAGE @@ -219,10 +219,10 @@ USAGE FLAGS --header= Early access header value - --header-alias= Alias for the header + --header-alias= Early access header alias DESCRIPTION - Set early access header + Set Early Access Program header ALIASES $ csdx config:set:ea-header @@ -235,7 +235,7 @@ EXAMPLES ## `csdx config:set:early-access-header` -Set early access header +Set Early Access Program header ``` USAGE @@ -243,10 +243,10 @@ USAGE FLAGS --header= Early access header value - --header-alias= Alias for the header + --header-alias= Early access header alias DESCRIPTION - Set early access header + Set Early Access Program header ALIASES $ csdx config:set:ea-header diff --git a/packages/contentstack-config/package.json b/packages/contentstack-config/package.json index fa72150a28..0ebe6c6737 100644 --- a/packages/contentstack-config/package.json +++ b/packages/contentstack-config/package.json @@ -1,7 +1,7 @@ { "name": "@contentstack/cli-config", "description": "Contentstack CLI plugin for configuration", - "version": "1.5.0", + "version": "1.5.1", "author": "Contentstack", "scripts": { "build": "npm run clean && npm run compile", @@ -22,7 +22,7 @@ }, "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "chalk": "^4.0.0", "debug": "^4.1.1", "inquirer": "8.2.4", diff --git a/packages/contentstack-config/src/commands/config/set/early-access-header.ts b/packages/contentstack-config/src/commands/config/set/early-access-header.ts index eb5f2f9b06..f63d40c9ee 100644 --- a/packages/contentstack-config/src/commands/config/set/early-access-header.ts +++ b/packages/contentstack-config/src/commands/config/set/early-access-header.ts @@ -20,10 +20,10 @@ export default class SetEarlyAccessHeaderCommand extends Command { flags: { header: earlyAccessHeader, 'header-alias': earlyAccessHeaderAlias }, } = await this.parse(SetEarlyAccessHeaderCommand); if (!earlyAccessHeaderAlias) { - earlyAccessHeaderAlias = await interactive.askEarlyAccessHeaderAlias(); + earlyAccessHeaderAlias = (await interactive.askEarlyAccessHeaderAlias())?.trim(); } if (!earlyAccessHeader) { - earlyAccessHeader = await interactive.askEarlyAccessHeaderValue(); + earlyAccessHeader = (await interactive.askEarlyAccessHeaderValue())?.trim(); } configHandler.set(`earlyAccessHeaders.${earlyAccessHeaderAlias}`, earlyAccessHeader); cliux.success( diff --git a/packages/contentstack-export-to-csv/package.json b/packages/contentstack-export-to-csv/package.json index e7c0e21de2..1fae8312a8 100644 --- a/packages/contentstack-export-to-csv/package.json +++ b/packages/contentstack-export-to-csv/package.json @@ -6,7 +6,7 @@ "bugs": "https://github.com/contentstack/cli/issues", "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "chalk": "^4.1.0", "fast-csv": "^4.3.6", "inquirer": "8.2.4", diff --git a/packages/contentstack-export/package.json b/packages/contentstack-export/package.json index 23b84d85bf..5c2874f7be 100644 --- a/packages/contentstack-export/package.json +++ b/packages/contentstack-export/package.json @@ -6,7 +6,7 @@ "bugs": "https://github.com/contentstack/cli/issues", "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "@oclif/core": "^2.9.3", "async": "^3.2.4", "big-json": "^3.2.0", @@ -98,4 +98,4 @@ } }, "repository": "https://github.com/contentstack/cli" -} +} \ No newline at end of file diff --git a/packages/contentstack-import/package.json b/packages/contentstack-import/package.json index a5435bf7ab..6da5117134 100644 --- a/packages/contentstack-import/package.json +++ b/packages/contentstack-import/package.json @@ -6,7 +6,7 @@ "bugs": "https://github.com/contentstack/cli/issues", "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "@contentstack/management": "~1.13.0", "@oclif/core": "^2.9.3", "axios": "^1.6.0", diff --git a/packages/contentstack-launch/package.json b/packages/contentstack-launch/package.json index a885e441a8..76389cf34a 100755 --- a/packages/contentstack-launch/package.json +++ b/packages/contentstack-launch/package.json @@ -19,7 +19,7 @@ "dependencies": { "@apollo/client": "^3.7.9", "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "@oclif/core": "^2.9.3", "@oclif/plugin-help": "^5", "@oclif/plugin-plugins": "^4.1.9", @@ -105,4 +105,4 @@ "launch:deployments": "LNCH-DPLMNT" } } -} +} \ No newline at end of file diff --git a/packages/contentstack-migrate-rte/package.json b/packages/contentstack-migrate-rte/package.json index ea0b71e591..c0e4cf86b1 100644 --- a/packages/contentstack-migrate-rte/package.json +++ b/packages/contentstack-migrate-rte/package.json @@ -6,7 +6,7 @@ "bugs": "https://github.com/contentstack/cli/issues", "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "@contentstack/json-rte-serializer": "~2.0.4", "collapse-whitespace": "^1.1.7", "chalk": "^4.1.2", diff --git a/packages/contentstack-migration/package.json b/packages/contentstack-migration/package.json index d5dfe6add3..fcb26548c8 100644 --- a/packages/contentstack-migration/package.json +++ b/packages/contentstack-migration/package.json @@ -5,7 +5,7 @@ "bugs": "https://github.com/contentstack/cli/issues", "dependencies": { "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "async": "^3.2.4", "callsites": "^3.1.0", "cardinal": "^2.1.1", diff --git a/packages/contentstack-seed/package.json b/packages/contentstack-seed/package.json index ba9b796186..5ebadf20a8 100644 --- a/packages/contentstack-seed/package.json +++ b/packages/contentstack-seed/package.json @@ -7,7 +7,7 @@ "dependencies": { "@contentstack/cli-cm-import": "~1.12.2", "@contentstack/cli-command": "~1.2.16", - "@contentstack/cli-utilities": "~1.5.9", + "@contentstack/cli-utilities": "~1.5.10", "inquirer": "8.2.4", "mkdirp": "^1.0.4", "tar": "^6.1.13", diff --git a/packages/contentstack-utilities/package.json b/packages/contentstack-utilities/package.json index bbb5373429..691f2a40ec 100644 --- a/packages/contentstack-utilities/package.json +++ b/packages/contentstack-utilities/package.json @@ -1,6 +1,6 @@ { "name": "@contentstack/cli-utilities", - "version": "1.5.9", + "version": "1.5.10", "description": "Utilities for contentstack projects", "main": "lib/index.js", "types": "lib/index.d.ts", @@ -83,4 +83,4 @@ "tslib": "^1.13.0", "typescript": "^4.9.3" } -} +} \ No newline at end of file diff --git a/packages/contentstack-utilities/src/http-client/client.ts b/packages/contentstack-utilities/src/http-client/client.ts index 7db8321b52..323cfd97d1 100644 --- a/packages/contentstack-utilities/src/http-client/client.ts +++ b/packages/contentstack-utilities/src/http-client/client.ts @@ -4,6 +4,9 @@ import { HttpResponse } from './http-response'; import configStore from '../config-handler'; import authHandler from '../auth-handler'; +type HttpClientOptions = { + disableEarlyAccessHeaders?: boolean; +}; export class HttpClient implements IHttpClient { /** * The request configuration. @@ -15,6 +18,8 @@ export class HttpClient implements IHttpClient { */ private readonly axiosInstance: AxiosInstance; + private disableEarlyAccessHeaders: boolean; + /** * The payload format for a JSON or form-url-encoded request. */ @@ -23,9 +28,10 @@ export class HttpClient implements IHttpClient { /** * Createa new pending HTTP request instance. */ - constructor(request: AxiosRequestConfig = {}) { + constructor(request: AxiosRequestConfig = {}, options: HttpClientOptions = {}) { this.request = request; this.axiosInstance = Axios.create(); + this.disableEarlyAccessHeaders = options.disableEarlyAccessHeaders || false; // Sets payload format as json by default this.asJson(); @@ -351,24 +357,53 @@ export class HttpClient implements IHttpClient { */ async createAndSendRequest(method: HttpMethod, url: string): Promise { let counter = 0; - this.axiosInstance.interceptors.response.use(null, async error => { + this.axiosInstance.interceptors.response.use(null, async (error) => { const { message, response } = error; if (response?.data?.error_message?.includes('access token is invalid or expired')) { const token = await this.refreshToken(); this.headers({ ...this.request.headers, authorization: token.authorization }); - return await this.axiosInstance({ url, method, withCredentials: true, ...this.request, data: this.prepareRequestPayload(), }) + return await this.axiosInstance({ + url, + method, + withCredentials: true, + ...this.request, + data: this.prepareRequestPayload(), + }); } // Retry while Network timeout or Network Error - if (!(message.includes('timeout') || message.includes('Network Error') || message.includes('getaddrinfo ENOTFOUND'))) { + if ( + !(message.includes('timeout') || message.includes('Network Error') || message.includes('getaddrinfo ENOTFOUND')) + ) { return Promise.reject(error); } if (counter < 1) { counter++; - return await this.axiosInstance({ url, method, withCredentials: true, ...this.request, data: this.prepareRequestPayload(), }) + return await this.axiosInstance({ + url, + method, + withCredentials: true, + ...this.request, + data: this.prepareRequestPayload(), + }); } return Promise.reject(error); }); - return await this.axiosInstance({ url, method, withCredentials: true, ...this.request, data: this.prepareRequestPayload(), }) + + if (!this.disableEarlyAccessHeaders) { + // Add early access header by default + const earlyAccessHeaders = configStore.get(`earlyAccessHeaders`); + if (earlyAccessHeaders && Object.keys(earlyAccessHeaders).length > 0) { + this.headers({ 'x-header-ea': Object.values(earlyAccessHeaders).join(',') }); + } + } + + return await this.axiosInstance({ + url, + method, + withCredentials: true, + ...this.request, + data: this.prepareRequestPayload(), + }); } /** @@ -383,8 +418,9 @@ export class HttpClient implements IHttpClient { if (authorisationType === 'BASIC') { return Promise.reject('Your session is timed out, please login to proceed'); } else if (authorisationType === 'OAUTH') { - return authHandler.compareOAuthExpiry(true) - .then(() => Promise.resolve({ authorization: `Bearer ${configStore.get('oauthAccessToken')}`, })) + return authHandler + .compareOAuthExpiry(true) + .then(() => Promise.resolve({ authorization: `Bearer ${configStore.get('oauthAccessToken')}` })) .catch((error) => Promise.reject(error)); } else { return Promise.reject('You do not have permissions to perform this action, please login to proceed'); diff --git a/packages/contentstack/README.md b/packages/contentstack/README.md index ddb48aeb3b..ff09a87ddd 100644 --- a/packages/contentstack/README.md +++ b/packages/contentstack/README.md @@ -18,7 +18,7 @@ $ npm install -g @contentstack/cli $ csdx COMMAND running command... $ csdx (--version|-v) -@contentstack/cli/1.12.0 darwin-arm64 node-v20.8.0 +@contentstack/cli/1.12.1 darwin-arm64 node-v20.8.0 $ csdx --help [COMMAND] USAGE $ csdx COMMAND @@ -2958,14 +2958,14 @@ _See code: [@contentstack/cli-config](https://github.com/contentstack/cli/blob/m ## `csdx config:get:ea-header` -Display early access headers +Display Early Access Program headers ``` USAGE $ csdx config:get:ea-header DESCRIPTION - Display early access headers + Display Early Access Program headers ALIASES $ csdx config:get:ea-header @@ -2976,14 +2976,14 @@ EXAMPLES ## `csdx config:get:early-access-header` -Display early access headers +Display Early Access Program headers ``` USAGE $ csdx config:get:early-access-header DESCRIPTION - Display early access headers + Display Early Access Program headers ALIASES $ csdx config:get:ea-header @@ -3036,7 +3036,7 @@ _See code: [@contentstack/cli-config](https://github.com/contentstack/cli/blob/m ## `csdx config:remove:ea-header` -Remove early access header +Remove Early Access Program header ``` USAGE @@ -3047,7 +3047,7 @@ FLAGS --header-alias= Early access header alias DESCRIPTION - Remove early access header + Remove Early Access Program header ALIASES $ csdx config:remove:ea-header @@ -3060,7 +3060,7 @@ EXAMPLES ## `csdx config:remove:early-access-header` -Remove early access header +Remove Early Access Program header ``` USAGE @@ -3071,7 +3071,7 @@ FLAGS --header-alias= Early access header alias DESCRIPTION - Remove early access header + Remove Early Access Program header ALIASES $ csdx config:remove:ea-header @@ -3109,7 +3109,7 @@ _See code: [@contentstack/cli-config](https://github.com/contentstack/cli/blob/m ## `csdx config:set:ea-header` -Set early access header +Set Early Access Program header ``` USAGE @@ -3117,10 +3117,10 @@ USAGE FLAGS --header= Early access header value - --header-alias= Alias for the header + --header-alias= Early access header alias DESCRIPTION - Set early access header + Set Early Access Program header ALIASES $ csdx config:set:ea-header @@ -3133,7 +3133,7 @@ EXAMPLES ## `csdx config:set:early-access-header` -Set early access header +Set Early Access Program header ``` USAGE @@ -3141,10 +3141,10 @@ USAGE FLAGS --header= Early access header value - --header-alias= Alias for the header + --header-alias= Early access header alias DESCRIPTION - Set early access header + Set Early Access Program header ALIASES $ csdx config:set:ea-header @@ -3213,7 +3213,7 @@ DESCRIPTION Display help for csdx. ``` -_See code: [@oclif/plugin-help](https://github.com/oclif/plugin-help/blob/v5.2.20/src/commands/help.ts)_ +_See code: [@oclif/plugin-help](https://github.com/oclif/plugin-help/blob/v5.2.14/src/commands/help.ts)_ ## `csdx launch` @@ -3258,7 +3258,7 @@ EXAMPLES $ csdx launch --config --type --name= --environment= --branch= --build-command= --framework=