diff --git a/src/routes/settings.js b/src/routes/settings.js index 3c561fbf5..abd06df4e 100644 --- a/src/routes/settings.js +++ b/src/routes/settings.js @@ -196,6 +196,32 @@ function setPlatformConfig(req, res, next) { }); } +function getExternalLdapConfig(req, res, next) { + settings.getExternalLdapConfig(function (error, config) { + if (error) return next(new HttpError(500, error)); + + next(new HttpSuccess(200, config)); + }); +} + +function setExternalLdapConfig(req, res, next) { + assert.strictEqual(typeof req.body, 'object'); + + if (typeof req.body.url !== 'string' || req.body.url === '') return next(new HttpError(400, 'url must be a non empty string')); + if (typeof req.body.baseDn !== 'string' || req.body.baseDn === '') return next(new HttpError(400, 'baseDn must be a non empty string')); + if (typeof req.body.filter !== 'string' || req.body.filter === '') return next(new HttpError(400, 'filter must be a non empty string')); + if ('bindDn' in req.body && (typeof req.body.bindDn !== 'string' || req.body.bindDn === '')) return next(new HttpError(400, 'bindDn must be a non empty string')); + if ('bindPassword' in req.body && typeof req.body.bindPassword !== 'string') return next(new HttpError(400, 'bindPassword must be a string')); + + settings.setExternalLdapConfig(req.body, function (error) { + if (error && error.reason === SettingsError.BAD_FIELD) return next(new HttpError(400, error.message)); + if (error && error.reason === SettingsError.EXTERNAL_ERROR) return next(new HttpError(424, error.message)); + if (error) return next(new HttpError(500, error)); + + next(new HttpSuccess(200, {})); + }); +} + function getDynamicDnsConfig(req, res, next) { settings.getDynamicDnsConfig(function (error, enabled) { if (error) return next(new HttpError(500, error)); @@ -262,6 +288,7 @@ function get(req, res, next) { case settings.DYNAMIC_DNS_KEY: return getDynamicDnsConfig(req, res, next); case settings.BACKUP_CONFIG_KEY: return getBackupConfig(req, res, next); case settings.PLATFORM_CONFIG_KEY: return getPlatformConfig(req, res, next); + case settings.EXTERNAL_LDAP_KEY: return getExternalLdapConfig(req, res, next); case settings.UNSTABLE_APPS_KEY: return getUnstableAppsConfig(req, res, next); case settings.APP_AUTOUPDATE_PATTERN_KEY: return getAppAutoupdatePattern(req, res, next); @@ -282,6 +309,7 @@ function set(req, res, next) { case settings.DYNAMIC_DNS_KEY: return setDynamicDnsConfig(req, res, next); case settings.BACKUP_CONFIG_KEY: return setBackupConfig(req, res, next); case settings.PLATFORM_CONFIG_KEY: return setPlatformConfig(req, res, next); + case settings.EXTERNAL_LDAP_KEY: return setExternalLdapConfig(req, res, next); case settings.UNSTABLE_APPS_KEY: return setUnstableAppsConfig(req, res, next); case settings.APP_AUTOUPDATE_PATTERN_KEY: return setAppAutoupdatePattern(req, res, next);