mirror of
https://github.com/strapi/strapi.git
synced 2025-08-07 16:29:18 +00:00
78 lines
2.0 KiB
JavaScript
78 lines
2.0 KiB
JavaScript
'use strict';
|
|
|
|
const { yup, formatYupErrors } = require('strapi-utils');
|
|
// eslint-disable-next-line node/no-extraneous-require
|
|
const { features } = require('strapi/lib/utils/ee');
|
|
|
|
const handleReject = error => Promise.reject(formatYupErrors(error));
|
|
|
|
const roleCreateSchema = yup
|
|
.object()
|
|
.shape({
|
|
name: yup
|
|
.string()
|
|
.min(1)
|
|
.required(),
|
|
description: yup.string().nullable(),
|
|
})
|
|
.noUnknown();
|
|
|
|
const rolesDeleteSchema = yup
|
|
.object()
|
|
.shape({
|
|
ids: yup
|
|
.array()
|
|
.of(yup.strapiID())
|
|
.min(1)
|
|
.required()
|
|
.test('roles-deletion-checks', 'Roles deletion checks have failed', async function(ids) {
|
|
try {
|
|
await strapi.admin.services.role.checkRolesIdForDeletion(ids);
|
|
|
|
if (features.isEnabled('sso')) {
|
|
await strapi.admin.services.role.ssoCheckRolesIdForDeletion(ids);
|
|
}
|
|
} catch (e) {
|
|
return this.createError({ path: 'ids', message: e.message });
|
|
}
|
|
|
|
return true;
|
|
}),
|
|
})
|
|
.noUnknown();
|
|
|
|
const roleDeleteSchema = yup
|
|
.strapiID()
|
|
.required()
|
|
.test('no-admin-single-delete', 'Role deletion checks have failed', async function(id) {
|
|
try {
|
|
await strapi.admin.services.role.checkRolesIdForDeletion([id]);
|
|
|
|
if (features.isEnabled('sso')) {
|
|
await strapi.admin.services.role.ssoCheckRolesIdForDeletion([id]);
|
|
}
|
|
} catch (e) {
|
|
return this.createError({ path: 'id', message: e.message });
|
|
}
|
|
|
|
return true;
|
|
});
|
|
|
|
const validateRoleCreateInput = async data => {
|
|
return roleCreateSchema.validate(data, { strict: true, abortEarly: false }).catch(handleReject);
|
|
};
|
|
|
|
const validateRolesDeleteInput = async data => {
|
|
return rolesDeleteSchema.validate(data, { strict: true, abortEarly: false }).catch(handleReject);
|
|
};
|
|
|
|
const validateRoleDeleteInput = async data => {
|
|
return roleDeleteSchema.validate(data, { strict: true, abortEarly: false }).catch(handleReject);
|
|
};
|
|
|
|
module.exports = {
|
|
validateRoleCreateInput,
|
|
validateRolesDeleteInput,
|
|
validateRoleDeleteInput,
|
|
};
|