27 releases

0.1.10 Dec 17, 2024
0.1.8 Oct 21, 2024
0.1.5 Sep 26, 2024
0.0.13 Apr 17, 2024
0.0.1-alpha8 Oct 30, 2023

#92 in HTTP server

Download history 112/week @ 2024-09-18 175/week @ 2024-09-25 123/week @ 2024-10-02 16/week @ 2024-10-09 130/week @ 2024-10-16 34/week @ 2024-10-23 1/week @ 2024-10-30 4/week @ 2024-11-06 17/week @ 2024-11-27 133/week @ 2024-12-04 204/week @ 2024-12-11 91/week @ 2024-12-18 22/week @ 2024-12-25 49/week @ 2025-01-01

403 downloads per month

Custom license

3MB
19K SLoC

Rust 12K SLoC // 0.1% comments TSX 6K SLoC // 0.0% comments TypeScript 1K SLoC // 0.2% comments JavaScript 328 SLoC // 0.3% comments Shell 16 SLoC // 0.3% comments

Contains (WOFF font, 99KB) fontawesome-webfont.woff, (WOFF font, 78KB) fontawesome-webfont.woff2, (WOFF font, 45KB) open-sans-v17-all-charsets-300.woff2, (WOFF font, 41KB) open-sans-v17-all-charsets-300italic.woff2, (WOFF font, 45KB) open-sans-v17-all-charsets-600.woff2, (WOFF font, 43KB) open-sans-v17-all-charsets-600italic.woff2 and 18 more.

BuildAndTest

ODD-BOX

A simple, cross-platform reverse proxy server tailored for local development and tinkering. Think of it as a lightweight (and more streamlined) alternative to something like IIS, but with a key difference: configuration is primarily done declaratively through structured files, rather than a graphical user interface.

It allows you to configure a list of processes to run and host them behind their own custom hostnames. Self-signed certificates for HTTPS are automatically generated when accessing a site thru the terminating proxy service the first time (cached in .odd-box-cache dir). As with most reverse-proxy servers, odd-box also supports targetting remote backend servers.

As configuration is done thru basic files (toml format) which are easy to share, it's very easy to reproduce a particular setup.

Pre-built binaries are available in the release section.

You can also build it yourself, or install it using brew, cargo, nix or devbox; see the installation section for guidance.

Screenshot(s)

odd-box v0.1.2: Screenshot of oddbox v0.1.2

odd-box web-ui v0.1.8: Screenshot of oddbox v0.1.8

Getting Started

You can generate a basic "odd-box.toml" config file to get started:

odd-box --init 

The resulting file will look something like this:

#:schema https://raw.githubusercontent.com/OlofBlomqvist/odd-box/main/odd-box-schema-v2.2.json

# Global settings
version = "V2"
ip = "127.0.0.1" 
http_port = 8080        
tls_port = 4343        

# ==========================================================

# This serves the directory where this file is located on the dir.localtest.me domain.
[[dir_server]]
host_name = "dir.localtest.me"
dir = "$cfg_dir"

# This sets up a basic reverse proxy to lobste.rs which you can reach thru the lobsters.localtest.me domain
[[remote_target]] 
host_name = "lobsters.localtest.me" 
backends = [ 
    { address = "lobste.rs", port = 443, https = true }
]

# This will spin up a python http server in the root directory of the config file (where this file is) -
# you can reach it thru the py.localtest.me domain.
[[hosted_process]]
host_name = "py.localtest.me"
bin = "python"
auto_start = false
args = ["-m", "http.server", "$port"] 

# Example for running a docker container
[[hosted_process]]
host_name = "nginx.localhost"
bin = "podman"
args = [ 
    "run",
    "--replace",
    "--quiet", 
    "-p$port:80", # incoming $port is handled by odd-box
    "nginx" # <-- image name
]

# oh and you can ofc also host processes that dont actually listen to a port
# but you just want to keep running :)

From here, you can either open up the config file in your favorite editor, or just run odd-box and open your browser going to http://localhost:1234 where you can configure odd-box thru its web-interface.

Documentation

For more in depth guidance on using odd-box, see the documentation.

Dependencies

~97–145MB
~3M SLoC