feat: add lnbitsNostrTransportPubkey option

New services.webapp.lnbitsNostrTransportPubkey threads through as
VITE_LNBITS_NOSTR_TRANSPORT_PUBKEY at build time. Empty default
keeps existing hosts unaffected; set per-host to opt into addressing
the lnbits backend over Nostr (NIP-44 v2 kind-21000 RPC) instead of
plain HTTP.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
Padreug 2026-05-24 22:40:02 +02:00
commit ca19127584

View file

@ -41,6 +41,7 @@ let
VITE_LNBITS_BASE_URL = cfg.lnbitsBaseUrl; VITE_LNBITS_BASE_URL = cfg.lnbitsBaseUrl;
VITE_LNBITS_DEBUG = if cfg.lnbitsDebug then "true" else "false"; VITE_LNBITS_DEBUG = if cfg.lnbitsDebug then "true" else "false";
VITE_WEBSOCKET_ENABLED = if cfg.websocketEnabled then "true" else "false"; VITE_WEBSOCKET_ENABLED = if cfg.websocketEnabled then "true" else "false";
VITE_LNBITS_NOSTR_TRANSPORT_PUBKEY = cfg.lnbitsNostrTransportPubkey;
# Lightning Address Domain # Lightning Address Domain
VITE_LIGHTNING_DOMAIN = cfg.lightningDomain; VITE_LIGHTNING_DOMAIN = cfg.lightningDomain;
@ -179,6 +180,18 @@ in {
description = "Enable LNBits debug mode"; description = "Enable LNBits debug mode";
}; };
lnbitsNostrTransportPubkey = lib.mkOption {
type = lib.types.str;
default = "";
example = "ac766168d4f3232772b16002a059cdf2ffed7293a25da620a2ddbdab7691c07f";
description = ''
Hex-encoded Nostr public key identifying the LNbits instance on
the relay network. The webapp uses this to address NIP-44 v2
encrypted kind-21000 RPC requests at the lnbits backend over
Nostr instead of HTTP. Empty string = nostr transport disabled.
'';
};
websocketEnabled = lib.mkOption { websocketEnabled = lib.mkOption {
type = lib.types.bool; type = lib.types.bool;
default = true; default = true;