{ config, lib, pkgs, ... }: with lib; let cfg = config.services.garage; toml = pkgs.formats.toml {}; configFile = toml.generate "garage.toml" cfg.settings; in { meta = { doc = ./garage-doc.xml; maintainers = with pkgs.lib.maintainers; [ raitobezarius ]; }; options.services.garage = { enable = mkEnableOption (lib.mdDoc "Garage Object Storage (S3 compatible)"); extraEnvironment = mkOption { type = types.attrsOf types.str; description = lib.mdDoc "Extra environment variables to pass to the Garage server."; default = {}; example = { RUST_BACKTRACE="yes"; }; }; logLevel = mkOption { type = types.enum (["info" "debug" "trace"]); default = "info"; example = "debug"; description = lib.mdDoc "Garage log level, see for examples."; }; settings = mkOption { type = types.submodule { freeformType = toml.type; options = { metadata_dir = mkOption { default = "/var/lib/garage/meta"; type = types.path; description = lib.mdDoc "The metadata directory, put this on a fast disk (e.g. SSD) if possible."; }; data_dir = mkOption { default = "/var/lib/garage/data"; type = types.path; description = lib.mdDoc "The main data storage, put this on your large storage (e.g. high capacity HDD)"; }; replication_mode = mkOption { default = "none"; type = types.enum ([ "none" "1" "2" "3" 1 2 3 ]); apply = v: toString v; description = lib.mdDoc "Garage replication mode, defaults to none, see: for reference."; }; }; }; description = lib.mdDoc "Garage configuration, see for reference."; }; package = mkOption { # TODO: when 23.05 is released and if Garage 0.9 is the default, put a stateVersion check. default = if versionAtLeast stateVersion "23.05" then pkgs.garage_0_8_0 else pkgs.garage_0_7; defaultText = literalExpression "pkgs.garage_0_7"; type = types.package; description = lib.mdDoc "Garage package to use, if you are upgrading from a major version, please read NixOS and Garage release notes for upgrade instructions."; }; }; config = mkIf cfg.enable { environment.etc."garage.toml" = { source = configFile; }; environment.systemPackages = [ cfg.package ]; # For administration systemd.services.garage = { description = "Garage Object Storage (S3 compatible)"; after = [ "network.target" "network-online.target" ]; wants = [ "network.target" "network-online.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { ExecStart = "${cfg.package}/bin/garage server"; StateDirectory = mkIf (hasPrefix "/var/lib/garage" cfg.settings.data_dir && hasPrefix "/var/lib/garage" cfg.settings.metadata_dir) "garage"; DynamicUser = lib.mkDefault true; ProtectHome = true; NoNewPrivileges = true; }; environment = { RUST_LOG = lib.mkDefault "garage=${cfg.logLevel}"; } // cfg.extraEnvironment; }; }; }