Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/libery/think-swagger
https://github.com/libery/think-swagger
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/libery/think-swagger
- Owner: libery
- Created: 2017-07-24T15:32:02.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-07-28T07:38:47.000Z (over 7 years ago)
- Last Synced: 2024-11-17T16:42:18.413Z (2 months ago)
- Size: 3.91 KB
- Stars: 9
- Watchers: 2
- Forks: 3
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- think-awesome - think-swagger - swagger-controller.svg) | ![](https://travis-ci.org/libery/think-swagger-controller.svg) | ![](https://coveralls.io/repos/github/libery/think-swagger-controller/badge.svg) | swagger middleware | (Middlewares)
README
# think-swagger
ThinkJS 是一个 Node.js 框架,自带脚手架通过简单的指令生成项目目录,集成了大量开箱即用的插件,适合 Node.js 环境下的快速开发。本项目为 ThinkJS 3.x 提供 swagger 的支持,本项目包含三个子项目和一个示例:
| 名称 | 说明 |
| --- | --- |
| [think-swagger-parser](https://github.com/libery/think-swagger-parser) | swagger文档解析模块 |
| [think-swagger-router](https://github.com/libery/think-swagger-router) | 路由模块 |
| [think-swagger-controller](https://github.com/libery/think-swagger-controller) | 控制器模块 |
| [think-swagger-demo](https://github.com/libery/think-swagger-demo) | 示例程序 |通过三个 middleware 模块让 ThinkJS 支持 swagger,基于 swagger 的 yam l文件实现路由和接口实现的映射,可以快速开发 RESTful 的接口。
## 安装
要实现该功能,在新建 ThinkJS 3.x 项目后,需要修改`src/config/middleware.js`引入并启用以上3个 middleware,并配置 swagger 文档路径和 ThinkJS controller 路径:
1. 安装 3 个模块
```bash
npm i think-swagger-parser think-swagger-router think-swagger-controller --save
```
2. 修改`src/config/middleware.js`文件+ 增加swaggerParser:
```js
{
handle: swaggerParser,
options: {
debug: isDev,
api_doc: './api/swagger.yaml',
controller_dir: './app/controller'
}
}
```
+ 增加swaggerRouter:```js
{
handle: swaggerRouter,
options: {
debug: isDev
}
}
```+ 增加swaggerController:
```js
{
handle: swaggerController,
options: {
debug: isDev
}
}
```
+ 删除默认的controller:```js
// 'controller'```
+ 完整middleware文件:
```js
const path = require('path');
const swaggerParser = require('think-swagger-parser');
const swaggerRouter = require('think-swagger-router');
const swaggerController = require('think-swagger-controller');
const isDev = think.env === 'development';module.exports = [
{
handle: 'meta',
options: {
logRequest: isDev,
sendResponseTime: isDev
}
},
{
handle: 'resource',
enable: isDev,
options: {
root: path.join(think.ROOT_PATH, 'www'),
publicPath: /^\/(static|favicon\.ico)/
}
},
{
handle: 'trace',
enable: !think.isCli,
options: {
debug: isDev
}
},
{
handle: 'payload',
options: {}
},
{
handle: swaggerParser,
options: {
debug: isDev,
api_doc: './api/swagger.yaml',
controller_dir: './app/controller'
}
},
{
handle: 'router',
options: {}
},
{
handle: swaggerRouter,
options: {
debug: isDev
}
},
'logic',
{
handle: swaggerController,
options: {
debug: isDev
}
}
// 'controller'
];```