routeswitch
v0.6.3
Published
A fast regexp-based router. Supports Swagger 2 specs.
Downloads
64
Readme
RouteSwitch
Simple and fast regexp-based switcher on regexps or URL patterns. Supports building a switcher from Swagger 2.0 API specs.
Installation
npm install routeswitch
Documentation
Path specs are defined in a subset of RFC 6570 URL patterns:
/{foo}/{bar}
-- matches two non-empty path components/{foo}/{bar}/
-- only matches with trailing slash/foo{/bar}
-- optionally matches a slash and a path component, if not empty/{+foo}
-- matches any non-empty path, including slashes
In the event of route overlaps, the most specific & shortest routes will win:
- regexps
- paths with fixed segments
- paths with templated segments
Examples:
/foo/{bar}
gets a higher precedence than/{some}/{thing}
and/{some}
Construction
RouteSwitch.fromDirectory(path, [options]) -> Promise<RouteSwitch>
Loads all modules in a directory tree. Modules can either directly export a Swagger 2.0 spec with optional additional data (such as a reference to a handler), or they can export a function returning a promise for the spec. Returns a promise for a RouteSwitch.
By default, RouteSwitch loads each handler by passing its path to require()
.
This can be overridden by providing a custom loader, implemented as a function
that takes a path and returns a spec fragment, and included in the optional
options
object under the loader
key:
RouteSwitch.fromDirectory(path, { loader: myLoaderFn })
RouteSwitch.fromHandlers(specs) -> RouteSwitch
Builds a RouteSwitch directly from an array of spec fragments.
new RouteSwitch(routes) -> RouteSwitch
Low-level construction. Routes are objects with the following members:
pattern
: either aRegExp
, or a URL patternmethods
: an arbitrary object, which will be returned as a member on successful.match(uri)
. Typically this is the object providing the method handlers for the route defined bypattern
.
Dynamic route addition / removal
RouteSwitch.addRoute(route)
Add a route to a RouteSwitch instance.
RouteSwitch.removeRoute(route)
Remove a route from a RouteSwitch instance.
Matching
RouteSwitch.match(uri) -> (null | object)
Returns null when there is no match. On match, it returns an object containing
pattern
: the matched URL patternmethods
: the original Swagger spec object defined for this pattern, keyed on method (lowercase)params
: Named parameters defined in the URL pattern
Example spec fragment
{
paths: {
'/v1/{domain}': {
put: {
summary: "Create or update a domain",
// optionally, more swagger docs optionally
request_handler: this.putDomain.bind(this)
}
},
'/v1/{domain}/': {
get: {
summary: "List buckets and tables for a domain",
request_handler: this.listBuckets.bind(this)
}
},
'/v1/{domain}/{bucket}': {
put: {
summary: "Create or update a bucket",
request_handler: this.putBucket.bind(this)
},
get: {
summary: "Get bucket metadata",
request_handler: this.getBucket.bind(this)
}
},
'/v1/{domain}/{bucket}/': {
get: {
request_handler: this.handleAll.bind(this)
}
},
'/v1/{domain}/{bucket}/{+rest}': {
all: {
request_handler: this.handleAll.bind(this)
}
}
}
};