joi - ArangoDB Joi Foxx 映射到 Swagger 不正确
问题描述
我在 joi 语法上定义了一个名为 TestBean 的 bean。然后定义了另一个使用 TestBean 模式/bean 的 bean BeanMethodDocument。生成的 Swagger/model 会忽略此参数,但使用 TestBean 定义的数组有效吗?
以下 JOI 语法似乎丢失了 TestBean 定义:“arg: joi.object().schema(TestBean).required()”
'use strict';
var createRouter = require('@arangodb/foxx/router');
var joi = require('joi');
var router = createRouter();
module.context.use(router);
const TestBean = joi.object().required().keys({
member1: joi.array().items(joi.string().required()),
member2: joi.number().required()
});
const BeanMethodDocument = joi.object().required().keys({
arg: joi.object().schema(TestBean).required(),
argArray: joi.array().items(TestBean).required(),
option: joi.string().valid('Empty','Full','HalfFull','HalfEmpty')
});
router.post('/beanMethod', function (req, res) {
const arg = req.body.arg;
const argArray = req.body.argArray;
const option = req.body.option;
res.send({result:true});
})
.body(BeanMethodDocument, 'beanMethod POST request')
.response(joi.boolean().required(), 'beanMethod POST response')
.summary('beanMethod summary')
.description('beanMethod description');
生成的 Swagger 文档显示 arg 参数为空?"arg": {
"type": "object",
"properties": {},
"additionalProperties": false },
解决方案
根据 JOI 文档(https://github.com/hapijs/joi/blob/v15.1.0/API.md#objectschema),您在那里使用的架构函数确实返回了当前对象的架构,它没有设置它. 您可以像这样简单地使用 TestBean 而不是 joi.object() :
const BeanMethodDocument = joi.object().required().keys({
arg: TestBean.required(),
argArray: joi.array().items(TestBean).required(),
option: joi.string().valid('Empty','Full','HalfFull','HalfEmpty')
});
在我的本地测试中,这项工作最终得到:
{
"arg": {
"member1": [
"string"
],
"member2": 0
},
"argArray": [
{
"member1": [
"string"
],
"member2": 0
}
],
"option": "Empty"
}
推荐阅读
- schema.org - Schema.org/Rich Snippets:页面上定义的多个 ListItem 元素
- java - 映射休眠实体多对一
- python - 存储在 Keras 模型中的单独“偏差”权重是什么意思?
- java - CameraX Image Analysis (with OUTPUT_IMAGE_FORMAT_RGBA_8888) : maxImages (4) 已经被获取,在获取更多之前调用#close
- azure - 如何使用 OIDC 设置多租户 Azure AD SSO
- bash - 如何自动化远程服务器上的任务。如何从一个响应中获取价值以添加到下一个命令中?
- python - 如何在python中拆分列表
- r - OTP_Get_Times 函数仅返回错误 406 的运输时间
- django - 添加应用程序初始迁移时的Django InconsistentMigrationHistory
- c - 是 memset(&ptr, 0, sizeof(ptr)); 等同于 ptr=NULL;?