stockholm/default.nix

88 lines
2.7 KiB
Nix
Raw Normal View History

{ configuration ? import (nixpkgs-path + "/nixos/lib/from-env.nix") "NIXOS_CONFIG" <nixos-config>
, system ? builtins.currentSystem
, current-host-name ?
let v = builtins.getEnv "HOSTNAME"; in
if v != "" then v else builtins.readFile /proc/sys/kernel/hostname
, current-user-name ?
let v = builtins.getEnv "LOGNAME"; in
if v != "" then v else abort "undefined variable: LOGNAME"
, nixpkgs-path ?
if (builtins.tryEval <nixpkgs/krebs>).success
then <upstream-nixpkgs>
else <nixpkgs>
, StrictHostKeyChecking ? "yes"
}@args:
2015-07-24 17:34:08 +02:00
let stockholm = {
2015-10-20 02:33:58 +02:00
inherit krebs;
inherit users;
inherit lib;
inherit config options pkgs;
system = config.system.build.toplevel;
2015-10-20 02:33:58 +02:00
};
krebs = import ./krebs (args // { inherit lib stockholm; });
2015-10-21 00:08:18 +02:00
2015-11-09 19:49:18 +01:00
lib = let
2016-02-04 04:35:39 +01:00
nlib = import (slib.npath "lib");
2015-11-09 19:49:18 +01:00
klib = import (slib.kpath "4lib") { lib = nlib; };
slib = rec {
npath = p: nixpkgs-path + "/${p}";
2016-02-04 04:35:39 +01:00
kpath = p: ./. + "/krebs/${p}";
upath = p: ./. + "/${current-user-name}/${p}";
2015-10-21 00:08:18 +02:00
};
2015-11-09 19:49:18 +01:00
ulib = let p = slib.upath "4lib"; in
nlib.optionalAttrs (klib.dir.has-default-nix p)
(import p { lib = nlib // klib; });
in nlib // klib // slib // ulib // builtins;
2015-10-17 05:44:42 +02:00
inherit (eval configuration) config options pkgs;
2015-10-21 22:29:35 +02:00
2015-10-25 14:15:21 +01:00
base-module = { config, ... }: {
imports = builtins.filter lib.dir.has-default-nix (lib.concatLists [
2015-11-09 19:49:18 +01:00
(map (f: f "2configs") [ lib.upath ])
(map (f: f "3modules") [ lib.kpath lib.upath ])
2015-11-06 22:05:36 +01:00
]);
2015-10-17 05:44:42 +02:00
2015-10-25 14:15:21 +01:00
krebs.current.enable = true;
krebs.current.host = config.krebs.hosts.${current-host-name};
krebs.current.user = config.krebs.users.${current-user-name};
2015-11-09 19:49:18 +01:00
nixpkgs.config.packageOverrides = pkgs: let
kpkgs = import (lib.kpath "5pkgs") { inherit lib pkgs; };
upkgs = import (lib.upath "5pkgs") { inherit lib; pkgs = pkgs // kpkgs; };
in kpkgs // upkgs;
2015-10-17 05:44:42 +02:00
};
2015-10-02 15:29:47 +02:00
2016-02-04 04:35:39 +01:00
eval = config: import (lib.npath "nixos/lib/eval-config.nix") {
inherit system;
2015-10-21 00:08:18 +02:00
specialArgs = {
inherit lib;
};
2015-09-27 00:22:50 +02:00
modules = [
base-module
2015-10-20 02:33:58 +02:00
config
2015-07-25 18:16:51 +02:00
];
};
2015-07-24 17:34:08 +02:00
2015-10-20 02:33:58 +02:00
# TODO move user namespaces' to users/, so no exception for krebs/ is needed
users =
lib.mapAttrs
(name: _: eval-all-systems (lib.nspath name "1systems"))
(lib.filterAttrs
(n: t: !lib.hasPrefix "." n && t == "directory" && n != "krebs")
(builtins.readDir ./.));
eval-all-systems = path:
lib.mapAttrs'
(n: _: (lib.nameValuePair (lib.removeSuffix ".nix" n)
(eval-system (path + "/${n}"))))
(builtins.readDir path);
2015-09-27 00:22:50 +02:00
2015-10-20 02:33:58 +02:00
eval-system = path: rec {
2015-09-27 00:22:50 +02:00
inherit (eval path) config options;
system = config.system.build.toplevel;
};
in stockholm