unifios-utilities/on-boot-script/README.md

96 lines
3.3 KiB
Markdown
Raw Normal View History

2020-05-31 13:40:04 +00:00
# UDM / UDMPro Boot Script
2020-07-13 05:37:04 +00:00
## Features
2020-05-31 13:40:04 +00:00
1. Allows you to run a shell script at S95 anytime your UDM starts / reboots
1. Persists through reboot and **firmware updates**! It is able to do this because Ubiquiti caches all debian package installs on the UDM in /mnt/data, then re-installs them on reset of unifi-os container.
2020-07-13 05:37:04 +00:00
## Compatibility
2020-05-31 13:40:04 +00:00
2020-05-31 15:52:00 +00:00
1. Should work on any UDM/UDMPro after 1.6.3
2021-01-30 00:31:28 +00:00
2. Tested and confirmed on 1.6.6, 1.7.0, 1.7.2rc4, 1.7.3rc1, 1.8.0rc7, 1.8.0+
2020-05-31 16:35:32 +00:00
### Upgrade from earlier way
2020-07-13 05:37:04 +00:00
* As long as you didn't change the filenames, installing the deb package is all you need to do. If you want to clean up beforehand anyways....
2020-07-13 05:37:04 +00:00
```bash
rm /etc/init.d/udm.sh
systemctl disable udmboot
rm /etc/systemd/system/udmboot.service
```
* [build_deb.sh](build_deb.sh) can be used to build the package by yourself.
* [dpkg-build-files](dpkg-build-files) contains the sources that debuild uses to build the package if you want to build it yourself / change it
* by default it uses docker or podman to build the debian package
2021-05-25 17:40:39 +00:00
* use ```./build_deb.sh build``` to not use a container
* the resulting package will be in [packages/](packages/)
* Built on Ubuntu-20.04 on Windows 10/WSL2
2020-06-05 03:50:23 +00:00
## Install
You can execute in UDM/Pro/SE and UDR with:
```bash
curl -fsL "https://raw.githubusercontent.com/unifi-utilities/unifios-utilities/HEAD/on-boot-script/remote_install.sh" | /bin/sh
```
This is a force to install script so will uninstall any previous version and install on_boot keeping your on boot files.
This will also install CNI Plugins & CNI Bridge scripts. If you are using UDMSE/UDR remember that you must install podman manually because there is no podman.
## Manually Install Steps
2020-07-13 05:37:04 +00:00
1. Get into the unifios shell on your udm
2020-07-13 05:37:04 +00:00
```bash
unifi-os shell
```
2021-05-25 18:25:55 +00:00
2. Download [udm-boot_1.0.5_all.deb](packages/udm-boot_1.0.5_all.deb) and install it and go back to the UDM. The latest package will always be found at https://udm-boot.boostchicken.dev
2020-07-13 05:37:04 +00:00
```bash
2023-01-17 13:46:14 +00:00
curl -L [[https://udm-boot.boostchicken.dev](https://unifi.boostchicken.io/udm-boot_1.0.5_all.deb)](https://unifi.boostchicken.io/udm-boot_1.0.5_all.deb) -o udm-boot_1.0.5_all.deb
2021-05-25 18:25:55 +00:00
dpkg -i udm-boot_1.0.5_all.deb
2022-07-19 13:28:16 +00:00
systemctl enable udm-boot
2020-07-13 05:37:04 +00:00
exit
```
3. Copy any shell scripts you want to run to /mnt/data/on_boot.d on your UDM (not the unifi-os shell) and make sure they are executable and have the correct shebang (#!/bin/sh). Additionally, scripts need to have a `.sh` extention in their filename.
2020-07-13 05:37:04 +00:00
Examples:
* Start a DNS Container [10-dns.sh](../dns-common/on_boot.d/10-dns.sh)
2020-07-06 05:39:21 +00:00
* Start wpa_supplicant [on_boot.d/10-wpa_supplicant.sh](examples/udm-files/on_boot.d/10-wpa_supplicant.sh)
2021-12-28 13:31:40 +00:00
* Add a persistent ssh key for the root user [on_boot.d/15-add-root-ssh-keys.sh](examples/udm-files/on_boot.d/15-add-root-ssh-keys.sh)
2020-07-07 07:52:02 +00:00
## Version History
2021-05-25 17:40:39 +00:00
### 1.0.5
* Remove on_boot.sh from UDM
* Follow symlinks
2021-05-25 18:25:55 +00:00
* move to network-online.target
2021-05-25 17:40:39 +00:00
2021-01-30 01:17:19 +00:00
### 1.0.4
* Fix 600s timeout issues
* Fix rc.d policy issue
2021-01-30 00:31:28 +00:00
### 1.0.3
* Fix not working after firmware upgrade
2021-01-30 01:00:54 +00:00
* Added udm-boot.boostchicken.dev domain
2021-01-30 00:31:28 +00:00
### 1.0.2
* Some build improvements and more clean installation
2020-07-07 07:52:02 +00:00
### 1.0.1
2020-07-13 05:37:04 +00:00
2020-07-07 07:52:02 +00:00
* Fully automated install, all that is left is populating /mnt/data/on_boot.d
### 1.0.0
2020-07-13 05:37:04 +00:00
2020-07-13 05:38:01 +00:00
* First release that persists through firmware