svrrouter/README.md

128 lines
5.7 KiB
Markdown
Raw Normal View History

# SVRRouter
2025-01-01 18:09:15 +01:00
SVRRouter is a router library built for use in building web applications as SVR.JS 4.x mods.
2025-01-01 18:09:15 +01:00
Example SVR.JS mod that uses SVRRouter (you will need to install the `svrrouter` npm package either in the SVR.JS installation root or globally):
2025-01-01 18:09:15 +01:00
```js
const svrrouter = require("svrrouter");
const router = svrrouter();
2025-01-01 18:09:15 +01:00
// eslint-disable-next-line no-unused-vars
router.get("/hello", (req, res, logFacilities, config, next) => {
res.writeHead(200, "OK", {
"Content-Type": "text/plain"
});
res.write("Hello World!");
res.end();
});
module.exports = router;
module.exports.modInfo = {
name: "Example mod with SVRRouter",
2025-01-01 18:09:15 +01:00
version: "0.0.0"
};
```
## Methods (exported by the `svrrouter` package)
2025-01-01 18:09:15 +01:00
### _svrrouter()_
2025-01-01 18:09:15 +01:00
Returns: the SVRRouter router, which is a SVR.JS mod function with additional functions for adding routes and middleware.
2025-01-01 18:09:15 +01:00
## Methods (provided by the SVRRouter router)
2025-01-01 18:09:15 +01:00
### _router(req, res, logFacilities, config, next)_
Parameters:
- _req_ - the SVR.JS request object
- _res_ - the SVR.JS response object
- _logFacilities_ - the SVR.JS log facilities object
- _config_ - the SVR.JS configuration object
- _next_ - the callback which passes the execution to SVR.JS mods and SVR.JS internal handlers.
The function is a SVR.JS mod callback. You can read more about the SVR.JS mod callbacks in the [SVR.JS mod API documentation](https://svrjs.org/docs/api/svrjs-api).
### _router.route(method, path, callback)_
Parameters:
- _method_ - the HTTP method, for which the route applies (_String_)
- _path_ - the route path (begins with "/"), for which the route applies. The route paths are process via the [`path-to-regexp` library](https://www.npmjs.com/package/path-to-regexp) (_String_)
2025-01-01 18:09:15 +01:00
- _callback_ - the SVR.JS mod callback applied for the route (_Function_)
Returns: the SVRRouter router (so that you can chain the methods for adding routes or pass-throughs)
The function adds a route to the SVRRouter router.
2025-01-01 18:09:15 +01:00
If the _method_ parameter is `"*"`, the route will apply to all the methods
2025-01-01 18:09:15 +01:00
The _callback_ parameter has these arguments of the SVR.JS mod callback:
- _req_ - the SVR.JS request object
- _res_ - the SVR.JS response object
- _logFacilities_ - the SVR.JS log facilities object
- _config_ - the SVR.JS configuration object
- _next_ - the callback which passes the execution to other routes, SVR.JS mods and SVR.JS internal handlers.
The _req_ object has an additional _params_ property, which contains request parameters, for example if the request URL is `/api/task/1`, and the route path is `/api/task/:id`, then the _req.params_ object is a `null` prototype object with the `id` property set to `"1"`.
The _req_ object has another additional _svrrouterBase_ property, which contains the route base used internally by a SVRRouter router. It's not recommended to override this property, as doing it may result in a SVRRouter router behaving erratically.
2025-01-01 18:09:15 +01:00
You can read more about the SVR.JS mod callbacks in the [SVR.JS mod API documentation](https://svrjs.org/docs/api/svrjs-api).
### _router.pass([path, ]callback)_
Parameters:
- _path_ - the path (begins with "/"), for which the route applies. (optional, _String_)
- _callback_ - the SVR.JS mod callback, which the SVRRouter router will pass to (_Function_)
2025-01-01 18:09:15 +01:00
Returns: the SVRRouter router (so that you can chain the methods for routes or pass-throughs)
The function adds a pass-through (can be middleware) to the SVRRouter router. The pass-through can be to an another SVRRouter router (the request URLs relative to a parent route need to be provided for the _router.route_ function in the SVRRouter router).
2025-01-01 18:09:15 +01:00
The _callback_ parameter has these arguments of the SVR.JS mod callback:
- _req_ - the SVR.JS request object
- _res_ - the SVR.JS response object
- _logFacilities_ - the SVR.JS log facilities object
- _config_ - the SVR.JS configuration object
- _next_ - the callback which passes the execution to other routes, SVR.JS mods and SVR.JS internal handlers.
The _req_ object has an additional _svrrouterBase_ property, which contains the route base used internally by a SVRRouter router. It's not recommended to override this property, as doing it may result in a SVRRouter router behaving erratically.
2025-01-01 18:09:15 +01:00
You can read more about the SVR.JS mod callbacks in the [SVR.JS mod API documentation](https://svrjs.org/docs/api/svrjs-api).
### _router.passExpressRouterMiddleware([path, ]middleware)_
Parameters:
- _path_ - the path (begins with "/"), for which the route applies. (optional, _String_)
- _middleware_ - the middleware compatible with the `router` library (_Function_)
Returns: the SVRRouter router (so that you can chain the methods for routes or pass-throughs)
The function adds middleware compatible with the `router` library to the SVRRouter router. Middleware that depends on Express's request and response properties may not work.
The _middleware_ parameter has these arguments of middleware compatible with the `router` library:
- _req_ - the request object
- _res_ - the response object
- _next_ - the callback which passes the execution to other routes, SVR.JS mods and SVR.JS internal handlers.
2025-01-01 18:09:15 +01:00
### _router.get(path, callback)_
An alias to the _router.route("GET", path, callback)_ function
### _router.post(path, callback)_
An alias to the _router.route("POST", path, callback)_ function
### _router.put(path, callback)_
An alias to the _router.route("PUT", path, callback)_ function
### _router.patch(path, callback)_
An alias to the _router.route("PATCH", path, callback)_ function
### _router.delete(path, callback)_
An alias to the _router.route("DELETE", path, callback)_ function
### _router.head(path, callback)_
An alias to the _router.route("HEAD", path, callback)_ function
### _router.all(path, callback)_
An alias to the _router.route("*", path, callback)_ function