mirror of
https://github.com/ivabus/urouter
synced 2024-11-10 02:25:22 +03:00
2.4 KiB
2.4 KiB
urouter
Static (list of routes read once) http router for routing small domains.
Installation
cargo install urouter
Edit alias.json
(or any other JSON file, check --alias-file
option) and cargo run
alias.json
specification
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/file
where--dir
is option (default:.
, see--help
) and respond with HTTP 200 OK withcontent-type: text/plain
text
(string) - plain text with HTTP 200 OK withcontent-type: text/plain
external
(set) - download (every time) file usingureq
HTTP library and response with contents of downloaded resource with HTTP 200 OK and extractedcontent-type
from 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
Set of array of sets (use only for very specific workarounds)
{
"alias": [
{
"uri": "/",
"alias": {
"url": "https://somecoolwebsite"
}
}
]
}
alias.json
example
[
{
"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.
License
The project is licensed under the terms of the MIT license.