nixos-config/flake.nix
Sean Buckley 0e244796eb flake.lock: Update
Flake lock file updates:

• Updated input 'nixpkgs':
    'github:NixOS/nixpkgs/a9eedea7232f5d00f0aca7267efb69a54da1b8a1' (2023-01-03)
  → 'github:NixOS/nixpkgs/befc83905c965adfd33e5cae49acb0351f6e0404' (2023-01-13)
2023-01-14 21:31:20 -05:00

72 lines
1.8 KiB
Nix

{
inputs.nixpkgs.url = "nixpkgs/nixos-unstable";
inputs.impermanence.url = "github:nix-community/impermanence";
outputs = { self, nixpkgs, impermanence, ... }:
let
inherit (nixpkgs) lib;
mypkgs = pkgs:
let
pkg = path:
let
p = pkgs.callPackage path { };
in
if p.meta.available then p else pkgs.emptyDirectory;
in
(lib.mapAttrs'
(name: type: {
name = lib.removeSuffix ".nix" name;
value = pkg (./pkgs + "/${name}");
})
(builtins.readDir ./pkgs));
forAllSystems = lib.genAttrs [ "x86_64-linux" ];
pins = {
nix.registry.nixpkgs.to = {
inherit (nixpkgs) rev;
owner = "NixOS";
repo = "nixpkgs";
type = "github";
};
nix.registry.bck.to = {
owner = "buckley310";
repo = "nixos-config";
type = "github";
};
};
mods =
{
inherit pins;
inherit (impermanence.nixosModules) impermanence;
pkgs.nixpkgs.overlays = [ (_: mypkgs) ];
} //
lib.mapAttrs'
(name: type: {
name = lib.removeSuffix ".nix" name;
value = import (./modules + "/${name}");
})
(builtins.readDir ./modules);
in
{
lib = {
inherit forAllSystems;
deploy = import lib/deploy.nix;
};
nixosModules = mods // { default.imports = builtins.attrValues mods; };
nixosConfigurations = builtins.mapAttrs
(_: lib.nixosSystem)
(import ./hosts self.nixosModules.default);
apps = forAllSystems (system:
import lib/apps.nix nixpkgs.legacyPackages.${system});
packages = forAllSystems (system:
mypkgs nixpkgs.legacyPackages.${system});
};
}