如何从 javascript 访问 swagger yaml 定义的对象
How to access swagger yaml defined objects from javascript
我使用 Swagger Yaml 来描述端点并生成模拟服务器。现有端点(我正在模拟)没有 100% 遵循 RESTful 原则,所以我只想覆盖模拟服务器 returned 的响应。简单服务器代码如下:
var swagger = require('swagger-server');
var server = swagger('map-cache.yaml');
var port = 7072;
server.post('/map-qa_trunk/v2/getData', function(req, res, next) {
var foo = {
err : 123,
msg : "error message"
};
res.json(foo);
});
server.listen(port, function() {
console.log('Map Cache Mock Server is now running at http://localhost:' + port);
});
在 Yaml 定义中,定义了一个名为 MapResponseData 的对象,我如何创建该对象的实例以便我可以根据需要填充它,return 在 res.json() ?类似于以下内容:
var response = getMapResponseData(); // don't know what this call should be
response.fieldA = 123;
res.json(response);
我猜这应该是可能的,因为 Swagger 解析了 YAML 文件并且知道指定的所有定义。
尝试将请求对象输出到 console.log 以查看是否可以找到对 swagger 定义的引用。另一种选择是从 yaml 文件中提取已解析的 swagger 定义(例如使用 js-yaml)并从那里提取。
不过,我最好的建议是使用 swagger-tools 而不是 swagger-server。 swagger-server 软件包是 alpha 版本,下载次数、修订次数和用户数少于 swagger-tools。 swagger-tools 的好处是它会得到积极维护,并且有一个更大的社区可以支持你。要将项目转换为 swagger-tools,请使用 swagger.io > Swagger Editor > Online Editor > Paste yaml in left pane > Generate Server > Node.js
在swagger-tools中,整个 Swagger Yaml 定义包含在每个请求对象中:
req.swagger.swaggerObject
您可以根据需要从中提取响应对象定义。
我使用 Swagger Yaml 来描述端点并生成模拟服务器。现有端点(我正在模拟)没有 100% 遵循 RESTful 原则,所以我只想覆盖模拟服务器 returned 的响应。简单服务器代码如下:
var swagger = require('swagger-server');
var server = swagger('map-cache.yaml');
var port = 7072;
server.post('/map-qa_trunk/v2/getData', function(req, res, next) {
var foo = {
err : 123,
msg : "error message"
};
res.json(foo);
});
server.listen(port, function() {
console.log('Map Cache Mock Server is now running at http://localhost:' + port);
});
在 Yaml 定义中,定义了一个名为 MapResponseData 的对象,我如何创建该对象的实例以便我可以根据需要填充它,return 在 res.json() ?类似于以下内容:
var response = getMapResponseData(); // don't know what this call should be
response.fieldA = 123;
res.json(response);
我猜这应该是可能的,因为 Swagger 解析了 YAML 文件并且知道指定的所有定义。
尝试将请求对象输出到 console.log 以查看是否可以找到对 swagger 定义的引用。另一种选择是从 yaml 文件中提取已解析的 swagger 定义(例如使用 js-yaml)并从那里提取。
不过,我最好的建议是使用 swagger-tools 而不是 swagger-server。 swagger-server 软件包是 alpha 版本,下载次数、修订次数和用户数少于 swagger-tools。 swagger-tools 的好处是它会得到积极维护,并且有一个更大的社区可以支持你。要将项目转换为 swagger-tools,请使用 swagger.io > Swagger Editor > Online Editor > Paste yaml in left pane > Generate Server > Node.js
在swagger-tools中,整个 Swagger Yaml 定义包含在每个请求对象中:
req.swagger.swaggerObject
您可以根据需要从中提取响应对象定义。