{ inputs = { flake-utils.url = "github:numtide/flake-utils"; naersk.url = "github:nix-community/naersk"; }; outputs = { self, nixpkgs, flake-utils, naersk }: flake-utils.lib.eachDefaultSystem ( system: let pkgs = nixpkgs.legacyPackages."${system}"; naersk-lib = naersk.lib."${system}"; deps = with pkgs; [ libvirt ]; in rec { # `nix build` packages.solard = naersk-lib.buildPackage { pname = "solard"; root = ./.; nativeBuildInputs = deps; buildInputs = deps; }; defaultPackage = packages.solard; # `nix run` apps.solard = flake-utils.lib.mkApp { drv = packages.solard; }; defaultApp = apps.solard; nixosModules.solard = { config, lib, ... }: { options = with lib; { cara.services.solard.enable = mkEnableOption "enable solard"; cara.services.solard.environmentFileLocation = mkOption { type = types.str; default = "/var/lib/solard/.env"; description = "The location of the environment file"; }; cara.services.solard.port = mkOption { type = types.port; default = 3000; description = "port to bind to"; }; }; config = lib.mkIf config.cara.services.solard.enable { users.groups.solard = { members = [ "solard" ]; }; users.users.solard = { createHome = true; isSystemUser = true; home = "/var/lib/solard"; group = "solard"; extraGroups = [ "libvirtd" ]; }; systemd.services.solard = { wantedBy = [ "multi-user.target" ]; serviceConfig = { User = "solard"; Group = "solard"; Restart = "always"; WorkingDirectory = "${defaultPackage}"; ExecStart = "${defaultPackage}/bin/solard"; EnvironmentFIle = "${config.cara.services.solard.environmentFileLocation}"; }; }; networking.firewall.allowedTCPPorts = [ config.cara.services.solard.port ]; }; }; # `nix develop` devShell = pkgs.mkShell { nativeBuildInputs = with pkgs; [ rustc cargo ] ++ deps; }; } ); }