Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/luckcoding/koa-controller

整合koa-router、joi,采用注解方式开发业务逻辑,实现参数验证、中间件绑定、接口文档生成等功能。
https://github.com/luckcoding/koa-controller

Last synced: about 11 hours ago
JSON representation

整合koa-router、joi,采用注解方式开发业务逻辑,实现参数验证、中间件绑定、接口文档生成等功能。

Awesome Lists containing this project

README

        

# @koa-lite/controller

[![npm package](https://img.shields.io/npm/v/@koa-lite/controller/latest.svg)](https://www.npmjs.com/package/@koa-lite/controller)

## install

`$ yarn add @koa-lite/controller`

## demo

> real demo: [hotchcms](https://github.com/luckcoding/hotchcms)

* `$ npm install`
* `$ npm start`

## use

```js
// 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())
```

## api

* `Prefix()`
* `Get()`
* `Post()`
* `Put()`
* `Delete()`
* `Body`
* `Query`
* `Params`
* `Headers`
* `Middle([])`
* `Summary()`
* `Tag()`