wildduck/lib/schemas.js
2020-07-19 20:51:06 +03:00

61 lines
1.9 KiB
JavaScript

'use strict';
const EJSON = require('mongodb-extended-json');
const Joi = require('joi');
const sessSchema = Joi.string().max(255).label('Session identifier');
const sessIPSchema = Joi.string()
.ip({
version: ['ipv4', 'ipv6'],
cidr: 'forbidden'
})
.label('Client IP');
/*
const tagSchema = Joi.string().max();
const tagStringValidator = () => {
return value => {
let tagSeen = new Set();
let tags = ((value && value.toString()) || '')
.split(',')
.map(tag => tag.toLowerCase().trim())
.filter(tag => {
if (tag && !tagSeen.has(tag)) {
tagSeen.add(tag);
return true;
}
return false;
});
return tags;
};
};
*/
const mongoCursorValidator = () => {
return (value, helpers) => {
value = value.toString();
if (/[^a-zA-Z0-9\-_]/.test(value)) {
return helpers.error('any.invalid');
}
try {
EJSON.parse(Buffer.from(value, 'base64'));
} catch (E) {
return helpers.error('any.invalid');
}
return value; // Everything is OK
};
};
const mongoCursorSchema = Joi.string().trim().lowercase().empty('').custom(mongoCursorValidator({}), 'Cursor validation').max(1024);
const pageLimitSchema = Joi.number().default(20).min(1).max(250).label('Page size');
const pageNrSchema = Joi.number().default(1).label('Page number');
const nextPageCursorSchema = mongoCursorSchema.label('Next page cursor');
const previousPageCursorSchema = mongoCursorSchema.label('Previous page cursor');
const booleanSchema = Joi.boolean().empty('').truthy('Y', 'true', 'yes', 'on', '1', 1).falsy('N', 'false', 'no', 'off', '0', 0);
module.exports = { sessSchema, sessIPSchema, pageNrSchema, nextPageCursorSchema, previousPageCursorSchema, pageLimitSchema, booleanSchema };