mirror of
https://github.com/bluewave-labs/Checkmate.git
synced 2026-01-20 00:29:45 -06:00
171 lines
4.5 KiB
JavaScript
171 lines
4.5 KiB
JavaScript
import joi from "joi";
|
|
import dayjs from "dayjs";
|
|
|
|
const nameSchema = joi
|
|
.string()
|
|
.max(50)
|
|
.trim()
|
|
.pattern(/^[A-Za-z]+$/)
|
|
.messages({
|
|
"string.empty": "Name is required",
|
|
"string.max": "Name must be less than 50 characters long",
|
|
"string.pattern.base": "Name must contain only letters",
|
|
});
|
|
|
|
const passwordSchema = joi
|
|
.string()
|
|
.trim()
|
|
.min(8)
|
|
.messages({
|
|
"string.empty": "Password is required",
|
|
"string.min": "Password must be at least 8 characters long",
|
|
})
|
|
.custom((value, helpers) => {
|
|
if (!/[A-Z]/.test(value)) {
|
|
return helpers.message("Password must contain at least one uppercase letter");
|
|
}
|
|
if (!/[a-z]/.test(value)) {
|
|
return helpers.message("Password must contain at least one lowercase letter");
|
|
}
|
|
if (!/\d/.test(value)) {
|
|
return helpers.message("Password must contain at least one number");
|
|
}
|
|
if (!/[!@#$%^&*]/.test(value)) {
|
|
return helpers.message("Password must contain at least one special character");
|
|
}
|
|
|
|
return value;
|
|
});
|
|
|
|
const credentials = joi.object({
|
|
firstName: nameSchema,
|
|
lastName: nameSchema,
|
|
email: joi
|
|
.string()
|
|
.trim()
|
|
.email({ tlds: { allow: false } })
|
|
.custom((value, helpers) => {
|
|
const lowercasedValue = value.toLowerCase();
|
|
if (value !== lowercasedValue) {
|
|
return helpers.message("Email must be in lowercase");
|
|
}
|
|
return lowercasedValue;
|
|
})
|
|
.messages({
|
|
"string.empty": "Email is required",
|
|
"string.email": "Must be a valid email address",
|
|
}),
|
|
password: passwordSchema,
|
|
newPassword: passwordSchema,
|
|
confirm: joi
|
|
.string()
|
|
.trim()
|
|
.messages({
|
|
"string.empty": "Password confirmation is required",
|
|
})
|
|
.custom((value, helpers) => {
|
|
const { password } = helpers.prefs.context;
|
|
if (value !== password) {
|
|
return helpers.message("Passwords do not match");
|
|
}
|
|
return value;
|
|
}),
|
|
role: joi.array(),
|
|
teamId: joi.string().allow("").optional(),
|
|
inviteToken: joi.string().allow(""),
|
|
});
|
|
|
|
const monitorValidation = joi.object({
|
|
url: joi.string().uri({ allowRelative: true }).trim().messages({
|
|
"string.empty": "This field is required.",
|
|
"string.uri": "The URL you provided is not valid.",
|
|
}),
|
|
name: joi.string().trim().max(50).allow("").messages({
|
|
"string.max": "This field should not exceed the 50 characters limit.",
|
|
}),
|
|
type: joi.string().trim().messages({ "string.empty": "This field is required." }),
|
|
interval: joi.number().messages({
|
|
"number.base": "Frequency must be a number.",
|
|
"any.required": "Frequency is required.",
|
|
}),
|
|
});
|
|
|
|
const imageValidation = joi.object({
|
|
type: joi.string().valid("image/jpeg", "image/png").messages({
|
|
"any.only": "Invalid file format.",
|
|
"string.empty": "File type required.",
|
|
}),
|
|
size: joi
|
|
.number()
|
|
.max(3 * 1024 * 1024)
|
|
.messages({
|
|
"number.base": "File size must be a number.",
|
|
"number.max": "File size must be less than 3 MB.",
|
|
"number.empty": "File size required.",
|
|
}),
|
|
});
|
|
|
|
const settingsValidation = joi.object({
|
|
ttl: joi.number().required().messages({
|
|
"string.empty": "TTL is required",
|
|
}),
|
|
});
|
|
|
|
const dayjsValidator = (value, helpers) => {
|
|
if (!dayjs(value).isValid()) {
|
|
return helpers.error("any.invalid");
|
|
}
|
|
return value;
|
|
};
|
|
|
|
const maintenanceWindowValidation = joi.object({
|
|
repeat: joi.string(),
|
|
startDate: joi.custom(dayjsValidator, "Day.js date validation"),
|
|
startTime: joi.custom(dayjsValidator, "Day.js date validation"),
|
|
duration: joi.number().integer().min(0),
|
|
durationUnit: joi.string(),
|
|
name: joi.string(),
|
|
monitors: joi.array().min(1),
|
|
});
|
|
|
|
const advancedSettingsValidation = joi.object({
|
|
apiBaseUrl: joi.string().uri({ allowRelative: true }).trim().messages({
|
|
"string.empty": "API base url is required.",
|
|
"string.uri": "The URL you provided is not valid.",
|
|
}),
|
|
logLevel: joi.string().valid("debug", "none", "error", "warn").allow(""),
|
|
systemEmailHost: joi.string().allow(''),
|
|
systemEmailPort: joi.string().allow(''),
|
|
systemEmailAddress: joi
|
|
.string().allow(''),
|
|
systemEmailPassword: joi.string().allow(''),
|
|
jwtTTL: joi
|
|
.string()
|
|
.trim()
|
|
.messages({
|
|
"string.empty": "JWT TTL is required."
|
|
}),
|
|
dbType: joi.string().trim().messages({
|
|
"string.empty": "DB type is required",
|
|
}),
|
|
redisHost: joi.string().trim().messages({
|
|
"string.empty": "Redis host is required",
|
|
}),
|
|
redisPort: joi.string().allow('').custom((value, helpers) => {
|
|
if(value && isNaN(parseInt(value))){
|
|
return helpers.message("Redit port must be a number")
|
|
}
|
|
return value
|
|
}),
|
|
pagespeedApiKey: joi.string().allow('')
|
|
});
|
|
|
|
export {
|
|
credentials,
|
|
imageValidation,
|
|
monitorValidation,
|
|
settingsValidation,
|
|
maintenanceWindowValidation,
|
|
advancedSettingsValidation,
|
|
};
|