Skip to content

Commit

Permalink
refactor(utils)!: promote to a flake module
Browse files Browse the repository at this point in the history
Accessible through `config.lib`
  • Loading branch information
reo101 committed Jul 28, 2024
1 parent 2941536 commit c070f48
Show file tree
Hide file tree
Showing 7 changed files with 164 additions and 148 deletions.
1 change: 1 addition & 0 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,7 @@
];

imports = [
./modules/flake/lib.nix
./modules/flake/pkgs.nix
./modules/flake/modules.nix
./modules/flake/configurations.nix
Expand Down
2 changes: 1 addition & 1 deletion modules/flake/configurations.nix
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{ lib, config, self, inputs, withSystem, ... }:

let
inherit (import ../../nix/utils.nix { inherit lib config self; })
inherit (config.lib)
and
hasFiles
hasDirectories
Expand Down
2 changes: 1 addition & 1 deletion modules/flake/deploy.nix
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{ lib, config, self, inputs, ... }:

let
inherit (import ../../nix/utils.nix { inherit lib config self; })
inherit (config.lib)
accumulateHosts
configuration-type-to-deploy-type;
in
Expand Down
159 changes: 159 additions & 0 deletions modules/flake/lib.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,159 @@
{ lib, config, self, ... }:

{
options = let
inherit (lib) types;
in {
lib = lib.mkOption {
type = types.unspecified;
};
};

config.lib = rec {
# Boolean helpers
and = lib.all lib.id;
or = lib.any lib.id;
eq = x: y: x == y;

# Directory walking helpers
recurseDir = dir:
lib.mapAttrs
(file: type:
if type == "directory"
then recurseDir "${dir}/${file}"
else type)
(builtins.readDir dir);

allSatisfy = predicate: attrs: attrset:
lib.all
(attr:
and [
(builtins.hasAttr attr attrset)
(predicate (builtins.getAttr attr attrset))
])
attrs;

# NOTE: Implying last argument is the output of `recurseDir`
hasFiles = allSatisfy (eq "regular");

# NOTE: Implying last argument is the output of `recurseDir`
hasDirectories = allSatisfy lib.isAttrs;

camelToKebab =
lib.stringAsChars
(c: if c == lib.toUpper c then "-${lib.toLower c}" else c);

# NOTE: adapted from Tweag's Nix Hour 76 - <https://github.com/tweag/nix-hour/blob/c4fd0f2fc3059f057571bbfd74f3c5e4021f526c/code/76/default.nix#L4-L22>
mutFirstChar =
f: s:
let
firstChar = f (lib.substring 0 1 s);
rest = lib.substring 1 (-1) s;
in firstChar + rest;

kebabToCamel = lib.flip lib.pipe [
(lib.splitString "-")
(lib.concatMapStrings
(mutFirstChar lib.toUpper))
(mutFirstChar lib.toLower)
];
# s:
# mutFirstChar
# lib.toLower
# (lib.concatMapStrings
# (mutFirstChar lib.toUpper)
# (lib.splitString "-" s));

gen-configuration-type-to = mappings: mkError: configuration-type:
mappings.${configuration-type} or
(builtins.throw
(mkError configuration-type));

# TODO: abstract away `_Hosts` and `_Modules`

configuration-type-to-outputs-hosts =
gen-configuration-type-to
{
nixos = "nixosHosts";
nix-on-droid = "nixOnDroidHosts";
nix-darwin = "darwinHosts";
home-manager = "homeManagerHosts";
}
(configuration-type:
builtins.throw
"Invaild configuration-type \"${configuration-type}\" for flake outputs' hosts");

configuration-type-to-outputs-modules =
gen-configuration-type-to
{
nixos = "nixosModules";
nix-on-droid = "nixOnDroidModules";
nix-darwin = "darwinModules";
home-manager = "homeManagerModules";
flake = "flakeModules";
}
(configuration-type:
builtins.throw
"Invaild configuration-type \"${configuration-type}\" for flake outputs' modules");

configuration-type-to-outputs-configurations =
gen-configuration-type-to
{
nixos = "nixosConfigurations";
nix-on-droid = "nixOnDroidConfigurations";
nix-darwin = "darwinConfigurations";
home-manager = "homeConfigurations";
}
(configuration-type:
builtins.throw
"Invaild configuration-type \"${configuration-type}\" for flake outputs' configurations");

configuration-type-to-deploy-type =
gen-configuration-type-to
{
nixos = "nixos";
nix-darwin = "darwin";
}
(configuration-type:
builtins.throw
"Invaild configuration-type \"${configuration-type}\" for deploy-rs deployment");

accumulateHosts = configuration-types: host-system-configuration-type-configuration-fn:
lib.flip lib.concatMapAttrs
(lib.genAttrs
configuration-types
(configuration-type:
config.flake.autoConfigurations.${configuration-type}.resultHosts))
(configuration-type: hosts:
lib.pipe
hosts
[
# Filter out nondirectories
(lib.filterAttrs
(system: configurations:
builtins.isAttrs configurations))
# Convert non-template configs into `system-and-config` pairs
(lib.concatMapAttrs
(system: configurations:
(lib.concatMapAttrs
(host: configuration:
lib.optionalAttrs
(host != "__template__")
{
${host} = {
inherit system;
configuration =
let
configurations = configuration-type-to-outputs-configurations configuration-type;
in
self.${configurations}.${host};
};
})
configurations)))
# Convert each `system-and-config` pair into a *whatever*
(lib.concatMapAttrs
(host: { system, configuration }:
host-system-configuration-type-configuration-fn { inherit host system configuration-type configuration; }))
]);
};
}
2 changes: 1 addition & 1 deletion modules/flake/modules.nix
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{ lib, config, self, inputs, ... }:

let
inherit (import ../../nix/utils.nix { inherit lib config self; })
inherit (config.lib)
eq
and
hasFiles
Expand Down
2 changes: 1 addition & 1 deletion modules/flake/packages/default.nix
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{ lib, config, self, inputs, ... }:

let
inherit (import ../../../nix/utils.nix { inherit lib config self; })
inherit (config.lib)
eq
and
hasFiles;
Expand Down
144 changes: 0 additions & 144 deletions nix/utils.nix

This file was deleted.

0 comments on commit c070f48

Please sign in to comment.