Skip to content

peatiscoding/kolp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

58 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Kolp

"jetpack for building microservice on Lambda"

Accronym for Koa on Lambda (Pack). A tiny library toolbox for Lambda (using Koa, Koa Router) then describe your endpoints with controllers.

Version 2:

  • Updated npm package dependencies to use aws-sdk v3 instead.

Install

npm i --save kolp

# OR

yarn kolp

NOTE we listed koa as our peerDependencies so please include the koa in your own codebase.

Usage

Start your typescript Lambda project. Describe your endpoints with Controller style.

To expose each method as routes. Use our built-in decorator. Route which accepts method, paths, and Koa's middlwares.

controllers/hello.cotnroller.ts

import type { Context } from 'koa'
import { Route, BaseRoutedController } from 'kolp'

export class HelloController extends BaseRoutedController {

  @Route('post', '/echo')
  async migrate(context: Context) {
    return context.request
  }

  @Route()
  async index(context: Context) {
    return {
      hello: 'world'
    }
  }
}

Or you can describe your controllers in a classical way. (Avoid using decorators). This method introduce less code when it is bundled.

controllers/hello.controller.ts

import type { Context } from 'koa'
import { RouteMap, BaseRoutedController } from 'kolp'

export class HelloController extends BasedRouteController {

  public getRouteMaps(): RouteMap {
    return {
      ...super.getRouteMaps(),
      index: { method: 'get', path: '/', middlewares: [] }, // Same as our decorator above.
    }
  }

  async index(context: Context) {
    return {
      hello: 'world'
    }
  }
}

Now to use these controllers. You will need to map them to paths in the Lambda's handler. Instead of creating your own handler from scratch. Just use makeServerWithRouter method to create your handler function.

The function itself allow you to customize the created router (Root router). Here is the example.

handler.ts

import 'source-map-support/register'
import { makeServerWithRouter, withJson } from 'kolp'

import { HelloController } from './controllers/hello.controller'

export default makeServerWithRouter((router) => {
  router.prefix('/hello')
    .use(withJson())    // Json error handler!
  
  // Register your controllers here.
  new HelloController().register('/hi', router)
})

By the example above. You will be able to:

curl -XGET http://localhost:9000/hello/hi

TODO

[ ] Example repo
[ ] Inter Service Communication
[X] SNS/SQS Handler

About

a small tiny library toolbox for Lambda.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

  •  
  •