From 79fb96b5815d431ebc6b175b06ddd82cdbb121c1 Mon Sep 17 00:00:00 2001 From: Shikhar Tanwar Date: Thu, 15 Jun 2023 18:38:05 +0530 Subject: [PATCH] Fix difference between integration types and corresponding json keys (#62) * Fix difference between integration types and corresponding json keys - For integration_type: 'service', console stores the credential config corresponding to 'jwt' key - For integration_type: 'oauth_server_to_server', console stores the credential config corresponding to 'oauth_server_to_server' key - For integration_type: 'oauth_server_to_server_migrate', console has both 'jwt' and 'oauth_server_to_server` credentials but we fetch details from 'oauth_server_to_server' key * Fix failing tests --------- Co-authored-by: Shikhar Tanwar --- src/BaseCommand.js | 14 ++++++++++---- test/BaseCommand.test.js | 4 ++-- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/src/BaseCommand.js b/src/BaseCommand.js index 8247c07..9b0ab4a 100644 --- a/src/BaseCommand.js +++ b/src/BaseCommand.js @@ -25,8 +25,14 @@ const CONSOLE_CONFIG_KEY = 'console' const CONSOLE_API_KEY = 'aio-cli-console-auth' const EVENTS_CONFIG_KEY = 'events' const JWT_INTEGRATION_TYPE = 'service' +const JWT_JSON_KEY = 'jwt' const OAUTH_SERVER_TO_SERVER_INTEGRATION_TYPE = 'oauth_server_to_server' const OAUTH_SERVER_TO_SERVER_MIGRATE_INTEGRATION_TYPE = 'oauth_server_to_server_migrate' +const INTEGRATION_TYPES_TO_JSON_KEYS_MAP = { + [OAUTH_SERVER_TO_SERVER_INTEGRATION_TYPE]: OAUTH_SERVER_TO_SERVER_INTEGRATION_TYPE, + [OAUTH_SERVER_TO_SERVER_MIGRATE_INTEGRATION_TYPE]: OAUTH_SERVER_TO_SERVER_INTEGRATION_TYPE, + [JWT_INTEGRATION_TYPE]: JWT_JSON_KEY +} class BaseCommand extends Command { async initSdk () { @@ -95,10 +101,11 @@ class BaseCommand extends Command { const consoleJSON = await consoleClient.downloadWorkspaceJson(org.id, project.id, workspace.id) const workspaceIntegration = this.extractServiceIntegrationConfig(consoleJSON.body.project.workspace) const integrationType = workspaceIntegration.integration_type + const credentialJsonKey = INTEGRATION_TYPES_TO_JSON_KEYS_MAP[integrationType] integration = { id: workspaceIntegration.id, name: workspaceIntegration.name, - clientId: workspaceIntegration[integrationType].client_id + clientId: workspaceIntegration[credentialJsonKey].client_id } // cache the integration details for future use @@ -128,9 +135,8 @@ class BaseCommand extends Command { // note here we take the first that matches const workspaceIntegration = workspaceConfig.details.credentials && workspaceConfig.details.credentials.find(c => { - return c.integration_type === OAUTH_SERVER_TO_SERVER_INTEGRATION_TYPE || - c.integration_type === OAUTH_SERVER_TO_SERVER_MIGRATE_INTEGRATION_TYPE || - c.integration_type === JWT_INTEGRATION_TYPE + return Object.keys(INTEGRATION_TYPES_TO_JSON_KEYS_MAP) + .includes(c.integration_type) }) if (!workspaceIntegration) { throw new Error(this.getErrorMessageForInvalidCredentials(workspaceConfig.name)) diff --git a/test/BaseCommand.test.js b/test/BaseCommand.test.js index cd2a24f..ef4d34f 100644 --- a/test/BaseCommand.test.js +++ b/test/BaseCommand.test.js @@ -140,7 +140,7 @@ describe('initSDK', () => { id: _validConfig.integration.id, name: _validConfig.integration.name, integration_type: 'service', - service: { client_id: _validConfig.integration.clientId } + jwt: { client_id: _validConfig.integration.clientId } } ] } @@ -176,7 +176,7 @@ describe('initSDK', () => { id: _validConfig.integration.id, name: _validConfig.integration.name, integration_type: 'service', - service: { client_id: _validConfig.integration.clientId } + jwt: { client_id: _validConfig.integration.clientId } } ] }