From 37e3715aece33a945f2e6c239c45e9f947c1342a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebasti=C3=A1n=20E=2E=20Peyrott?= Date: Fri, 5 Feb 2021 15:29:12 -0300 Subject: [PATCH] ULP-2609: add page templates support to /branding (#574) --- src/management/BrandingManager.js | 79 ++++++++++ src/management/index.js | 66 ++++++++ test/management/branding.tests.js | 240 ++++++++++++++++++++++++++++++ 3 files changed, 385 insertions(+) diff --git a/src/management/BrandingManager.js b/src/management/BrandingManager.js index a537d6cae..42609bdfb 100644 --- a/src/management/BrandingManager.js +++ b/src/management/BrandingManager.js @@ -51,6 +51,19 @@ var BrandingManager = function(options) { options.tokenProvider ); this.resource = new RetryRestClient(auth0RestClient, options.retry); + + /** + * Provides an abstraction layer for consuming the + * {@link https://auth0.com/docs/api/management/v2#!/Branding/get_universal_login Branding new universal login template endpoint}. + * + * @type {external:RestClient} + */ + var brandingTemplateAuth0RestClient = new Auth0RestClient( + options.baseUrl + '/branding/templates/universal-login', + clientOptions, + options.tokenProvider + ); + this.brandingTemplates = new RetryRestClient(brandingTemplateAuth0RestClient, options.retry); }; /** @@ -101,4 +114,70 @@ utils.wrapPropertyMethod(BrandingManager, 'updateSettings', 'resource.patch'); */ utils.wrapPropertyMethod(BrandingManager, 'getSettings', 'resource.get'); +/** + * Get the new universal login template. + * + * @method getUniversalLoginTemplate + * @memberOf module:management.BrandingManager.prototype + * + * @example + * management.branding.getUniversalLoginTemplate(data, function (err, template) { + * if (err) { + * // Handle error. + * } + * + * // Branding + * console.log(template); + * }); + * + * @param {Object} params Branding parameters (leave empty). + * @param {Object} data Branding data (leave empty). + * @param {Function} [cb] Callback function. + * + * @return {Promise|undefined} + */ +utils.wrapPropertyMethod(BrandingManager, 'getUniversalLoginTemplate', 'brandingTemplates.get'); + +/** + * Set the new universal login template. + * + * @method setUniversalLoginTemplate + * @memberOf module:management.BrandingManager.prototype + * + * @example + * management.branding.setUniversalLoginTemplate({ template: "a template" }, function (err) { + * if (err) { + * // Handle error. + * } + * }); + * + * @param {Object} params Branding parameters (leavy empty). + * @param {Object} data Branding data (object with template field). + * @param {Function} [cb] Callback function. + * + * @return {Promise|undefined} + */ +utils.wrapPropertyMethod(BrandingManager, 'setUniversalLoginTemplate', 'brandingTemplates.update'); + +/** + * Delete the new universal login template (revert to default). + * + * @method deleteUniversalLoginTemplate + * @memberOf module:management.BrandingManager.prototype + * + * @example + * management.branding.deleteUniversalLoginTemplate(data, function (err) { + * if (err) { + * // Handle error. + * } + * }); + * + * @param {Object} params Branding parameters (leavy empty). + * @param {Object} data Branding data (leave empty). + * @param {Function} [cb] Callback function. + * + * @return {Promise|undefined} + */ +utils.wrapPropertyMethod(BrandingManager, 'deleteUniversalLoginTemplate', 'brandingTemplates.delete'); + module.exports = BrandingManager; diff --git a/src/management/index.js b/src/management/index.js index 1dfac641d..95cfd4522 100644 --- a/src/management/index.js +++ b/src/management/index.js @@ -3651,6 +3651,72 @@ utils.wrapPropertyMethod(ManagementClient, 'updateBrandingSettings', 'branding.u */ utils.wrapPropertyMethod(ManagementClient, 'getBrandingSettings', 'branding.getSettings'); +/** + * Get the new universal login template. + * + * @method getBrandingUniversalLoginTemplate + * @memberOf module:management.ManagementClient.prototype + * + * @example + * management.getBrandingUniversalLoginTemplate(data, function (err, template) { + * if (err) { + * // Handle error. + * } + * + * // Branding + * console.log(template); + * }); + * + * @param {Object} params Branding parameters (leave empty). + * @param {Object} data Branding data (leave empty). + * @param {Function} [cb] Callback function. + * + * @return {Promise|undefined} + */ +utils.wrapPropertyMethod(ManagementClient, 'getBrandingUniversalLoginTemplate', 'branding.getUniversalLoginTemplate'); + +/** + * Get the new universal login template. + * + * @method setBrandingUniversalLoginTemplate + * @memberOf module:management.ManagementClient.prototype + * + * @example + * management.setBrandingUniversalLoginTemplate({ template: "a template" }, function (err, template) { + * if (err) { + * // Handle error. + * } + * }); + * + * @param {Object} params Branding parameters (leave empty). + * @param {Object} template Branding data (object with template field). + * @param {Function} [cb] Callback function. + * + * @return {Promise|undefined} + */ +utils.wrapPropertyMethod(ManagementClient, 'setBrandingUniversalLoginTemplate', 'branding.setUniversalLoginTemplate'); + +/** + * Delete the new universal login template. + * + * @method deleteBrandingUniversalLoginTemplate + * @memberOf module:management.ManagementClient.prototype + * + * @example + * management.deleteBrandingUniversalLoginTemplate(template, function (err) { + * if (err) { + * // Handle error. + * } + * }); + * + * @param {Object} params Branding parameters (leave empty). + * @param {Object} data Branding data (leave empty). + * @param {Function} [cb] Callback function. + * + * @return {Promise|undefined} + */ +utils.wrapPropertyMethod(ManagementClient, 'deleteBrandingUniversalLoginTemplate', 'branding.deleteUniversalLoginTemplate'); + /** * Update the tenant migrations. * diff --git a/test/management/branding.tests.js b/test/management/branding.tests.js index 103559ce7..e8c69c59c 100644 --- a/test/management/branding.tests.js +++ b/test/management/branding.tests.js @@ -233,4 +233,244 @@ describe('BrandingManager', function() { }); }); }); + + describe('#getUniversalLoginTemplate', function() { + beforeEach(function() { + this.request = nock(API_URL) + .get('/branding/templates/universal-login') + .reply(200); + }); + + afterEach(function() { + nock.cleanAll(); + }); + + it('should accept a callback', function(done) { + this.branding.getUniversalLoginTemplate(function() { + done(); + }); + }); + + it('should return a promise if no callback is given', function(done) { + this.branding + .getUniversalLoginTemplate() + .then(done.bind(null, null)) + .catch(done.bind(null, null)); + }); + + it('should pass any errors to the promise catch handler', function(done) { + nock.cleanAll(); + + var request = nock(API_URL) + .get('/branding/templates/universal-login') + .reply(500); + + this.branding.getUniversalLoginTemplate().catch(function(err) { + expect(err).to.exist; + + done(); + }); + }); + + it('should pass the body of the response to the "then" handler', function(done) { + var data = { body: 'test' }; + + nock.cleanAll(); + + var request = nock(API_URL) + .get('/branding/templates/universal-login') + .reply(200, data); + + this.branding.getUniversalLoginTemplate().then(function(response) { + expect(response.body).to.equal(data.body); + + done(); + }); + }); + + it('should perform a GET request to /api/v2/branding', function(done) { + var request = this.request; + + this.branding.getUniversalLoginTemplate().then(function() { + expect(request.isDone()).to.be.true; + + done(); + }); + }); + + it('should include the token in the Authorization header', function(done) { + nock.cleanAll(); + + var request = nock(API_URL) + .get('/branding/templates/universal-login') + .matchHeader('Authorization', 'Bearer ' + this.token) + .reply(200); + + this.branding.getUniversalLoginTemplate().then(function() { + expect(request.isDone()).to.be.true; + + done(); + }); + }); + }); + + describe('#setUniversalLoginTemplate', function() { + beforeEach(function() { + this.request = nock(API_URL) + .put('/branding/templates/universal-login') + .reply(200); + }); + + afterEach(function() { + nock.cleanAll(); + }); + + it('should accept a callback', function(done) { + this.branding.setUniversalLoginTemplate({}, {}, function() { + done(); + }); + }); + + it('should return a promise if no callback is given', function(done) { + this.branding + .setUniversalLoginTemplate({}, {}) + .then(done.bind(null, null)) + .catch(done.bind(null, null)); + }); + + it('should pass any errors to the promise catch handler', function(done) { + nock.cleanAll(); + + var request = nock(API_URL) + .put('/branding/templates/universal-login') + .reply(500); + + this.branding.setUniversalLoginTemplate({}, {}).catch(function(err) { + expect(err).to.exist; + + done(); + }); + }); + + it('should pass the body of the response to the "then" handler', function(done) { + var data = { body: 'test' }; + + nock.cleanAll(); + + var request = nock(API_URL) + .put('/branding/templates/universal-login') + .reply(200, data); + + this.branding.setUniversalLoginTemplate({}, data).then(function(response) { + expect(response.body).to.equal(data.body); + + done(); + }); + }); + + it('should perform a PUT request to /api/v2/branding/templates/universal-login', function(done) { + var request = this.request; + + this.branding.setUniversalLoginTemplate({}, {}).then(function() { + expect(request.isDone()).to.be.true; + + done(); + }); + }); + + it('should include the token in the Authorization header', function(done) { + nock.cleanAll(); + + var request = nock(API_URL) + .put('/branding/templates/universal-login') + .matchHeader('Authorization', 'Bearer ' + this.token) + .reply(200); + + this.branding.setUniversalLoginTemplate({}, {}).then(function() { + expect(request.isDone()).to.be.true; + + done(); + }); + }); + }); + + describe('#deleteUniversalLoginTemplate', function() { + beforeEach(function() { + this.request = nock(API_URL) + .delete('/branding/templates/universal-login') + .reply(200); + }); + + afterEach(function() { + nock.cleanAll(); + }); + + it('should accept a callback', function(done) { + this.branding.deleteUniversalLoginTemplate(function() { + done(); + }); + }); + + it('should return a promise if no callback is given', function(done) { + this.branding + .deleteUniversalLoginTemplate() + .then(done.bind(null, null)) + .catch(done.bind(null, null)); + }); + + it('should pass any errors to the promise catch handler', function(done) { + nock.cleanAll(); + + var request = nock(API_URL) + .delete('/branding/templates/universal-login') + .reply(500); + + this.branding.deleteUniversalLoginTemplate().catch(function(err) { + expect(err).to.exist; + + done(); + }); + }); + + it('should pass the body of the response to the "then" handler', function(done) { + var data = { body: 'test' }; + + nock.cleanAll(); + + var request = nock(API_URL) + .delete('/branding/templates/universal-login') + .reply(200, data); + + this.branding.deleteUniversalLoginTemplate().then(function(response) { + expect(response.body).to.equal(data.body); + + done(); + }); + }); + + it('should perform a DELETE request to /api/v2/branding/templates/universal-login', function(done) { + var request = this.request; + + this.branding.deleteUniversalLoginTemplate().then(function() { + expect(request.isDone()).to.be.true; + + done(); + }); + }); + + it('should include the token in the Authorization header', function(done) { + nock.cleanAll(); + + var request = nock(API_URL) + .delete('/branding/templates/universal-login') + .matchHeader('Authorization', 'Bearer ' + this.token) + .reply(200); + + this.branding.deleteUniversalLoginTemplate().then(function() { + expect(request.isDone()).to.be.true; + + done(); + }); + }); + }); });