Luke Childs 9ca93eb031 Update btcpay-server app to 1.1.2 4 years ago
.github/workflows Remove use of deprecated ::set-env in GitHub Actions (#316) 4 years ago
app-data Add app framework (#333) 4 years ago
apps Update btcpay-server app to 1.1.2 4 years ago
bin Fix quoted arguments in bin helper scripts (#864) 4 years ago
bitcoin Redo configuration logic (#87) 5 years ago
db Automatic deterministic backups (#188) 4 years ago
electrs Integrate electrs (#242) 4 years ago
events Add debug trigger (#391) 4 years ago
lnd Redo configuration logic (#87) 5 years ago
logs Fix missing file descriptors when starting Umbrel from the CLI (#269) 4 years ago
nginx Add app framework (#333) 4 years ago
scripts Update Samourai Server app to v1.10.1 (#862) 4 years ago
statuses Create change-password trigger (#429) 4 years ago
templates Mention config files are reset on update (#826) 4 years ago
tor Redo configuration logic (#87) 5 years ago
.gitignore Add status server (#812) 4 years ago
.umbrel Refactor external storage logic (#93) 5 years ago
LICENSE.md Update license (#235) 4 years ago
README.md Umbrel v0.3.14 (#859) 4 years ago
SECURITY.md Document network sandboxing (#813) 4 years ago
docker-compose.yml Update to getumbrel/manager:v0.2.12 (#822) 4 years ago
info.json Umbrel v0.3.14 (#859) 4 years ago
karen Remove uneeded line from 8416b3feb7316d45d854a49fc2d68c8d12e6bafa 4 years ago

README.md

Umbrel

Version Community Chat Developer Chat

Twitter Reddit

☂️ Umbrel

⚠️ Umbrel is currently in beta and is not considered secure. Please see SECURITY.md for more details.

This is the master repository of Umbrel and contains the framework for orchestration of all containerized services running on Umbrel OS.

It is platform and architecture-agnostic, thus can be used to directly spin up instances of Umbrel without installing the Umbrel OS since all orchestrated services use multi-architecture Docker images.

We run it on Raspbery Pis (ARMv8) as a part of Umbrel OS, Ubuntu (x64) for testnet.getumbrel.com and macOS (x64) for local development.

🚀 Getting started

If you're looking to run Umbrel on:

🛠 Installation

Umbrel OS for Raspberry Pi is the easiest and the recommended way to run Umbrel. If you don't have a Raspberry Pi, you can manually install Umbrel on any hardware running a Linux-based operating system such as Ubuntu, Debian, etc by following the instructions below, but please note it's not the recommended way to run Umbrel as it's still very experimental.

Installation Requirements

Make sure your User ID is 1000 (verify it by running id -u) and ensure that your account is correctly permissioned to use docker.

Step 1. Download Umbrel

Run this in an empty directory where you want to install Umbrel. If using an external storage such as an SSD or HDD, run this inside an empty directory on that drive.

curl -L https://github.com/getumbrel/umbrel/archive/v0.3.14.tar.gz | tar -xz --strip-components=1

Step 2. Run Umbrel

# To use Umbrel on mainnet, run:
sudo ./scripts/start

# The following environment settings can only be set
# during first run of the start script and will be persisted through
# any updates

# For testnet, run:
sudo NETWORK=testnet ./scripts/start

# For regtest, run:
sudo NETWORK=regtest ./scripts/start

# For umbrel to listen on port 12345 instead of 80, run:
sudo NGINX_PORT=12345 ./scripts/start

To stop Umbrel, run:

sudo ./scripts/stop

🎹 Services orchestrated

Architecture

                          + -------------------- +
                          |   umbrel-dashboard   |
                          + -------------------- +
                                      |
                                      |
                              + ------------- +
                              |     nginx     |
                              + ------------- +
                                      |
                                      |
              + - - - - - - - - - - - + - - - - - - - - - - - +
              |                                               |
              |                                               |
   + ------------------ +                         + --------------------- +
   |   umbrel-manager   | < - - - jwt auth - - -  |   umbrel-middleware   |
   + ------------------ +                         + --------------------- +
                                                              |
                                                              |
                                            + - - - - - - - - + - - - - - - - - +
                                            |                                   |
                                            |                                   |
                                    + ------------- +                   + ------------- +
                                    |    bitcoind   | < - - - - - - - - |      lnd      |
                                    + ------------- +                   + ------------- +

️ Don't be too reckless

Umbrel is still in beta development and should not be considered secure. Read our writeup of security tradeoffs that exist today.

It's recommended that you note down your 24 secret words (seed phrase) with a pen and paper, and secure it safely. If you forget your dashboard's password, or in case something goes wrong with your Umbrel, you will need these 24 words to recover your funds in the Bitcoin wallet of your Umbrel.

You're also recommended to download a backup of your payment channels regularly as it'll be required to recover your funds in the Lightning wallet of your Umbrel in case something goes wrong. You should also always download the latest backup file before installing an update.

❤️ Contributing

We welcome and appreciate new contributions.

If you're a developer looking to help but not sure where to begin, check out these issues that have specifically been marked as being friendly to new contributors.

If you're looking for a bigger challenge, before opening a pull request please create an issue or join our community chat to get feedback, discuss the best way to tackle the challenge, and to ensure that there's no duplication of work.


"Being open source means anyone can independently review the code. If it was closed source, nobody could verify the security. I think it's essential for a program of this nature to be open source." — Satoshi Nakamoto

License

getumbrel.com