strapi/packages/strapi-admin/validation/common-validators.js

118 lines
3.3 KiB
JavaScript
Raw Normal View History

'use strict';
const { yup } = require('strapi-utils');
const _ = require('lodash');
const {
checkFieldsAreCorrectlyNested,
checkFieldsDontHaveDuplicates,
} = require('./common-functions');
2020-05-27 16:06:15 +02:00
const email = yup
.string()
.email()
.min(1);
const firstname = yup.string().min(1);
const lastname = yup.string().min(1);
2020-05-27 16:06:15 +02:00
const username = yup.string().min(1);
const password = yup
.string()
.min(8)
.matches(/[a-z]/, '${path} must contain at least one lowercase character')
.matches(/[A-Z]/, '${path} must contain at least one uppercase character')
.matches(/\d/, '${path} must contain at least one number');
const roles = yup.array(yup.strapiID()).min(1);
2020-05-27 16:06:15 +02:00
const isAPluginName = yup
.string()
.test('is-a-plugin-name', 'is not a plugin name', function(value) {
return [undefined, 'admin', ...Object.keys(strapi.plugins)].includes(value)
? true
: this.createError({ path: this.path, message: `${this.path} is not an existing plugin` });
});
const arrayOfConditionNames = yup
.array()
.of(yup.string())
.test('is-an-array-of-conditions', 'is not a plugin name', function(value) {
const ids = strapi.admin.services.permission.conditionProvider.getAll().map(c => c.id);
return _.isUndefined(value) || _.difference(value, ids).length === 0
? true
: this.createError({ path: this.path, message: `contains conditions that don't exist` });
});
const checkCTPermsDeleteHaveFieldsToNull = permissions =>
!Array.isArray(permissions) ||
permissions.every(
perm => perm.action !== 'plugins::content-manager.explorer.delete' || _.isNil(perm.fields)
);
const permissionsAreEquals = (a, b) =>
a.action === b.action && (a.subject === b.subject || (_.isNil(a.subject) && _.isNil(b.subject)));
const checkNoDuplicatedPermissions = permissions =>
!Array.isArray(permissions) ||
permissions.every((permA, i) =>
permissions.slice(i + 1).every(permB => !permissionsAreEquals(permA, permB))
);
const updatePermissions = yup
.object()
.shape({
permissions: yup
.array()
.requiredAllowEmpty()
.of(
yup
.object()
.shape({
action: yup.string().required(),
subject: yup.string().nullable(),
fields: yup
.array()
.of(yup.string())
.nullable()
.test(
'field-nested',
'Fields format are incorrect (bad nesting).',
checkFieldsAreCorrectlyNested
)
.test(
'field-nested',
'Fields format are incorrect (duplicates).',
checkFieldsDontHaveDuplicates
),
conditions: yup.array().of(yup.string()),
})
.test(
'delete-fields-are-null',
'Some permissions are duplicated (same action and subject)',
checkNoDuplicatedPermissions
)
.test(
'delete-fields-are-null',
'The action "plugins::content-manager.explorer.delete" must have fields set to null or undefined',
checkCTPermsDeleteHaveFieldsToNull
)
.noUnknown()
),
})
.required()
.noUnknown();
2020-05-27 16:06:15 +02:00
module.exports = {
email,
firstname,
lastname,
username,
password,
roles,
isAPluginName,
arrayOfConditionNames,
updatePermissions,
2020-05-27 16:06:15 +02:00
};