@pagodas/egg-routing-controllers
v3.0.1
Published
Mount [routing-controllers](https://github.com/typestack/routing-controllers) package as an egg middleware.
Downloads
167
Readme
egg-routing-controllers
Mount routing-controllers package as an egg middleware.
Install
$ npm i @pagodas/egg-routing-controllers --save
For extensible,we also need install [email protected]
, class-transformer@^0.2.3
, [email protected]
.
[email protected]
is our base peerDependencies.
class-transformer^0.2.3
, [email protected]
is [email protected]
's base peerDependencies.
$ npm i [email protected] class-transformer@^0.2.3 [email protected] --save
Usage
// {app_root}/config/plugin.js
exports.routingControllers = {
enable: true,
package: '@pagodas/egg-routing-controllers',
};
Configuration
Support all configurations in routing-controllers.
// {app_root}/config/config.default.js
config.routingControllers = {
options: {},// config for routing-controllers create.
disableResponseTransform: true, // hack routing-controllers to disable transform response,default false.(It's useful for mongoose response otherwise ObjectId may cause error)
mountPath:'./app/routing-controller' // controller path.If relative then base app.baseDir.default value ./app/routing-controller.If options have controllers then ignore this config.
};
warming: Don't set options.controllers for routing-controllers unless you know what it is. egg run .ts files when debug and run .js files in production. Files in mouthPath will priority use the .js file ,the same name .ts file will ignored.
controller example
// file app/routing-controller/util.ts
import {Ctx, Get, JsonController} from 'routing-controllers';
@JsonController()
export class UtilController {
@Get('/api/search')
async search(@Ctx()ctx: Context) {
return {};
}
}
Just export your controller(created using routing-controllers
).
Questions & Suggestions
Please open an issue here.