krebs 3 tinc_graphs: mv from makefu 3 tinc_graphs
This commit is contained in:
parent
cac20cb3c4
commit
bd6199c2fa
|
@ -40,7 +40,7 @@ in {
|
|||
krebs.retiolum-bootstrap.enable = true;
|
||||
|
||||
nixpkgs.config.packageOverrides = pkgs: { tinc = pkgs.tinc_pre; };
|
||||
makefu.tinc_graphs = {
|
||||
krebs.tinc_graphs = {
|
||||
enable = true;
|
||||
nginx = {
|
||||
enable = true;
|
||||
|
|
|
@ -2,7 +2,6 @@ _:
|
|||
|
||||
{
|
||||
imports = [
|
||||
./tinc_graphs.nix
|
||||
];
|
||||
}
|
||||
|
||||
|
|
|
@ -1,145 +0,0 @@
|
|||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
let
|
||||
cfg = config.makefu.tinc_graphs;
|
||||
internal_dir = "${cfg.workingDir}/internal";
|
||||
external_dir = "${cfg.workingDir}/external";
|
||||
|
||||
out = {
|
||||
options.makefu.tinc_graphs = api;
|
||||
config = mkIf cfg.enable imp ;
|
||||
};
|
||||
|
||||
api = {
|
||||
enable = mkEnableOption "tinc graphs";
|
||||
|
||||
geodbPath = mkOption {
|
||||
type = types.str;
|
||||
description = "Path to geocitydb, defaults to geolite-legacy";
|
||||
default = "${pkgs.geolite-legacy}/share/GeoIP/GeoIPCity.dat";
|
||||
};
|
||||
|
||||
nginx = {
|
||||
enable = mkEnableOption "enable tinc_graphs to be served with nginx";
|
||||
|
||||
anonymous = {
|
||||
server-names = mkOption {
|
||||
type = with types; listOf str;
|
||||
description = "hostnames which serve anonymous graphs";
|
||||
default = [ "graphs.${config.krebs.build.host.name}" ];
|
||||
};
|
||||
|
||||
listen = mkOption {
|
||||
# use the type of the nginx listen option
|
||||
type = with types; listOf str;
|
||||
description = "listen address for anonymous graphs";
|
||||
default = [ "80" ];
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
complete = {
|
||||
server-names = mkOption {
|
||||
type = with types; listOf str;
|
||||
description = "hostname which serves complete graphs";
|
||||
default = [ "graphs.${config.krebs.build.host.name}" ];
|
||||
};
|
||||
|
||||
listen = mkOption {
|
||||
type = with types; listOf str;
|
||||
description = "listen address for complete graphs";
|
||||
default = [ "127.0.0.1:80" ];
|
||||
};
|
||||
|
||||
};
|
||||
};
|
||||
|
||||
workingDir = mkOption {
|
||||
type = types.str;
|
||||
description = ''
|
||||
Path to working dir, will create interal and external/.
|
||||
Defaults to the new users home dir which defaults to
|
||||
/var/cache/tinc_graphs'';
|
||||
default = config.users.extraUsers.tinc_graphs.home;
|
||||
};
|
||||
|
||||
timerConfig = mkOption {
|
||||
type = with types; attrsOf str;
|
||||
default = {
|
||||
OnCalendar = "*:0/15";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
imp = {
|
||||
environment.systemPackages = [ pkgs.tinc_graphs];
|
||||
systemd.timers.tinc_graphs = {
|
||||
description = "Build Tinc Graphs via via timer";
|
||||
wantedBy = [ "timers.target"];
|
||||
timerConfig = cfg.timerConfig;
|
||||
};
|
||||
systemd.services.tinc_graphs = {
|
||||
description = "Build Tinc Graphs";
|
||||
environment = {
|
||||
EXTERNAL_FOLDER = external_dir;
|
||||
INTERNAL_FOLDER = internal_dir;
|
||||
GEODB = cfg.geodbPath;
|
||||
TINC_HOSTPATH=config.krebs.retiolum.hosts;
|
||||
};
|
||||
|
||||
restartIfChanged = true;
|
||||
|
||||
serviceConfig = {
|
||||
Type = "simple";
|
||||
|
||||
ExecStartPre = pkgs.writeScript "tinc_graphs-init" ''
|
||||
#!/bin/sh
|
||||
if ! test -e "${cfg.workingDir}/internal/index.html"; then
|
||||
cp -fr "$(${pkgs.tinc_graphs}/bin/tincstats-static-dir)/internal/" "${internal_dir}"
|
||||
fi
|
||||
'';
|
||||
|
||||
ExecStart = "${pkgs.tinc_graphs}/bin/all-the-graphs";
|
||||
|
||||
ExecStartPost = pkgs.writeScript "tinc_graphs-post" ''
|
||||
#!/bin/sh
|
||||
# TODO: this may break if workingDir is set to something stupid
|
||||
# this is needed because homedir is created with 700
|
||||
chmod 755 "${cfg.workingDir}"
|
||||
'';
|
||||
PrivateTmp = "yes";
|
||||
|
||||
User = "root"; # tinc cannot be queried as user,
|
||||
# seems to be a tinc-pre issue
|
||||
};
|
||||
};
|
||||
|
||||
users.extraUsers.tinc_graphs = {
|
||||
uid = 3925439960; #genid tinc_graphs
|
||||
home = "/var/spool/tinc_graphs";
|
||||
createHome = true;
|
||||
};
|
||||
|
||||
krebs.nginx.servers = mkIf cfg.nginx.enable {
|
||||
tinc_graphs_complete = mkMerge [ cfg.nginx.complete {
|
||||
locations = [
|
||||
(nameValuePair "/" ''
|
||||
autoindex on;
|
||||
root ${internal_dir};
|
||||
'')
|
||||
];
|
||||
}] ;
|
||||
tinc_graphs_anonymous = mkMerge [ cfg.nginx.anonymous {
|
||||
locations = [
|
||||
(nameValuePair "/" ''
|
||||
autoindex on;
|
||||
root ${external_dir};
|
||||
'')
|
||||
];
|
||||
}];
|
||||
};
|
||||
};
|
||||
|
||||
in
|
||||
out
|
Loading…
Reference in a new issue