From 7b92d7401a21199caedb2698c795580311eabbb4 Mon Sep 17 00:00:00 2001 From: Robert Date: Thu, 5 May 2016 13:15:28 -0700 Subject: [PATCH 1/2] allow user-provided config to disable email verification, password reset --- ...richIntegrationFromRemoteConfigStrategy.js | 7 +- ...IntegrationFromRemoteConfigStrategyTest.js | 84 ++++++++++++++++--- 2 files changed, 76 insertions(+), 15 deletions(-) diff --git a/lib/strategy/EnrichIntegrationFromRemoteConfigStrategy.js b/lib/strategy/EnrichIntegrationFromRemoteConfigStrategy.js index fe8b19f..de6c5f5 100644 --- a/lib/strategy/EnrichIntegrationFromRemoteConfigStrategy.js +++ b/lib/strategy/EnrichIntegrationFromRemoteConfigStrategy.js @@ -174,18 +174,19 @@ EnrichIntegrationFromRemoteConfigStrategy.prototype._enrichWithDirectoryPolicies // Enrich config with with directory policies. client.getDirectory(directoryHref, { expand: 'passwordPolicy,accountCreationPolicy' }, stopIfError(function (directory) { var resetEmailStatusEnabled = isEnabled(directory.passwordPolicy.resetEmailStatus); + var verificationEmailStatusEnabled = isEnabled(directory.accountCreationPolicy.verificationEmailStatus); // Enrich config with account policies. extend(config, { web: { forgotPassword: { - enabled: resetEmailStatusEnabled + enabled: config.web.forgotPassword.enabled === false ? false : resetEmailStatusEnabled }, changePassword: { - enabled: resetEmailStatusEnabled + enabled: config.web.changePassword.enabled === false ? false : resetEmailStatusEnabled }, verifyEmail: { - enabled: isEnabled(directory.accountCreationPolicy.verificationEmailStatus) + enabled: config.web.verifyEmail.enabled === false ? false : verificationEmailStatusEnabled } } }); diff --git a/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js b/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js index 13ba877..f783114 100644 --- a/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js +++ b/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js @@ -208,7 +208,7 @@ describe('EnrichIntegrationFromRemoteConfigStrategy', function () { }); }); - describe('_enrichWithDirectoryPolicies method', function () { + describe('when parsing the directory workflow statuses', function () { var enrichWithDirectoryPolicies; var mockConfig; @@ -227,29 +227,57 @@ describe('EnrichIntegrationFromRemoteConfigStrategy', function () { sandbox.stub(policy, 'getStrength').yields(null, {}); }); - describe('directory.passwordPolicy.resetEmailStatus property', function () { + describe('the password policy', function () { describe('when "ENABLED"', function () { beforeEach(function () { mockDirectory.passwordPolicy.resetEmailStatus = 'ENABLED'; }); - it('should set config.web.forgotPassword.enabled to true', function (done) { - mockConfig.web.forgotPassword.enabled = false; + describe('and config.web.forgotPassword.enabled is false', function () { + it('should leave config.web.forgotPassword.enabled as false', function (done) { + mockConfig.web.forgotPassword.enabled = false; - enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { - assert.equal(mockConfig.web.forgotPassword.enabled, true); - done(); + enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { + assert.equal(mockConfig.web.forgotPassword.enabled, false); + done(); + }); }); }); - it('should set config.web.changePassword.enabled to true', function (done) { - mockConfig.web.changePassword.enabled = false; + describe('and config.web.forgotPassword.enabled is undefined', function () { + it('should set config.web.forgotPassword.enabled to true', function (done) { + mockConfig.web.forgotPassword.enabled = undefined; - enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { - assert.equal(mockConfig.web.changePassword.enabled, true); - done(); + enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { + assert.equal(mockConfig.web.forgotPassword.enabled, true); + done(); + }); + }); + }); + + describe('and config.web.changePassword.enabled is false', function () { + it('should leave config.web.changePassword.enabled as false', function (done) { + mockConfig.web.changePassword.enabled = false; + + enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { + assert.equal(mockConfig.web.changePassword.enabled, false); + done(); + }); }); }); + + describe('and config.web.changePassword.enabled is undefined', function () { + it('should set config.web.changePassword.enabled to true', function (done) { + mockConfig.web.changePassword.enabled = undefined; + + enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { + assert.equal(mockConfig.web.changePassword.enabled, true); + done(); + }); + }); + }); + + }); describe('when undefined', function () { @@ -276,5 +304,37 @@ describe('EnrichIntegrationFromRemoteConfigStrategy', function () { }); }); }); + + describe('the email verification policy', function(){ + describe('when ENABLED', function(){ + beforeEach(function () { + mockDirectory.accountCreationPolicy.verificationEmailStatus = 'ENABLED'; + }); + + describe('and config.web.verifyEmail.enabled is false', function () { + it('should leave config.web.verifyEmail.enabled as false', function (done) { + mockConfig.web.verifyEmail.enabled = false; + + enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { + assert.equal(mockConfig.web.verifyEmail.enabled, false); + done(); + }); + }); + }); + + describe('and config.web.verifyEmail.enabled is undefined', function () { + it('should set config.web.verifyEmail.enabled to true', function (done) { + mockConfig.web.verifyEmail.enabled = undefined; + + enrichWithDirectoryPolicies(client, mockConfig, mockDirectory.href, function () { + assert.equal(mockConfig.web.verifyEmail.enabled, true); + done(); + }); + }); + }); + + }); + }); }); + }); From 67e895faf8e28d05440605ca612a93a7b3d6fad1 Mon Sep 17 00:00:00 2001 From: Robin Orheden Date: Mon, 9 May 2016 17:47:12 +0200 Subject: [PATCH 2/2] remove unnecessary whitelines --- .../strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js | 4 ---- 1 file changed, 4 deletions(-) diff --git a/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js b/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js index f783114..ef19f1e 100644 --- a/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js +++ b/test/strategy/EnrichIntegrationFromRemoteConfigStrategyTest.js @@ -276,8 +276,6 @@ describe('EnrichIntegrationFromRemoteConfigStrategy', function () { }); }); }); - - }); describe('when undefined', function () { @@ -332,9 +330,7 @@ describe('EnrichIntegrationFromRemoteConfigStrategy', function () { }); }); }); - }); }); }); - });