Static (list of routes read once) http router for routing small domains.
cargo install urouterEdit alias.json (or any other JSON file, check --alias-file option) and cargo run
JSON file with array of sets (or set with one field of arrays of sets with --alias-file-is-set-not-a-list, may be useful i.e. Nix packaging).
Each set contains 2 necessary elements and 1 optional.
uri(string) - of URL after host (e.g.,/,some/cool/path, should not start with/(only for root))alias(set) - set of one fieldurl(string) - redirect to URL with HTTP 303 See Otherfile(string) - read file from path--dir/filewhere--diris option (default:., see--help) and respond with HTTP 200 OK withcontent-type: text/plaintext(string) - plain text with HTTP 200 OK withcontent-type: text/plainhtml(string) - plain text with HTTP 200 OK withcontent-type: text/htmlexternal(set) - download (every time) file usingureqHTTP library and response with contents of downloaded resource with HTTP 200 OK and extractedcontent-typefrom responseurl(string) - URL to downloadheaders(set, optional) - headers to include with request
agent(set, optional) - set of one necessary field and one optionalregex(string) - regular expression to match user-agent HTTP headeronly_matching(bool, optional, false by default) - if false whole alias will be visible for any user agent, if true only for regex matched
{
"alias": [
{
"uri": "/",
"alias": {
"url": "https://somecoolwebsite"
}
}
]
}[
{
"uri": "/",
"alias": {
"url": "https://somecoolwebsite"
}
},
{
"uri": "/",
"alias": {
"file": "somecoolscript"
},
"agent": {
"regex": "^curl/[0-9].[0-9].[0-9]$",
"only_matching": false
}
},
{
"uri": "text",
"alias": {
"text": "sometext"
}
},
{
"uri": "external",
"alias": {
"external": {
"url": "https://somecool.external.link",
"headers": {
"user-agent": "curl/8.6.0"
}
}
}
}
]Agent matching made for curl https://url | sh like scripts.
- Passed with
--alias_file, will look up to this path, if file doesn't exist (or no access to it) will panic - If urouter started with privileges (EUID = 0), file would be
/etc/urouter/alias.json - Otherwise if
XDG_CONFIG_HOMEis set, file would be$XDG_CONFIG_HOME/urouter/alias.json - Otherwise if
$HOMEis set, file would be$HOME/.config/urouter/alias.json - If not matched any, will panic and exit
The project is licensed under the terms of the MIT license.