2024-10-04 17:53:32 +01:00
|
|
|
{
|
|
|
|
inputs,
|
|
|
|
lib,
|
|
|
|
config,
|
2024-10-07 14:19:27 +01:00
|
|
|
configVars,
|
2024-10-04 17:53:32 +01:00
|
|
|
pkgs,
|
|
|
|
...
|
|
|
|
}: let
|
|
|
|
bitcoin-rpcpassword-privileged = lib.optionalString (lib.hasAttr "sops-nix" inputs) config.sops.secrets."software/bitcoind/bitcoin-rpcpassword-privileged".path;
|
|
|
|
bitcoin-rpcpassword-public = lib.optionalString (lib.hasAttr "sops-nix" inputs) config.sops.secrets."software/bitcoind/bitcoin-rpcpassword-public".path;
|
|
|
|
bitcoin-HMAC-privileged = lib.optionalString (lib.hasAttr "sops-nix" inputs) config.sops.secrets."software/bitcoind/bitcoin-HMAC-privileged".path;
|
|
|
|
bitcoin-HMAC-public = lib.optionalString (lib.hasAttr "sops-nix" inputs) config.sops.secrets."software/bitcoind/bitcoin-HMAC-public".path;
|
2024-10-07 14:19:27 +01:00
|
|
|
containerName = "bitcoin-node";
|
|
|
|
containerIp = configVars.networking.addresses.bitcoin-node.ip;
|
2024-10-10 01:37:37 +01:00
|
|
|
mempoolPort = configVars.networking.addresses.bitcoin-node.services.mempool.port;
|
2024-10-07 14:19:27 +01:00
|
|
|
gatewayIp = configVars.networking.addresses.gateway.ip;
|
|
|
|
allowip = configVars.networking.addresses.bitcoin-node.services.bitcoind.allowip;
|
2024-10-06 17:25:27 +01:00
|
|
|
pubKeys = lib.filesystem.listFilesRecursive ../../users/keys;
|
2024-10-04 17:53:32 +01:00
|
|
|
in {
|
|
|
|
sops.secrets = {
|
|
|
|
"software/bitcoind/bitcoin-rpcpassword-privileged" = {};
|
|
|
|
"software/bitcoind/bitcoin-rpcpassword-public" = {};
|
|
|
|
"software/bitcoind/bitcoin-HMAC-privileged" = {};
|
|
|
|
"software/bitcoind/bitcoin-HMAC-public" = {};
|
|
|
|
};
|
|
|
|
|
2024-10-06 17:25:27 +01:00
|
|
|
environment.persistence."/persist" = {
|
|
|
|
hideMounts = true;
|
|
|
|
directories = [
|
2024-10-07 14:19:27 +01:00
|
|
|
"/var/lib/nixos-containers/${containerName}"
|
2024-10-06 17:25:27 +01:00
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2024-10-04 17:53:32 +01:00
|
|
|
networking.nat.enable = true;
|
|
|
|
networking.nat.internalInterfaces = ["ve-+"];
|
2024-10-05 16:42:16 +01:00
|
|
|
networking.nat.externalInterface = "br0";
|
2024-10-04 17:53:32 +01:00
|
|
|
|
2024-10-07 14:19:27 +01:00
|
|
|
containers.${containerName} = {
|
2024-10-04 17:53:32 +01:00
|
|
|
autoStart = true;
|
|
|
|
privateNetwork = true;
|
2024-10-05 16:42:16 +01:00
|
|
|
hostBridge = "br0";
|
2024-10-04 17:53:32 +01:00
|
|
|
nixpkgs = pkgs.path;
|
|
|
|
bindMounts = {
|
|
|
|
"/etc/nix-bitcoin-secrets/bitcoin-rpcpassword-privileged" = {
|
|
|
|
hostPath = "${bitcoin-rpcpassword-privileged}";
|
|
|
|
isReadOnly = false;
|
|
|
|
};
|
|
|
|
"/etc/nix-bitcoin-secrets/bitcoin-rpcpassword-public" = {
|
|
|
|
hostPath = "${bitcoin-rpcpassword-public}";
|
|
|
|
isReadOnly = false;
|
|
|
|
};
|
|
|
|
"/etc/nix-bitcoin-secrets/bitcoin-HMAC-privileged" = {
|
|
|
|
hostPath = "${bitcoin-HMAC-privileged}";
|
|
|
|
isReadOnly = false;
|
|
|
|
};
|
|
|
|
"/etc/nix-bitcoin-secrets/bitcoin-HMAC-public" = {
|
|
|
|
hostPath = "${bitcoin-HMAC-public}";
|
|
|
|
isReadOnly = false;
|
|
|
|
};
|
2024-10-05 16:42:16 +01:00
|
|
|
"/var/lib/bitcoind" = {
|
|
|
|
hostPath = "/media/main-ssd/nix-bitcoin/bitcoind";
|
|
|
|
isReadOnly = false;
|
|
|
|
};
|
|
|
|
"/var/lib/electrs" = {
|
|
|
|
hostPath = "/media/main-ssd/nix-bitcoin/electrs";
|
|
|
|
isReadOnly = false;
|
|
|
|
};
|
|
|
|
"/var/lib/mysql" = {
|
|
|
|
hostPath = "/media/main-ssd/nix-bitcoin/mysql";
|
|
|
|
isReadOnly = false;
|
|
|
|
};
|
|
|
|
"/var/lib/tor" = {
|
|
|
|
hostPath = "/media/main-ssd/nix-bitcoin/tor";
|
2024-10-04 17:53:32 +01:00
|
|
|
isReadOnly = false;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = {
|
|
|
|
pkgs,
|
|
|
|
lib,
|
|
|
|
...
|
|
|
|
}: {
|
|
|
|
imports = [
|
|
|
|
inputs.nix-bitcoin.nixosModules.default
|
2024-12-28 16:08:23 +00:00
|
|
|
inputs.lnbits.nixosModules.default
|
2024-10-04 17:53:32 +01:00
|
|
|
];
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
vim
|
|
|
|
lsof
|
|
|
|
jq
|
|
|
|
];
|
|
|
|
networking = {
|
2024-10-07 14:19:27 +01:00
|
|
|
defaultGateway = "${gatewayIp}";
|
2024-12-28 16:08:23 +00:00
|
|
|
interfaces.eth0.ipv4.addresses = [
|
|
|
|
{
|
|
|
|
"address" = "${containerIp}";
|
|
|
|
"prefixLength" = 24;
|
|
|
|
}
|
|
|
|
];
|
2024-10-04 17:53:32 +01:00
|
|
|
firewall = {
|
|
|
|
enable = true;
|
|
|
|
allowedTCPPorts = [
|
|
|
|
80
|
|
|
|
443
|
|
|
|
22
|
|
|
|
config.containers.bitcoin-node.config.services.bitcoind.rpc.port
|
|
|
|
config.containers.bitcoin-node.config.services.mempool.frontend.port
|
2024-10-05 16:42:16 +01:00
|
|
|
config.containers.bitcoin-node.config.services.electrs.port
|
2024-12-28 16:08:23 +00:00
|
|
|
config.containers.bitcoin-node.config.services.rtl.port
|
|
|
|
config.containers.bitcoin-node.config.services.lnd.port
|
2024-10-04 17:53:32 +01:00
|
|
|
];
|
|
|
|
};
|
|
|
|
useHostResolvConf = lib.mkForce false;
|
|
|
|
};
|
|
|
|
|
|
|
|
services.resolved.enable = true;
|
|
|
|
|
|
|
|
# node services here
|
2024-10-06 17:25:27 +01:00
|
|
|
nix-bitcoin.generateSecrets = true;
|
2024-12-28 16:08:23 +00:00
|
|
|
nix-bitcoin.nodeinfo.enable = true;
|
2024-10-04 17:53:32 +01:00
|
|
|
services = {
|
2024-12-28 16:08:23 +00:00
|
|
|
backups.enable = true;
|
2024-10-04 17:53:32 +01:00
|
|
|
tor = {
|
|
|
|
enable = true;
|
|
|
|
client.enable = true;
|
|
|
|
};
|
|
|
|
bitcoind = {
|
|
|
|
tor.proxy = true;
|
|
|
|
tor.enforce = true;
|
|
|
|
enable = true;
|
2024-10-05 16:42:16 +01:00
|
|
|
dataDir = "/var/lib/bitcoind";
|
2024-10-04 17:53:32 +01:00
|
|
|
dbCache = 5000;
|
|
|
|
txindex = true;
|
|
|
|
rpc = {
|
|
|
|
address = "0.0.0.0";
|
2024-10-07 14:19:27 +01:00
|
|
|
allowip = allowip;
|
2024-10-04 17:53:32 +01:00
|
|
|
users = let
|
|
|
|
name = "bitcoin";
|
|
|
|
in {
|
|
|
|
privileged.name = name;
|
|
|
|
public.name = name;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
extraConfig = ''
|
|
|
|
onlynet=onion
|
|
|
|
bind=127.0.0.1
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
electrs = {
|
|
|
|
tor.enforce = true;
|
|
|
|
enable = true;
|
2024-10-05 16:42:16 +01:00
|
|
|
dataDir = "/var/lib/electrs";
|
|
|
|
address = "0.0.0.0";
|
2024-10-04 17:53:32 +01:00
|
|
|
};
|
|
|
|
mempool = {
|
|
|
|
enable = true;
|
|
|
|
electrumServer = "electrs";
|
|
|
|
frontend = {
|
2024-10-10 01:37:37 +01:00
|
|
|
port = mempoolPort;
|
2024-10-04 17:53:32 +01:00
|
|
|
address = "0.0.0.0";
|
|
|
|
};
|
|
|
|
};
|
2024-12-28 16:08:23 +00:00
|
|
|
lnd = {
|
|
|
|
enable = true;
|
|
|
|
lndconnect = {
|
|
|
|
enable = true;
|
|
|
|
onion = true;
|
|
|
|
};
|
|
|
|
extraConfig = ''
|
|
|
|
alias=bitlab21
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
rtl = {
|
|
|
|
enable = true;
|
|
|
|
nodes.lnd.enable = true;
|
|
|
|
address = "0.0.0.0";
|
|
|
|
};
|
|
|
|
lnbits = {
|
|
|
|
enable = true;
|
|
|
|
openFirewall = true;
|
|
|
|
host = "0.0.0.0";
|
|
|
|
port = 8231;
|
2024-12-29 10:25:09 +00:00
|
|
|
env = {
|
|
|
|
LNBITS_ADMIN_UI = "true";
|
|
|
|
LNBITS_BACKEND_WALLET_CLASS = "LndRestWallet";
|
|
|
|
LND_REST_ENDPOINT = "https://127.0.0.1:8080";
|
|
|
|
LND_REST_CERT = "/etc/nix-bitcoin-secrets/lnd-cert";
|
|
|
|
LND_REST_MACAROON = "/var/lib/lnbits/admin.macaroon";
|
|
|
|
};
|
2024-12-28 16:08:23 +00:00
|
|
|
};
|
2024-10-04 17:53:32 +01:00
|
|
|
};
|
2024-12-28 16:08:23 +00:00
|
|
|
|
|
|
|
# Add custom systemd overrides for above services
|
|
|
|
systemd.services.lnbits.after = ["lnd.service"];
|
|
|
|
|
2024-10-04 17:53:32 +01:00
|
|
|
nix-bitcoin.onionServices = {
|
|
|
|
bitcoind.enable = true;
|
|
|
|
electrs.enable = true;
|
|
|
|
mempool-frontend.enable = true;
|
2024-12-28 16:08:23 +00:00
|
|
|
lnd.public = true;
|
2024-10-04 17:53:32 +01:00
|
|
|
};
|
2024-10-06 17:25:27 +01:00
|
|
|
|
|
|
|
services.openssh = {
|
|
|
|
enable = true;
|
|
|
|
settings.PasswordAuthentication = false;
|
|
|
|
};
|
|
|
|
|
|
|
|
users.users.root = {
|
|
|
|
openssh.authorizedKeys.keys = lib.lists.forEach pubKeys (key: builtins.readFile key);
|
|
|
|
};
|
|
|
|
|
2024-10-04 17:53:32 +01:00
|
|
|
system.stateVersion = "24.05";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|