modules/soft-serve: refactor for soft-serve 0.5
This commit is contained in:
parent
bee6bd5d2d
commit
d07c67aaea
1 changed files with 60 additions and 11 deletions
|
@ -3,18 +3,54 @@ with lib;
|
||||||
with lib.hlissner;
|
with lib.hlissner;
|
||||||
let
|
let
|
||||||
cfg = config.services.soft-serve;
|
cfg = config.services.soft-serve;
|
||||||
|
mkIfNotNull = v: mkIf (v != null) v;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.services.soft-serve = with types; {
|
options.services.soft-serve = with types; {
|
||||||
enable = mkBoolOpt false;
|
enable = mkBoolOpt false;
|
||||||
|
|
||||||
|
host = mkOpt str "";
|
||||||
path = mkOpt path "/srv/soft-serve";
|
path = mkOpt path "/srv/soft-serve";
|
||||||
|
initial_admin_keys = mkOpt (nullOr str) null;
|
||||||
|
|
||||||
port = mkOpt port 23231;
|
name = mkOpt (nullOr str) null;
|
||||||
host = mkOpt str "0.0.0.0";
|
log_format = mkOpt (nullOr str) null;
|
||||||
key_path = mkOpt path "${cfg.path}/soft_serve_server_ed25519";
|
|
||||||
repo_path = mkOpt path "${cfg.path}/repos";
|
# TODO: Allow adding git hooks via Nix
|
||||||
initial_admin_key = mkOpt (nullOr str) null;
|
|
||||||
|
ssh = {
|
||||||
|
host = mkOpt str cfg.host;
|
||||||
|
port = mkOpt port 23231;
|
||||||
|
|
||||||
|
public_url = mkOpt (nullOr str) null;
|
||||||
|
key_path = mkOpt (nullOr str) null;
|
||||||
|
client_key_path = mkOpt (nullOr str) null;
|
||||||
|
max_timeout = mkOpt (nullOr int) null;
|
||||||
|
idle_timeout = mkOpt (nullOr int) null;
|
||||||
|
};
|
||||||
|
|
||||||
|
git = {
|
||||||
|
host = mkOpt str cfg.host;
|
||||||
|
port = mkOpt port 9418;
|
||||||
|
|
||||||
|
max_timeout = mkOpt (nullOr int) null;
|
||||||
|
idle_timeout = mkOpt (nullOr int) null;
|
||||||
|
max_connections = mkOpt (nullOr int) null;
|
||||||
|
};
|
||||||
|
|
||||||
|
http = {
|
||||||
|
host = mkOpt str cfg.host;
|
||||||
|
port = mkOpt port 23232;
|
||||||
|
|
||||||
|
public_url = mkOpt (nullOr str) null;
|
||||||
|
tls_key_path = mkOpt (nullOr str) null;
|
||||||
|
tls_cert_path = mkOpt (nullOr str) null;
|
||||||
|
};
|
||||||
|
|
||||||
|
stats = {
|
||||||
|
host = mkOpt str cfg.host;
|
||||||
|
port = mkOpt port 23233;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
|
@ -23,16 +59,29 @@ in
|
||||||
after = [ "network.target" ];
|
after = [ "network.target" ];
|
||||||
description = "SSH Git server and TUI";
|
description = "SSH Git server and TUI";
|
||||||
environment = {
|
environment = {
|
||||||
SOFT_SERVE_PORT = toString cfg.port;
|
SOFT_SERVE_DATA_PATH = cfg.path;
|
||||||
SOFT_SERVE_HOST = cfg.host;
|
SOFT_SERVE_INITIAL_ADMIN_KEYS = mkIfNotNull cfg.initial_admin_keys;
|
||||||
SOFT_SERVE_KEY_PATH = cfg.key_path;
|
|
||||||
SOFT_SERVE_REPO_PATH = cfg.repo_path;
|
SOFT_SERVE_SSH_LISTEN_ADDR = "${cfg.ssh.host}:${toString cfg.ssh.port}";
|
||||||
SOFT_SERVE_INITIAL_ADMIN_KEY = cfg.initial_admin_key;
|
SOFT_SERVE_GIT_LISTEN_ADDR = "${cfg.git.host}:${toString cfg.git.port}";
|
||||||
|
SOFT_SERVE_HTTP_LISTEN_ADDR = "${cfg.http.host}:${toString cfg.http.port}";
|
||||||
|
SOFT_SERVE_STATS_LISTEN_ADDR = "${cfg.stats.host}:${toString cfg.stats.port}";
|
||||||
|
|
||||||
|
SOFT_SERVE_NAME = mkIfNotNull cfg.name;
|
||||||
|
|
||||||
|
# TODO: Add the rest of the config override environment variables
|
||||||
|
# TODO: Document how configuration from Nix works, potentially adding a comment to the top of any existing `config.yaml` in `path`
|
||||||
};
|
};
|
||||||
script = "${pkgs.soft-serve}/bin/soft serve";
|
script = "${pkgs.soft-serve}/bin/soft serve";
|
||||||
serviceConfig.Type = "exec";
|
serviceConfig.Type = "exec";
|
||||||
};
|
};
|
||||||
|
|
||||||
networking.firewall.allowedTCPPorts = [ cfg.port ];
|
networking.firewall.allowedTCPPorts = [
|
||||||
|
cfg.ssh.port
|
||||||
|
cfg.git.port
|
||||||
|
cfg.http.port
|
||||||
|
cfg.stats.port
|
||||||
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue