@appolo/context

8.0.2 • Public • Published

Request context module for appolo built with appolo-context and async_hooks.

new context will be create for every request

Installation

npm i @appolo/context

Options

key Description Type Default
id id of context injector string context

in config/modules/all.ts

import {ContextModule} from '@appolo/context';

export = async function (app: App) {
   await app.module(ContextModule);
}

Usage

first define your context using the @context decorator

import {context} from '@appolo/context';

@context()
export class MyContext {

    @inject() env: any;

    constructor(req, res) {

    }

    private _user: string;

    public set user(value: string) {

        this._user = value
    }

    public get user(): string {
        return this._user
    }
}

For the example we will define a middleware to set the context data

@define()
@singleton()
export class UserMiddleware extends Middleware {
    @inject() context: MyContext;

    async run(req, res, next) {
        this.context.user = req.query.userName;
        next()
    }
}

Now we can access the context from any class using @inject context

note that the context is uniq for every request and can not share data between requests

@define()
@singleton()
export class SomeManager {

    @inject() context: MyContext ;

    public async getName():Promise<string>{
        return this.context.user;
    }
}

In the controller we will put the middleware and access the manager to get the context name

@controller()
export class ContextController extends Controller {

    @inject() someManager: Manager;

    @get("/test/context/")
    @validation("userName", validator.string().required())
    @middleware(UserMiddleware)
    async test(req: IRequest, res: IResponse) {

        let userName = await this.someManager.getName()

        return {userName}
    }
}

You can also access the current context from getContext function

import {getContext} from '@appolo/context';

@define()
@singleton()
export class SomeManager {

    public async getName():Promise<string>{
        return getContext().user;
    }
}

Readme

Keywords

Package Sidebar

Install

npm i @appolo/context

Weekly Downloads

35

Version

8.0.2

License

MIT

Unpacked Size

26.1 kB

Total Files

25

Last publish

Collaborators

  • saar120
  • shmoop207