liminix/default.nix

104 lines
2.3 KiB
Nix
Raw Normal View History

{
2024-03-22 22:55:44 +01:00
deviceName ? null
, device ? (import ./devices/${deviceName} )
, liminix-config ? <liminix-config>
2023-02-05 23:38:21 +01:00
, nixpkgs ? <nixpkgs>
2023-02-20 18:46:07 +01:00
, borderVmConf ? ./bordervm.conf.nix
}:
let
overlay = import ./overlay.nix;
2023-02-05 23:38:21 +01:00
pkgs = import nixpkgs (device.system // {
overlays = [ overlay ];
2023-02-20 18:46:07 +01:00
config = {
allowUnsupportedSystem = true; # mipsel
permittedInsecurePackages = [
"python-2.7.18.8" # kernel backports needs python <3
2023-02-20 18:46:07 +01:00
];
};
});
2023-02-11 00:10:44 +01:00
evalModules = (import ./lib/eval-config.nix {
inherit nixpkgs pkgs;
inherit (pkgs) lib;
});
eval = evalModules {
modules = [
2024-10-05 11:50:12 +02:00
({ lib, pkgs, ... }: {
_module.args = {
utils = import "${nixpkgs}/nixos/lib/utils.nix" {
inherit lib pkgs;
config.systemd.globalEnvironment = {};
};
};
2024-09-18 09:10:07 +02:00
nixpkgs = {
2024-09-18 17:04:51 +02:00
source = nixpkgs;
2024-09-18 09:10:07 +02:00
overlays = [ overlay ];
config.permittedInsecurePackages = [
"python-2.7.18.8"
];
};
2024-10-05 11:50:12 +02:00
})
device.module
liminix-config
];
};
config = eval.config;
2022-10-05 22:52:30 +02:00
borderVm = ((import <nixpkgs/nixos/lib/eval-config.nix>) {
system = builtins.currentSystem;
modules = [
{
nixpkgs.overlays = [
(final: prev: {
go-l2tp = final.callPackage ./pkgs/go-l2tp {};
tufted = final.callPackage ./pkgs/tufted {};
})
];
}
(import ./bordervm-configuration.nix)
2023-02-20 18:46:07 +01:00
borderVmConf
];
2023-02-14 23:08:52 +01:00
}).config.system;
in {
2024-09-30 16:39:58 +02:00
inherit evalModules config;
outputs = config.system.outputs // {
default = config.system.outputs.${config.hardware.defaultOutput};
optionsJson =
let o = import ./doc/extract-options.nix {
inherit pkgs eval;
lib = pkgs.lib;
};
in pkgs.writeText "options.json" (builtins.toJSON o);
2023-02-11 00:10:44 +01:00
};
2022-09-25 14:18:26 +02:00
# this is just here as a convenience, so that we can get a
# cross-compiling nix-shell for any package we're customizing
2023-02-07 00:19:35 +01:00
inherit pkgs;
deployEnv = pkgs.mkShell {
packages = with pkgs.pkgsBuildBuild; [
tufted
min-copy-closure
];
};
2023-02-08 19:10:11 +01:00
buildEnv = pkgs.mkShell {
packages = with pkgs.pkgsBuildBuild; [
tufted
routeros.routeros
routeros.ros-exec-script
2023-09-20 19:33:08 +02:00
run-liminix-vm
2023-02-14 23:08:52 +01:00
borderVm.build.vm
go-l2tp
2023-05-12 00:53:25 +02:00
min-copy-closure
fennelrepl
2024-01-23 12:56:34 +01:00
lzma
2024-04-06 13:30:41 +02:00
lua
2023-02-08 19:10:11 +01:00
];
};
}