2018-12-06 11:39:54 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
2019-01-01 19:16:24 +00:00
|
|
|
cfg = config.services.nix-bitcoin-webindex;
|
2019-11-27 13:04:23 +00:00
|
|
|
inherit (config) nix-bitcoin-services;
|
2018-12-06 11:39:54 +00:00
|
|
|
indexFile = pkgs.writeText "index.html" ''
|
|
|
|
<html>
|
|
|
|
<body>
|
|
|
|
<p>
|
|
|
|
<h1>
|
|
|
|
nix-bitcoin
|
|
|
|
</h1>
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
<h3>
|
|
|
|
lightning node: CLIGHTNING_ID
|
|
|
|
</h3>
|
|
|
|
</p>
|
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
'';
|
|
|
|
createWebIndex = pkgs.writeText "make-index.sh" ''
|
|
|
|
set -e
|
|
|
|
cp ${indexFile} /var/www/index.html
|
2020-05-06 10:43:57 +00:00
|
|
|
chown -R nginx:nginx /var/www/
|
2018-12-06 11:39:54 +00:00
|
|
|
nodeinfo
|
|
|
|
. <(nodeinfo)
|
|
|
|
sed -i "s/CLIGHTNING_ID/$CLIGHTNING_ID/g" /var/www/index.html
|
|
|
|
'';
|
|
|
|
in {
|
2019-01-01 19:16:24 +00:00
|
|
|
options.services.nix-bitcoin-webindex = {
|
2018-12-06 11:39:54 +00:00
|
|
|
enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = ''
|
|
|
|
If enabled, the webindex service will be installed.
|
|
|
|
'';
|
|
|
|
};
|
2020-06-10 14:48:20 +00:00
|
|
|
host = mkOption {
|
|
|
|
type = types.str;
|
2020-08-21 20:36:02 +00:00
|
|
|
default = if config.nix-bitcoin.netns-isolation.enable then
|
|
|
|
config.nix-bitcoin.netns-isolation.netns.nginx.address
|
|
|
|
else
|
|
|
|
"localhost";
|
2020-06-10 14:48:20 +00:00
|
|
|
description = "HTTP server listen address.";
|
|
|
|
};
|
2019-04-27 23:53:26 +00:00
|
|
|
enforceTor = nix-bitcoin-services.enforceTor;
|
2018-12-06 11:39:54 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2020-06-15 10:34:11 +00:00
|
|
|
assertions = [
|
2021-01-01 17:37:30 +00:00
|
|
|
{ assertion = config.services.clightning.enable;
|
|
|
|
message = "nix-bitcoin-webindex requires clightning.";
|
2020-06-15 10:34:11 +00:00
|
|
|
}
|
|
|
|
];
|
|
|
|
|
2020-05-06 10:43:57 +00:00
|
|
|
systemd.tmpfiles.rules = [
|
|
|
|
"d /var/www 0755 nginx nginx - -"
|
|
|
|
];
|
|
|
|
|
2018-12-06 11:39:54 +00:00
|
|
|
services.nginx = {
|
|
|
|
enable = true;
|
|
|
|
virtualHosts."_" = {
|
|
|
|
root = "/var/www";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
services.tor.hiddenServices.nginx = {
|
|
|
|
map = [{
|
2020-06-10 14:48:20 +00:00
|
|
|
port = 80; toHost = cfg.host;
|
2018-12-06 11:39:54 +00:00
|
|
|
} {
|
2020-06-10 14:48:20 +00:00
|
|
|
port = 443; toHost = cfg.host;
|
2018-12-06 11:39:54 +00:00
|
|
|
}];
|
|
|
|
version = 3;
|
|
|
|
};
|
|
|
|
|
|
|
|
# create-web-index
|
|
|
|
systemd.services.create-web-index = {
|
|
|
|
description = "Get node info";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
2020-08-21 20:35:58 +00:00
|
|
|
path = with pkgs; [
|
2020-05-03 14:42:53 +00:00
|
|
|
config.programs.nodeinfo
|
2019-11-27 13:04:33 +00:00
|
|
|
jq
|
|
|
|
sudo
|
2020-08-21 20:35:58 +00:00
|
|
|
] ++ optional config.services.lnd.enable config.services.lnd.cli
|
|
|
|
++ optional config.services.clightning.enable config.services.clightning.cli;
|
2020-05-05 13:18:41 +00:00
|
|
|
serviceConfig = nix-bitcoin-services.defaultHardening // {
|
2018-12-06 11:39:54 +00:00
|
|
|
ExecStart="${pkgs.bash}/bin/bash ${createWebIndex}";
|
|
|
|
User = "root";
|
|
|
|
Type = "simple";
|
|
|
|
RemainAfterExit="yes";
|
|
|
|
Restart = "on-failure";
|
|
|
|
RestartSec = "10s";
|
2020-05-05 13:25:00 +00:00
|
|
|
PrivateNetwork = "true"; # This service needs no network access
|
2020-05-06 08:28:00 +00:00
|
|
|
PrivateUsers = "false";
|
2020-05-05 15:15:16 +00:00
|
|
|
ReadWritePaths = "/var/www";
|
2020-05-05 13:27:07 +00:00
|
|
|
CapabilityBoundingSet = "CAP_SETUID CAP_SETGID CAP_SETPCAP CAP_SYS_ADMIN CAP_CHOWN CAP_FSETID CAP_SETFCAP CAP_DAC_OVERRIDE CAP_DAC_READ_SEARCH CAP_FOWNER CAP_IPC_OWNER";
|
2020-05-05 13:18:41 +00:00
|
|
|
} // (if cfg.enforceTor
|
2019-04-27 23:53:26 +00:00
|
|
|
then nix-bitcoin-services.allowTor
|
|
|
|
else nix-bitcoin-services.allowAnyIP
|
|
|
|
);
|
2018-12-06 11:39:54 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|