1
0
Fork 0
mirror of synced 2024-06-02 18:44:54 +12:00

Fix for validator adding.

This commit is contained in:
mike12345567 2022-02-24 12:03:46 +00:00
parent bc87e2b562
commit d0e0889cc6
7 changed files with 64 additions and 6 deletions

View file

@ -1,5 +1,6 @@
const controller = require("../../controllers/public/applications")
const Endpoint = require("./utils/Endpoint")
const { nameValidator } = require("../utils/validators")
const read = [],
write = []
@ -35,7 +36,11 @@ const read = [],
* applications:
* $ref: '#/components/examples/applications'
*/
read.push(new Endpoint("post", "/applications/search", controller.search))
read.push(
new Endpoint("post", "/applications/search", controller.search).addMiddleware(
nameValidator()
)
)
/**
* @openapi

View file

@ -22,6 +22,9 @@ const publicRouter = new Router({
})
function addMiddleware(endpoints, middleware) {
if (!Array.isArray(endpoints)) {
endpoints = [endpoints]
}
for (let endpoint of endpoints) {
endpoint.addMiddleware(middleware)
}

View file

@ -1,5 +1,6 @@
const controller = require("../../controllers/public/queries")
const Endpoint = require("./utils/Endpoint")
const { nameValidator } = require("../utils/validators")
const read = [],
write = []
@ -35,7 +36,11 @@ const read = [],
* queries:
* $ref: '#/components/examples/queries'
*/
read.push(new Endpoint("post", "/queries/search", controller.search))
read.push(
new Endpoint("post", "/queries/search", controller.search).addMiddleware(
nameValidator()
)
)
/**
* @openapi

View file

@ -1,6 +1,6 @@
const controller = require("../../controllers/public/tables")
const Endpoint = require("./utils/Endpoint")
const { tableValidator } = require("../utils/validators")
const { tableValidator, nameValidator } = require("../utils/validators")
const read = [],
write = []
@ -36,7 +36,11 @@ const read = [],
* tables:
* $ref: '#/components/examples/tables'
*/
read.push(new Endpoint("post", "/tables/search", controller.search))
read.push(
new Endpoint("post", "/tables/search", controller.search).addMiddleware(
nameValidator()
)
)
/**
* @openapi

View file

@ -1,5 +1,6 @@
const controller = require("../../controllers/public/users")
const Endpoint = require("./utils/Endpoint")
const { nameValidator } = require("../utils/validators")
const read = [],
write = []
@ -32,7 +33,11 @@ const read = [],
* users:
* $ref: '#/components/examples/users'
*/
read.push(new Endpoint("post", "/users/search", controller.search))
read.push(
new Endpoint("post", "/users/search", controller.search).addMiddleware(
nameValidator()
)
)
/**
* @openapi

View file

@ -8,6 +8,7 @@ class Endpoint {
addMiddleware(middleware) {
this.middlewares.push(middleware)
return this
}
apply(router) {

View file

@ -5,7 +5,6 @@ const {
BUILTIN_PERMISSION_IDS,
PermissionLevels,
} = require("@budibase/backend-core/permissions")
const Joi = require("joi")
exports.tableValidator = () => {
@ -48,6 +47,42 @@ exports.datasourceValidator = () => {
}).unknown(true))
}
/**
* * {
* "tableId": "ta_70260ff0b85c467ca74364aefc46f26d",
* "query": {
* "string": {},
* "fuzzy": {},
* "range": {
* "columnName": {
* "high": 20,
* "low": 10,
* }
* },
* "equal": {
* "columnName": "someValue"
* },
* "notEqual": {},
* "empty": {},
* "notEmpty": {},
* "oneOf": {
* "columnName": ["value"]
* }
* },
* "limit": 10,
* "sort": "name",
* "sortOrder": "descending",
* "sortType": "string",
* "paginate": true
* }
*/
exports.searchValidator = () => {
// prettier-ignore
return joiValidator.body(Joi.object({
tableId: Joi.string()
}))
}
exports.datasourceQueryValidator = () => {
// prettier-ignore
return joiValidator.body(Joi.object({