Go to file
Micah Hausler 070ff2ade6
fix(nspawn-container): Retry 0-setup-system.sh on failure (#586)
Other system processes can acquire a dpkg frontend lock on startup that
will cause the downloaded package install to fail. The setup script
continues without exiting and machinectl is not found.

This change forces the script to exit early on error, and adds 5 retries
to the systemd unit at 30s intervals.

Signed-off-by: Micah Hausler <hausler.m@gmail.com>
2024-01-11 10:05:01 -08:00
.github Update podman-udmp-udmse.yml 2023-04-17 16:51:50 -07:00
AdguardHome Update README.md (#520) 2023-03-19 03:57:47 -07:00
att-ipv6 Fixed auto path created for att-ipv6 (#493) 2023-02-22 08:54:05 -08:00
cloudflare-ddns moved to bash (#499) 2023-02-22 21:44:27 -08:00
cloudflared add cloudflared scripts (#571) 2023-11-23 07:45:18 -08:00
cni-plugins ensure /etc/cni/net.d directory exists before using it (#506) 2023-03-01 16:39:47 -08:00
container-common moved to bash (#499) 2023-02-22 21:44:27 -08:00
dns-common/on_boot.d moved to bash (#499) 2023-02-22 21:44:27 -08:00
haproxy moved to bash (#499) 2023-02-22 21:44:27 -08:00
hdhomerun moved to bash (#499) 2023-02-22 21:44:27 -08:00
homebridge moved to bash (#499) 2023-02-22 21:44:27 -08:00
ipt-enable-logs moved to bash (#499) 2023-02-22 21:44:27 -08:00
modern-unix Add modern-unix directory (#502) 2023-03-01 16:39:34 -08:00
mosquitto moved to bash (#499) 2023-02-22 21:44:27 -08:00
nextdns Auto set correct data path (#491) 2023-02-22 08:49:54 -08:00
nspawn-container fix(nspawn-container): Retry 0-setup-system.sh on failure (#586) 2024-01-11 10:05:01 -08:00
on-boot-script Updates cron job file to work with /crond and /cron (#519) 2023-03-19 03:57:21 -07:00
on-boot-script-2.x moved to bash (#499) 2023-02-22 21:44:27 -08:00
persist-changes moved to bash (#499) 2023-02-22 21:44:27 -08:00
podman-install moved to bash (#499) 2023-02-22 21:44:27 -08:00
podman-update Update Dockerfile (#536) 2023-04-17 16:53:52 -07:00
python moved to bash (#499) 2023-02-22 21:44:27 -08:00
rclone moved to bash (#499) 2023-02-22 21:44:27 -08:00
run-pihole Update Dockerfile 2023-04-04 15:56:28 -07:00
static-ips Update att-fiber.md 2023-02-22 21:49:59 -08:00
suricata moved to bash (#499) 2023-02-22 21:44:27 -08:00
tailscale moved to bash (#499) 2023-02-22 21:44:27 -08:00
traffic-mirror Add traffic mirroring capability for UDM-SE #568 (#569) 2023-11-23 07:44:38 -08:00
unbound Add missing directory back (#527) 2023-04-04 02:50:12 -07:00
wireguard-go moved to bash (#499) 2023-02-22 21:44:27 -08:00
zerotier-one change to official zerotier image (#529) 2023-04-17 15:01:55 -07:00
.gitignore Added some features to README (#258) 2021-11-05 12:35:36 -07:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2021-11-16 08:09:12 -08:00
CONTRIBUTING.md Clean up the markdown 2022-02-24 09:26:04 +01:00
LICENSE Initial commit 2020-05-31 06:17:59 -07:00
README.md Update README.md to document breaking changes in 3.x (#584) 2024-01-11 10:04:48 -08:00

unifios-utilities Discord !Cloudflare

UDM Podman UDM-Pro-SE Podman

Branches

  1. 1.12.x - Support for 1.x.x firmware line
  2. main - Support for 2.4.x and above

Current Branch is main, supporting UniFi OS 2.5.x

A collection of things to enhance the capabilities of your Unifi Dream Machine, Dream Machine Pro or UXG-Pro.

⚠️ Breaking Changes for UniFi OS 3.x

UniFi OS 3.x no longer supports podman. The utilities in this respository may not work as documented. For alternatives, review the documentation in nspawn-container or consider direct installations like wpa_supplicant-UniFi-OS-3.x for AT&T Fiber.


Custom Kernel

If you want to do a custom kernel with wireguard support, multicast, multipath routing that is now a possiblity. Please see the repo and please use at your own risk. This a much larger change than anything in this repo.

udm-kernel-tools

Custom Podman Builds for UDM-SE

All artifacts can be found on IPFS

IPFS Gateway Cloudflare

Extract the zip to the root of your device! Look at the assets on the Podman workflow.

UDM Base

Standard Image for base UDM, systemd removed

UDM Pro / SE

Base build with apparmor, systemd, devicemapper removal, and overlay kept

Works on PRO on 2.x, for 1.x use the UDM Base still.

Does not work on 3.x use nspawn-container

macvlan kernel module for UDR

Ui have stopped building the macvlan kernel module into the kernel for the UDR, which means containers cannot have their own routable IPs out of the box. This module is being built and distributed separately, and can be found at macvlan-unifi-udr.

General Tools

on-boot-script-2.x

Do this first. Enables init.d style scripts to run on every boot of your UDM. Includes examples to run wpa-supplicant/eap-proxy and/or ntop-ng on startup. Follow this readme.

It enables complete customization of your UDM/P and fills the gap that config.gateway.json left behind.

nspawn-container

Enables containers on UniFiOS 3.x, this replaces podman.

podman-update

Updates Podman, conmon, and runc to a recent version.This allows docker-compose usage as well.

Works on PRO on 2.x, for 1.x use the UDM Base still.

Does not working on 3.x use nspawn-container

container-common

Apply this after on-boot-script. Updates container defaults to maintain stable disk usage footprint of custom containers. Prevents logs filling up UDM storage full.

python

If you need python3 on your UDM, generally not recommended, can always use it in unifi-os container.

VPN Servers / Clients

Name URL Description
wireguard-go Run a Wireguard client/server
WireGuard kernel module https://github.com/tusc/wireguard-kmod Uses a prebuilt linux kernel module, without the need to move to a custom kernel.
OpenConnect VPN https://github.com/shuguet/openconnect-udm OpenConnect VPN Client for the UniFi Dream Machine Pro (Unofficial).
split-vpn https://github.com/peacey/split-vpn A split tunnel VPN script for the UDM with policy based routing. This helper script can be used on your UDM to route select VLANs, clients, or even domains through a VPN connection. It supports OpenVPN, WireGuard, and OpenConnect (Cisco AnyConnect) clients running directly on your UDM, and external VPN clients running on other servers on your network.
Zerotier https://zerotier.com ZeroTier provides network control and P2P functionality · Use ZeroTier to create products which run on their own decentralized networks

DNS Providers

Install a DNS server that functions as a network-wide ad and tracker blocker, and which can also securely proxy encrypted DNS requests to an upstream DNS provider. Begin by following the instructions to setup on-boot-script and dns-common. Then, follow the guides below to setup either Pi-Hole, NextDNS, or AdGuard Home.

dns-common

Base configuration for DNS server containers, both IPv4 and IPv6. Utilizes MacVLAN CNI plugins to completely isolate the network stack.

nextdns

Run NextDNS on your UDM with podman.

run-pihole

!Docker Pulls

PiHole w/ DoH Image. Run Pi-hole on your UDM with podman. Also contains custom image for Pi-hole with cloudflared.

PiHole with DoTe

!Docker Pulls

Designed by: https://github.com/chrisstaite/DoTe/

Alternative to mine which uses DoTe

AdguardHome

Run AdguardHome on your UDM with podman.

Cloudflare DDNS

Cloudflare

Update your cloudflare domains from your UDM with podman.

Cool projects you can use with this

Name URL Description
multicast-relay https://hub.docker.com/r/scyto/multicast-relay This is a docker container that implements https://github.com/alsmith/multicast-relay to provide mDNS and SSDP on a unifi dream machine. It will likely work on any multi homed host.
mosquitto https://hub.docker.com/_/eclipse-mosquitto Eclipse Mosquitto is an open source MQTT message broker
ntopng https://github.com/tusc/ntopng-udm Much better network stats for your UDM/P! Install this docker container and create an on_boot script to make sure it's always running.
LetsEncrypt https://github.com/kchristensen/udm-le Provision and renew LetsEncrypt SSL certs from your UDM/P.
ubios-cert https://github.com/alxwolf/ubios-cert Provision and renew SSL/TLS certificates from LetsEncrypt, ZeroSSL, BuyPass, Google and any other RFC8555-compliant CA. Runs acme.sh on your UDM, UDM Pro, UDM SE or UDR. No podman required, supports both V1.x and V2.x firmwares. Secure your HTTPS connections to device, WiFiman and Guest Portal.
Unifi API Browser https://hub.docker.com/r/scyto/unifibrowser This is a docker container that implements https://github.com/Art-of-WiFi/UniFi-API-browser to provide a graphical tool to inspect the data structures available via the unifi API.Great if you are using the REST API for your own purposes and want to explore.Works with multiple controller versions.
ubnt-auto-fan-speed https://github.com/renedis/ubnt-auto-fan-speed A shell script with the goal to make the UDM-Pro silenced while still having good thermal values.
rclone https://rclone.org/ Run rclone container with Web GUI for offsite backups.
udm-proxy https://github.com/xpherism/udm-proxy Run a reverse proxy (using caddy in vlan) on the udm-pro.
Telegram-Notifications On WAN Failover https://github.com/fire1ce/UDM-Failover-Telegram-Notifications Use telegram bot to be notified of a wan failover with local account

!Protected by Cloudflare

Unsupported / No longer maintained

Name URL Description
suricata Updates suricata to a recent version. Now in firmware
Jumbo Frames https://github.com/kalenarndt/udmp-jumbo-frames native jumbo frame support for the UDM and UDM-Pro is added in the 1.12.13 EA firmware, support for the UDM-SE is not yet announced.
UDM Persistent SSH Keys Script https://github.com/fire1ce/UDM-Persistent-SSH-Keys Stores SSH Keys. This functionality is now in firmware

Reimaging your UDM

Working in the shell means that mistakes can happen. Deleted directories or packages may break the underlying software that makes your UDM-Pro SE function as designed. Thankfully, Unifi Support seems to have provided the following process to help bring your UDM back to the stock image.

  1. Remove the unit from your network and disconnect the cables from the unit.
  2. Press down the reset button for 40+ seconds without power and cables.
  3. Release the reset button and power the unit.
  4. Again press the reset button for 15+ seconds.

Thanks to user cfallwell for describing this fix here.