$ yarn add @koa-lite/controller
real demo: hotchcms
$ npm install
$ npm start
// controller.ts
import { Prefix, Tag, Get, Summary, Query } from '@koa-lite/controller'
@Prefix('/ucenter')
export default class User {
@Tag('User')
@Get('/user') // or request.get('/user'), request('get', '/user')
@Summary('User list')
@Query(Joi.object({
name: Joi.string().required().description('name'),
})) // check.query()
async sms(ctx: BaseContext) {
ctx.body = {}
}
}
// router.ts
import { Controller, InjectHandle } from '@koa-lite/controller'
import User from './controller.ts'
// 包装函数
InjectHandle(({ fn }) => fn)
const router = new Controller({
prefix: '/v1',
docs: {
title: '接口文档 - 客户端',
version: 'v1',
description: '业务接口文档 - by Hotchcms',
securities: [{
type: 'headers',
key: 'Authorization', // 自动注入token等信息
value: function (data) {
var ret = (data instanceof Object) && data.ret
return /^Bearer\s/.test(ret) ? ret : ''
},
}, {
type: 'headers',
key: 'x-device-id',
value: '10001',
}],
}})
.controllers([ User ])
.get('/', ctx => { ctx.body = 'API V1' })
// app.ts
app.use(router.routes())
Prefix()
Get()
Post()
Put()
Delete()
Body
Query
Params
Headers
Middle([])
Summary()
Tag()