aboutsummaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--modules/by-name/co/constants/module.nix2
-rw-r--r--modules/by-name/gr/grocy/module.nix51
2 files changed, 53 insertions, 0 deletions
diff --git a/modules/by-name/co/constants/module.nix b/modules/by-name/co/constants/module.nix
index 2115a37..1513b0c 100644
--- a/modules/by-name/co/constants/module.nix
+++ b/modules/by-name/co/constants/module.nix
@@ -52,6 +52,7 @@
stalwart-mail-certificates = 338; # GROUP
sharkey = 339;
redis-sharkey = 340;
+ grocy = 341;
# As per the NixOS file, the uids should not be greater or equal to 400;
};
@@ -85,6 +86,7 @@
systemd-oom
sharkey
redis-sharkey
+ grocy
systemd-coredump # matches systemd-coredump user
resolvconf # This group is not matched to an user?
stalwart-mail-certificates # This group is used to connect nginx and stalwart-mail
diff --git a/modules/by-name/gr/grocy/module.nix b/modules/by-name/gr/grocy/module.nix
new file mode 100644
index 0000000..28107f2
--- /dev/null
+++ b/modules/by-name/gr/grocy/module.nix
@@ -0,0 +1,51 @@
+{
+ config,
+ lib,
+ ...
+}: let
+ cfg = config.vhack.grocy;
+ data = "/var/lib/grocy";
+in {
+ options.vhack.grocy = {
+ enable = lib.mkEnableOption "grocy";
+
+ domain = lib.mkOption {
+ type = lib.types.str;
+ description = "FQDN for the grocy instance.";
+ };
+ };
+
+ config = lib.mkIf cfg.enable {
+ services.grocy = {
+ enable = true;
+
+ hostName = cfg.domain;
+ dataDir = data;
+
+ settings = {
+ currency = "EUR";
+ culture = "sv_SE";
+ calendar.firstDayOfWeek = 1;
+ };
+ };
+
+ vhack.persist.directories = [
+ {
+ directory = data;
+ user = "grocy";
+ group = "grocy";
+ mode = "0700";
+ }
+ ];
+
+ users = {
+ groups.grocy = {
+ gid = config.vhack.constants.ids.gids.grocy;
+ };
+ users.grocy = {
+ extraGroups = ["grocy"];
+ uid = config.vhack.constants.ids.uids.grocy;
+ };
+ };
+ };
+}