Skip to content

Latest commit

 

History

History
166 lines (132 loc) · 5.01 KB

File metadata and controls

166 lines (132 loc) · 5.01 KB

Dashboard page Login page Transaction page Contacts page

Phoenixd Lightning Wallet UI (StartOS)

This project is a Lightning wallet interface built on top of Phoenixd server designed for Start9 server. It allows you to easily manage your phoenixd transactions and leverage the power of Phoenixd for your Bitcoin Lightning wallet needs.

This repository creates the s9pk package that is installed to run phoenixd-lightning-wallet-ui on StartOS. Learn more about service packaging in the Developer Docs.

Installing (on StartOS)

1. Install as a sideload serivice

  1. Download phoenixd-lightning-wallet-ui.s9pk on your Start9os server [link] (https://github.com/ZapriteApp/phoenixd-lightning-wallet-ui-startos/releases/download/v0.1.2/phoenixd-lightning-wallet-ui.s9pk)

  2. Go System > Sideload a Service

System menu

  1. Browse to upload phoenixd-lightning-wallet-ui.s9pk and install

System menu

2. Installing via cli

Run the following commands to determine successful install:

ℹ️ Change server-name.local to your Start9 server address

start-cli auth login
# Enter your StartOS password
start-cli --host https://server-name.local package install phoenixd-lightning-wallet-ui.s9pk

If you already have your start-cli config file setup with a default host, you can install simply by running:

make install

Tip: You can also install the phoenixd-lightning-wallet-ui.s9pk using Sideload Service under the System > Manage section.

Verify Install

Go to your StartOS Services page, select Phoenixd lightning wallet UI, configure and start the service. Then, verify its interfaces are accessible.

Done!

Features

  • Send and receive bitcoin with Bolt11 invoices
  • Pay offer and receive bitcoin with BOLT12 offers
  • Paginated transactions history table
  • Pay wallet contacts
  • Contacts address book
  • Password login
  • Import Wallet offer with QR Scan
  • Scan QR to pay BOLT11 invoices
  • Show bitcoin value in USD
  • Wallet seed backup confirmation before setting password
  • Wallet notifications
  • Create multiple wallets
  • Recieve bitcoin with mainnet address
  • Import wallet contacts
  • Show sats amount in USD on transction table
  • Add your BTC price fetching api
  • Choose default currency

Build it Yourself

Dependencies

Install the system dependencies below to build this project by following the instructions in the provided links. You can find instructions on how to set up the appropriate build environment in the Developer Docs.

Build s9pk file

Prepare your StartOS build environment. In this example we are using Ubuntu 20.04.

  1. Install docker
curl -fsSL https://get.docker.com | bash
sudo usermod -aG docker "$USER"
exec sudo su -l $USER
  1. Set buildx as the default builder
docker buildx install
docker buildx create --use
  1. Enable cross-arch emulated builds in docker
docker run --privileged --rm linuxkit/binfmt:v0.8
  1. Install yq
sudo snap install yq
  1. Install deno
sudo snap install deno
  1. Install essentials build packages
sudo apt-get install -y build-essential openssl libssl-dev libc6-dev clang libclang-dev ca-certificates
  1. Install Rust
curl https://sh.rustup.rs -sSf | sh
# Choose nr 1 (default install)
source $HOME/.cargo/env
  1. Build and install start-sdk
git clone https://github.com/Start9Labs/start-os.git && \
 cd start-os && git submodule update --init --recursive && \
 make sdk

Initialize sdk & verify install

start-sdk init
start-sdk --version

Now you are ready to build the phoenixd-lightning-wallet-ui package!

Cloning

Clone the project locally:

git clone https://github.com/ZapriteApp/phoenixd-lightning-wallet-ui-startos.git
cd phoenixd-lightning-wallet-ui
git submodule update --init --recursive

Building

To build the phoenixd-lightning-wallet-ui package for all platforms using start-sdk, run the following command:

make

To build the phoenixd-lightning-wallet-ui package for a single platform using start-sdk, run:

# for amd64
make x86

or

# for arm64
make arm