1
0
Fork 0

check email enabled for requiresEmailVer config

This commit is contained in:
Josh Morel 2019-02-17 13:14:00 -05:00 committed by Chocobozzz
parent 41d713446c
commit 576ad67aac
3 changed files with 39 additions and 2 deletions

View File

@ -2,6 +2,8 @@ import * as express from 'express'
import { body } from 'express-validator/check'
import { isUserNSFWPolicyValid, isUserVideoQuotaValid, isUserVideoQuotaDailyValid } from '../../helpers/custom-validators/users'
import { logger } from '../../helpers/logger'
import { CustomConfig } from '../../../shared/models/server/custom-config.model'
import { Emailer } from '../../lib/emailer'
import { areValidationErrors } from './utils'
const customConfigUpdateValidator = [
@ -46,11 +48,27 @@ const customConfigUpdateValidator = [
logger.debug('Checking customConfigUpdateValidator parameters', { parameters: req.body })
if (areValidationErrors(req, res)) return
if (!checkInvalidConfigIfEmailDisabled(req.body as CustomConfig, res)) return
return next()
}
]
// ---------------------------------------------------------------------------
export {
customConfigUpdateValidator
}
function checkInvalidConfigIfEmailDisabled (customConfig: CustomConfig, res: express.Response) {
if (Emailer.isEnabled()) return true
if (customConfig.signup.requiresEmailVerification === true) {
res.status(400)
.send({ error: 'Emailer is disabled but you require signup email verification.' })
.end()
return false
}
return true
}

View File

@ -167,6 +167,25 @@ describe('Test config API validators', function () {
})
})
it('Should fail if email disabled and signup requires email verification', async function () {
// opposite scenario - succcess when enable enabled - covered via tests/api/users/user-verification.ts
const newUpdateParams = immutableAssign(updateParams, {
signup: {
enabled: true,
limit: 5,
requiresEmailVerification: true
}
})
await makePutBodyRequest({
url: server.url,
path,
fields: newUpdateParams,
token: server.accessToken,
statusCodeExpected: 400
})
})
it('Should success with the correct parameters', async function () {
await makePutBodyRequest({
url: server.url,

View File

@ -81,7 +81,7 @@ function checkUpdatedConfig (data: CustomConfig) {
expect(data.signup.enabled).to.be.false
expect(data.signup.limit).to.equal(5)
expect(data.signup.requiresEmailVerification).to.be.true
expect(data.signup.requiresEmailVerification).to.be.false
expect(data.admin.email).to.equal('superadmin1@example.com')
expect(data.contactForm.enabled).to.be.false
@ -186,7 +186,7 @@ describe('Test config', function () {
signup: {
enabled: false,
limit: 5,
requiresEmailVerification: true
requiresEmailVerification: false
},
admin: {
email: 'superadmin1@example.com'