-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathflake.nix
More file actions
executable file
·48 lines (40 loc) · 1.22 KB
/
flake.nix
File metadata and controls
executable file
·48 lines (40 loc) · 1.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
{
description = "sworne@ dotfiles";
inputs = {
nixpkgs.url = "nixpkgs/nixos-23.05";
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
secrets = {
url = "git+ssh://git@github.com/sworne/sec.git?ref=main";
flake = false;
};
};
outputs = { home-manager, secrets, ... }@attrs:
let
system = "x86_64-linux";
username = "sworne";
home = builtins.readFile "${secrets.outPath}/homedir";
in
{
roles = builtins.listToAttrs (map
(name: {
name = (builtins.replaceStrings [ ".nix" ] [ "" ] name);
value = import (./roles + "/${name}");
})
(builtins.attrNames (builtins.readDir ./roles)));
pkgs = builtins.listToAttrs (map
(name: {
name = (builtins.replaceStrings [ ".nix" ] [ "" ] name);
value = import (./pkgs + "/${name}");
})
(builtins.attrNames (builtins.readDir ./pkgs)));
homeConfigurations.non-nix = home-manager.lib.homeManagerConfiguration {
inherit system username;
configuration = import ./roles/sway.nix;
homeDirectory = home;
extraSpecialArgs = attrs;
};
};
}