summaryrefslogtreecommitdiffstats
path: root/nixos/modules/services/admin
diff options
context:
space:
mode:
authorLinus Heckemann <git@sphalerite.org>2021-07-21 18:03:57 +0200
committerLinus Heckemann <git@sphalerite.org>2021-07-29 11:42:42 +0200
commita175be0e7e06c2404d25777e9e8c8fa6ebee376d (patch)
tree6d8229cb45cf46182ecf10f387c0c67e939bc22e /nixos/modules/services/admin
parent39790153557ce5ff2355110ce40f17275ce631bf (diff)
nixos/meshcentral: init module
Diffstat (limited to 'nixos/modules/services/admin')
-rw-r--r--nixos/modules/services/admin/meshcentral.nix53
1 files changed, 53 insertions, 0 deletions
diff --git a/nixos/modules/services/admin/meshcentral.nix b/nixos/modules/services/admin/meshcentral.nix
new file mode 100644
index 000000000000..ae7b6edda7d5
--- /dev/null
+++ b/nixos/modules/services/admin/meshcentral.nix
@@ -0,0 +1,53 @@
+{ config, pkgs, lib, ... }:
+let
+ cfg = config.services.meshcentral;
+ configFormat = pkgs.formats.json {};
+ configFile = configFormat.generate "meshcentral-config.json" cfg.settings;
+in with lib; {
+ options.services.meshcentral = with types; {
+ enable = mkEnableOption "MeshCentral computer management server";
+ package = mkOption {
+ description = "MeshCentral package to use. Replacing this may be necessary to add dependencies for extra functionality.";
+ type = types.package;
+ default = pkgs.meshcentral;
+ defaultText = "pkgs.meshcentral";
+ };
+ settings = mkOption {
+ description = ''
+ Settings for MeshCentral. Refer to upstream documentation for details:
+
+ <itemizedlist>
+ <listitem><para><link xlink:href="https://github.com/Ylianst/MeshCentral/blob/master/meshcentral-config-schema.json">JSON Schema definition</link></para></listitem>
+ <listitem><para><link xlink:href="https://github.com/Ylianst/MeshCentral/blob/master/sample-config.json">simple sample configuration</link></para></listitem>
+ <listitem><para><link xlink:href="https://github.com/Ylianst/MeshCentral/blob/master/sample-config-advanced.json">complex sample configuration</link></para></listitem>
+ <listitem><para><link xlink:href="https://www.meshcommander.com/meshcentral2">Old homepage) with documentation link</link></para></listitem>
+ </itemizedlist>
+ '';
+ type = types.submodule {
+ freeformType = configFormat.type;
+ };
+ example = {
+ settings = {
+ WANonly = true;
+ Cert = "meshcentral.example.com";
+ TlsOffload = "10.0.0.2,fd42::2";
+ Port = 4430;
+ };
+ domains."".certUrl = "https://meshcentral.example.com/";
+ };
+ };
+ };
+ config = mkIf cfg.enable {
+ services.meshcentral.settings.settings.autoBackup.backupPath = lib.mkDefault "/var/lib/meshcentral/backups";
+ systemd.services.meshcentral = {
+ wantedBy = ["multi-user.target"];
+ serviceConfig = {
+ ExecStart = "${cfg.package}/bin/meshcentral --datapath /var/lib/meshcentral --configfile ${configFile}";
+ DynamicUser = true;
+ StateDirectory = "meshcentral";
+ CacheDirectory = "meshcentral";
+ };
+ };
+ };
+ meta.maintainers = [ maintainers.lheckemann ];
+}