/udm-proxy

Caddy proxy for Ubiquiti UDM Pro

Primary LanguageShellMIT LicenseMIT

Proxy for UDM Pro

Create a reverse proxy for UDM Pro.

Work based upon unifi-utilities/unifios-utilities#149

Prerequisities

Setup

Follow the steps below to get going

  1. Download or clone this repository into /mnt/data/proxy.

  2. Customize on_boot.d/30-proxy.sh to your needs.

  3. Symlink container proxy boot script

    $ ln -sf /mnt/data/proxy/on_boot.d/30-proxy.sh /mnt/data/on_boot.d/.

  4. Run boot script (to create/update network and create CNI configuration for container)

    $ /mnt/data/on_boot.d/30-proxy.sh

    It will fail when trying to run the container, but thats okay, its just for setting op needed configuration before initial image run.

  5. Register the container with podman

    $ podman run -d --systemd=false --network proxy --name proxy -v "/mnt/data/proxy/Caddyfile:/etc/proxy/Caddyfile" xpherism/udm-proxy

  6. Run boot script again and we are done :-)

Remember to change the etc/caddy/Caddyfile to your requirements and add additional mounts to podman run if needed.
The default caddefile proxies unifi.my.domain to 10.0.0.1 (ie. unifi controller) If you keep the proxy settings for the unifi controller, then you need do following first to avoid redirect recursion

$ ln -sf /mnt/data/proxy/etc/unifi-core/config.yaml /mnt/data/unifi-os/unifi-core/.

This disabled http->https redirect from unifi controller which is the cause of the above problem.

Image

Container image xpherism/udm-proxy is caddy built with the following modules

Feel free to use the vanilla caddy docker image or roll your own depending on your needs.

To update container image, simple do

$ podman stop proxy && podman rm proxy and run boot script again :-)

For more information

To build your own image, simple fork this repository and change what you need and simple run

$ docker build --platform arm64 -t udm-proxy .

TODO

  • Add DNS proxy DoH or DoT to xpherism:udm-proxy docker image
  • If bored make a simple UI to reverse proxy :-)