From fff9f4cd4c227951e26840b55492f74421f39c6a Mon Sep 17 00:00:00 2001 From: Masaya Sonobe Date: Mon, 6 Nov 2023 15:57:46 +0900 Subject: [PATCH 1/2] Fix setApiKey and setTwilioEmailAuth to prevent overwriting baseUrl --- packages/client/src/classes/client.js | 5 +++-- packages/client/src/client.spec.js | 17 +++++++++++++++++ 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/packages/client/src/classes/client.js b/packages/client/src/classes/client.js index c91768d4d..1497ae1d8 100644 --- a/packages/client/src/classes/client.js +++ b/packages/client/src/classes/client.js @@ -38,7 +38,6 @@ class Client { setApiKey(apiKey) { this.auth = 'Bearer ' + apiKey; - this.setDefaultRequest('baseUrl', SENDGRID_BASE_URL); if (!this.isValidApiKey(apiKey)) { console.warn(`API key does not start with "${API_KEY_PREFIX}".`); @@ -48,7 +47,9 @@ class Client { setTwilioEmailAuth(username, password) { const b64Auth = Buffer.from(username + ':' + password).toString('base64'); this.auth = 'Basic ' + b64Auth; - this.setDefaultRequest('baseUrl', TWILIO_BASE_URL); + if (this.defaultRequest.baseUrl === SENDGRID_BASE_URL) { + this.setDefaultRequest('baseUrl', TWILIO_BASE_URL); + } if (!this.isValidTwilioAuth(username, password)) { console.warn('Twilio Email credentials must be non-empty strings.'); diff --git a/packages/client/src/client.spec.js b/packages/client/src/client.spec.js index 65e0e5997..9a526f173 100644 --- a/packages/client/src/client.spec.js +++ b/packages/client/src/client.spec.js @@ -106,6 +106,23 @@ describe('setImpersonateSubuser', () => { }); }); +describe('setDefaultRequest', () => { + const customBaseUrl = 'localhost:3030'; + const sgClient = require('./client'); + + it('should set the custom base URL without being overwritten by setApiKey', () => { + sgClient.setDefaultRequest('baseUrl', customBaseUrl); + sgClient.setApiKey('SG\.1234567890'); + expect(sgClient.defaultRequest.baseUrl).to.equal(customBaseUrl); + }); + + it('should set the custom base URL without being overwritten by setTwilioEmailAuth', () => { + sgClient.setDefaultRequest('baseUrl', customBaseUrl); + sgClient.setTwilioEmailAuth('username', 'password'); + expect(sgClient.defaultRequest.baseUrl).to.equal(customBaseUrl); + }); +}); + describe('test_access_settings_activity_get', () => { const request = {}; request.qs = { From 6ec293bf41553de81c334736b17986ee5e43c1c4 Mon Sep 17 00:00:00 2001 From: be3 Date: Thu, 30 Nov 2023 00:36:19 +0900 Subject: [PATCH 2/2] Add inline documentation --- packages/client/src/classes/client.js | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/client/src/classes/client.js b/packages/client/src/classes/client.js index 1497ae1d8..f09142b9d 100644 --- a/packages/client/src/classes/client.js +++ b/packages/client/src/classes/client.js @@ -47,6 +47,7 @@ class Client { setTwilioEmailAuth(username, password) { const b64Auth = Buffer.from(username + ':' + password).toString('base64'); this.auth = 'Basic ' + b64Auth; + // Prevent implicit overwriting if baseUrl is not the default value if (this.defaultRequest.baseUrl === SENDGRID_BASE_URL) { this.setDefaultRequest('baseUrl', TWILIO_BASE_URL); }