Security News
New Python Packaging Proposal Aims to Solve Phantom Dependency Problem with SBOMs
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
decorate-express
Advanced tools
This is a fork of @stewartml's no longer actively maintained
express-decorators
package.
Decorators for easily wiring up controller classes to Express routes.
$ npm install --save decorate-express
import { BasePath, Get, Use, registerRoutes } from 'decorate-express'
import myMiddlewareFunction from './middleware'
import express from 'express'
@BasePath('/test')
public class TestController {
constructor(target) {
this.target = target
}
@Get('/hello', myMiddlewareFunction)
async sayHelloAction(request, response) {
response.send(`Hello, ${this.target}!`)
}
@Use()
async otherMiddleware(request, response, next) {
// This middleware will be called for every action.
next()
}
}
let app = express()
let test = new TestController('world')
registerRoutes(app, test)
When can now go to /test/hello
and get Hello, world!
back.
this
is an instance of the class).Promise
's or be async
functions and errors will get handled properly.@BasePath(path: string)
Class decorator to add a base path to every route defined in the class.
@Middleware(fn: Middleware)
If fn
is a function, then the function is added as route-specific middleware for the action. Note that the middleware will be bound to the controller instance.
If fn
is a string, then the method with that name will be exectued as route-specific middleware when the action is invoked.
@Param(param: string)
Marks the method as a handler for all routes that use the specified parameter. This can be useful if you want to do something with it before it's passed on to the actual route handler, for example converting a string to an integer:
@Param('id')
idParam(request, response, next, id) {
request.params.id = parseInt(request.params.id)
next()
}
@Route(method: string, path: string, middleware: Middleware[])
Marks the method as a handler for the specified path and HTTP method.
Instead of passing the HTTP method into the @Route
decorator you can also use one of the provided shortcuts. @Get('/path')
for example is equivalent to @Route('get', '/path')
.
@All
@Delete
@Get
@Options
@Patch
@Post
@Put
@Use
getRoutes(target: Object): Route[]
Gets the route metadata for the target object. Paths are automatically prefixed with a base path if one was defined.
registerRoutes(router: Express.Router, target: Object)
Registers the routes found on the target object with an express Router instance.
Please feel free to start an issue or offer a pull request.
FAQs
Route decorators for Express.
We found that decorate-express demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.
Security News
Socket CEO Feross Aboukhadijeh discusses open source security challenges, including zero-day attacks and supply chain risks, on the Cyber Security Council podcast.
Security News
Research
Socket researchers uncover how threat actors weaponize Out-of-Band Application Security Testing (OAST) techniques across the npm, PyPI, and RubyGems ecosystems to exfiltrate sensitive data.