0.0.1 • Published 8 years ago
koa-smartdoc-middleware v0.0.1
smartdoc-middleware
Smartdoc is an RESTful document generator according to document-style comment.
Smartdoc是一个基于文档化注释的RESTful文档生成器,同时也包括一个浏览接口的网页。
如何工作
Smartdoc通过AST读取接口目录下所有的API文档化注释,生成一个描述接口的数据文件,然后在中间件的挂载目录上提供一个网页,用来查看文档和测试接口。
用法
1. 安装
npm install --save koa-smartdoc-middleware2. 引入中间件
例如有如下的项目结构:
- index.js
+ services // The directory where api functions defined in.
  - user.js
  - post.js
  - ...而且,services里面的接口方法都已经写好了文档化注释。
然后就可以在Express中引用:
// index.js
const app = require('koa')();
const mount = require('koa-mount');
const smartdoc = require('koa-smartdoc-middleware');
const pathToServices = path.join('../services');
// ...
app.use(mount('/doc', smartdoc(pathToServices)));
// ...
app.listen(3000);然后启动服务器,就可以用http://localhost:3000/doc访问文档页面了.
3. 编写文档化注释
首先需要在services目录里定义Application(任意文件都可以,但是推荐在index.js中)
// services/index.js
/**
 * 示例应用
 * @application example-app
 *
 * @author linkeo
 * @version 0.0.1
 */
module.exports = {};注意:
@application [name]是定义Application的必须条件
然后在接口模块文件中定义模块和接口:
// services/user.js
/**
 * 用户模块
 * @module user
 * @path /user
 */
module.exports = class UserService {
  /**
   * 用户登录
   *
   * @note 登陆成功时会在响应中设置cookie
   *
   * @route {post} /login
   * @param {String} account 用户的手机号或邮箱
   * @param {String} password
   * @param {String} from 登陆的位置,可以是 'app', 'web'
   * @return {Object} 用户信息
   */
  *login(req, res) {
    //...
  }
}注意:
@module [name]是定义Module的必须条件注意:
@route [method] [path]是定义Action的必须条件
解析出来的结构描述文件大致如下:
name: example-app
title: Example Application
modules:
  - name: user-674e7e
    title: User Services
    path: /user
    actions:
      - name: post-login-768ed4
        title: User Login
        route:
          method: post
          path: /login
        params: ...功能
- 读取RESTful风格的文档化注释
- 提供一个单页应用,用于查看和测试接口。
Todo
- 更丰富的请求设置
- 可以提供一个沙箱环境,保存一些请求用的变量
- 可以在沙箱环境中执行接口测试代码
0.0.1
8 years ago