{ lib, inputs, self, ... }: let inherit (lib) mkOption; in { # Verify the existence of a binary inside of a derivation. # Returns the path to the binary or throws. checkPath = pkg: bin: let abs = lib.getExe' pkg bin; in if builtins.pathExists abs then abs else throw "${abs} does not exist."; mkSystem = { withSystem, hostname, extraModules ? [ ], system, }: withSystem system ( { inputs', self', ... }: lib.nixosSystem { inherit system; modules = [ "${self}/hosts/${hostname}" "${self}/options" "${self}/modules" { networking.hostName = hostname; } ] ++ extraModules; specialArgs = { inherit inputs inputs'; inherit self self'; pubkeys = import ../../options/keys.nix { inherit lib; }; username = "ny"; }; } ); mkPortOption = port: name: lib.mkOption { type = lib.types.port; default = port; description = "The port ${name} should listen on"; }; mkOption' = type: default: description: mkOption { inherit type default description; }; validatePath = s: if (builtins.pathExists s) then (builtins.baseNameOf s) else throw "${s} does not exist"; mkVHost = name: port: ssl: { inherit name; value = { enableACME = ssl; forceSSL = ssl; locations."/" = { proxyPass = "http://127.0.0.1:${toString port}"; extraConfig = '' proxy_ssl_server_name on; proxy_pass_header Authorization; ''; }; }; }; slugify = let inherit (lib.strings) sanitizeDerivationName; in str: (sanitizeDerivationName (lib.toLower str)); }