hapi-class-extension-points
TypeScript icon, indicating that this package has built-in type declarations

2.1.0 • Public • Published
hapi-class-extension-points logo

Use class methods to add lifecycle extension points to your hapi server.


Installation · Usage · Contribute



Build Status Known Vulnerabilities hapi-class-extension-points Version Monthly downloads

Follow @marcuspoehls for updates!


The Future Studio University supports development of this hapi plugin 🚀
Join the Future Studio University and Skyrocket in Node.js


Introduction

This hapi plugin adds the server.extClass(class) decoration to register lifecycle extensions from class methods.

Requirements

hapi v19 (or later) and Node.js v12 (or newer)

This plugin requires hapi v19 (or later) and Node.js v12 or newer.

Compatibility

Major Release hapi.js version Node.js version
v2 >=17 hapi >=12
v1 >=17 hapi >=8

Installation

Add hapi-class-extension-points as a dependency to your project:

npm i hapi-class-extension-points

Usage

Register hapi-class-extension-points to your hapi server. This will decorate the hapi server with a server.extClass() method:

await server.register({
  plugin: require('hapi-class-extension-points')
})
 
// went smooth like chocolate :)
// now your hapi server supports 'server.extClass(class MyMiddleware {})'

Having the plugin registered, you can now write your lifecycle extension points as classes:

class RateLimiting {
  constructor (server) {
    this.server = server
  }
 
  async onRequest (request, h) {
    // rate limit the request
 
    await this.handle(request)
 
    return h.continue
  }
 
  async handle (request) {
    // this is a private method that won't be registered as a lifecycle extension
  }
 
  onPreResponse (request, h) {
    // add rate limiting headers
 
    return h.continue
  }
}
 
server.extClass(RateLimiting)

That's it! The constructor of your class receives the hapi server. You can then store it as a class property and use it when needed!

Enjoy!

Links & Resources

Contributing

  1. Create a fork
  2. Create your feature branch: git checkout -b my-feature
  3. Commit your changes: git commit -am 'Add some feature'
  4. Push to the branch: git push origin my-new-feature
  5. Submit a pull request 🚀

License

MIT © Future Studio


futurestud.io  ·  GitHub @futurestudio  ·  Twitter @futurestud_io

Package Sidebar

Install

npm i hapi-class-extension-points

Weekly Downloads

1

Version

2.1.0

License

MIT

Unpacked Size

39.2 kB

Total Files

13

Last publish

Collaborators

  • marcuspoehls