feat(y2q): add opengist

- Add environment and environmentFile options to runit module to support environment variables
- Add opengist runit service that uses these options
This commit is contained in:
toast 2025-12-07 15:19:44 +09:00
parent bd9cb2afff
commit 3b3476c110
5 changed files with 69 additions and 16 deletions

View file

@ -18,6 +18,16 @@
description = "Shell commands executed as the service's main process";
};
log.enable = lib.mkEnableOption "Enable logging";
environment = lib.mkOption {
type = lib.types.attrsOf lib.types.str;
default = {};
description = "Environment variables passed to the service's processes";
};
environmentFile = lib.mkOption {
type = lib.types.nullOr lib.types.path;
default = null;
description = "Environment file passed to the service";
};
};
}));
};
@ -28,10 +38,31 @@
config = {
home.file = lib.mkMerge (
lib.mapAttrsToList (serviceName: sCfg:
let
envExports = lib.concatStringsSep "\n" (
lib.mapAttrsToList (k: v: "export ${k}='${v}'") sCfg.environment
);
envFile = lib.mkIf (sCfg.environmentFile != null) {
"runit/services/${serviceName}/.env" = {
source = sCfg.environmentFile;
};
};
envFileSetup = if sCfg.environmentFile != null then ''
set -a
source .env
set +a
'' else "";
in
lib.mkMerge [
{
# run script
"runit/services/${serviceName}/run" = {
text = sCfg.script;
text = ''
#!/usr/bin/env bash
${envExports}
${envFileSetup}
${sCfg.script}
'';
executable = true;
};
@ -41,8 +72,11 @@
#!/bin/sh
exec svlogd -t ./main
'';
executable = true;
};
}
envFile
]
) config.runit.services
);
};

View file

@ -3,8 +3,7 @@
{
runit.services.glances = {
script = ''
#!/bin/bash
${pkgs.glances}/bin/glances -w
exec ${pkgs.glances}/bin/glances -w
'';
};
}

View file

@ -0,0 +1,20 @@
{ pkgs, rootPath, ... }:
{
runit.services.opengist = {
script = ''
exec ${pkgs.opengist}/bin/opengist start
'';
environment = {
OG_HTTP_HOST = "127.0.0.1";
OG_HTTP_PORT = "6157";
OG_SSH_HOST = "127.0.0.1";
OG_SSH_PORT = "6522";
};
environmentFile = rootPath + /secrets/gitcrypt/opengist.env;
log.enable = true;
};
}

Binary file not shown.

Binary file not shown.