LNbits, free and open-source lightning-network wallet/accounts system.
Go to file
schneimi fb98576431
[FEAT] Push notification integration into core (#1393)
* push notification integration into core

added missing component

fixed bell working on all pages
- made pubkey global template env var
- had to move `get_push_notification_pubkey` to `helpers.py` because of circular reference with `tasks.py`

formay

trying to fix mypy

added py-vapid to requirements

Trying to fix stub mypy issue

* removed key files

* webpush key pair is saved in db `webpush_settings`

* removed lnaddress extension changes

* support for multi user account subscriptions, subscriptions are stored user based

fixed syntax error

fixed syntax error

removed unused line

* fixed subscribed user storage with local storage, no get request required

* method is singular now

* cleanup unsubscribed or expired push subscriptions

fixed flake8 errors

fixed poetry errors

* updating to latest lnbits

formatting, rebase error

fix

* remove unused?

* revert

* relock

* remove

* do not create settings table use adminsettings

mypy

fix

* cleanup old code

* catch case when client tries to recreate existing webpush subscription e.g. on cleared local storage

* show notification bell on user related pages only

* use local storage with one key like array, some refactoring

* fixed crud import

* fixed too long line

* removed unused imports

* ruff

* make webpush editable

* fixed privkey encoding

* fix ruff

* fix migration

---------

Co-authored-by: schneimi <admin@schneimi.de>
Co-authored-by: schneimi <dev@schneimi.de>
Co-authored-by: dni  <office@dnilabs.com>
2023-09-11 14:48:49 +01:00
.github [TEST] workflows, added 10s timeout to lncli subprocess and logging (#1910) 2023-08-30 11:01:32 +01:00
docs support uvicorn reload functionality (#1841) 2023-08-03 09:53:36 +02:00
lnbits [FEAT] Push notification integration into core (#1393) 2023-09-11 14:48:49 +01:00
nix FEAT: precommit git hooks, based on fusions #913 (#1645) 2023-05-09 09:41:40 +01:00
tests Add deleted flag wallet (#1826) 2023-09-11 14:06:31 +01:00
tools [CHORE] string formatting default length 88 (#1887) 2023-08-24 10:26:09 +01:00
.dockerignore good bye venv (#1569) 2023-03-16 16:45:23 +01:00
.env.example Wallets: add cln-rest (#1775) 2023-08-23 08:59:39 +02:00
.gitignore [REFACTOR] .super_user move it into data dir (#1900) 2023-09-11 12:19:19 +01:00
.pre-commit-config.yaml [CHORE] string formatting default length 88 (#1887) 2023-08-24 10:26:09 +01:00
.prettierignore ignore upgrades dir in linters and formatters and precommit (#1783) 2023-06-26 10:38:40 +02:00
.prettierrc FIX: prettier formatting (#1395) 2023-01-23 14:23:30 +01:00
Dockerfile Update poetry to 1.5.1 (#1804) 2023-07-11 12:46:40 +02:00
flake.lock flake: update to latest nixpkgs 2023-03-17 18:03:33 +01:00
flake.nix flake: update to latest nixpkgs 2023-03-17 18:03:33 +01:00
LICENSE Update LICENSE 2022-01-30 08:27:05 -03:00
Makefile [REFACTOR] replace async_wrap with run_sync (#1858) 2023-08-28 10:59:56 +01:00
package-lock.json fix bundle for 0.10.9 (#1792) 2023-07-03 10:29:03 +02:00
package.json Create cn.js (#1768) 2023-06-20 08:41:04 +02:00
poetry.lock [FEAT] Push notification integration into core (#1393) 2023-09-11 14:48:49 +01:00
pyproject.toml [FEAT] Push notification integration into core (#1393) 2023-09-11 14:48:49 +01:00
README.md Update README.md (#1818) 2023-07-11 09:34:21 +01:00

LNbits

license-badge docs-badge

Lightning network wallet

LNbits v0.10 BETA, free and open-source Lightning wallet accounts system

(Join us on https://t.me/lnbits)

LNbits is beta, for responsible disclosure of any concerns please contact lnbits@pm.me

Use legend.lnbits.com, or run your own LNbits server!

LNbits is a Python server that sits on top of any funding source. It can be used as:

  • Accounts system to mitigate the risk of exposing applications to your full balance via unique API keys for each wallet
  • Extendable platform for exploring Lightning network functionality via the LNbits extension framework
  • Part of a development stack via LNbits API
  • Fallback wallet for the LNURL scheme
  • Instant wallet for LN demonstrations

LNbits can run on top of any Lightning funding source. It supports LND, CLN, Eclair, Spark, LNpay, OpenNode, LightningTipBot, and with more being added regularly.

See LNbits Wiki for more detailed documentation.

Checkout the LNbits YouTube video series.

LNbits is inspired by all the great work of opennode.com, and in particular lnpay.co. Both work as funding sources for LNbits.

Running LNbits

See the install guide for details on installation and setup.

LNbits as an account system

LNbits is packaged with tools to help manage funds, such as a table of transactions, line chart of spending, export to csv + more to come..

Lightning network wallet

Each wallet also comes with its own API keys, to help partition the exposure of your funding source.

(LNbits M5StackSats available here https://github.com/arcbtc/M5StackSats)

lnurl ATM

LNbits as an LNURL-withdraw fallback

LNURL has a fallback scheme, so if scanned by a regular QR code reader it can default to a URL. LNbits exploits this to generate an instant wallet using the LNURL-withdraw.

lnurl fallback

Using lnbits.com/?lightning="LNURL-withdraw" will trigger a withdraw that builds an LNbits wallet. Example use would be an ATM, which utilises LNURL, if the user scans the QR with a regular QR code scanner app, they will still be able to access the funds.

lnurl ATM

LNbits as an instant wallet

Wallets can be easily generated and given out to people at events. "Go to this website", has a lot less friction than "Download this app".

lnurl ATM

Tip us

If you like this project send some tip love!