nixos/flake.nix

153 lines
7.4 KiB
Nix
Raw Normal View History

2023-07-08 16:56:36 +08:00
{
2023-09-01 21:05:26 +08:00
description = "CNH's NixOS Flake";
2023-07-08 16:26:12 +08:00
2023-09-01 21:05:26 +08:00
inputs =
{
2023-11-22 11:39:04 +08:00
nixpkgs.url = "github:CHN-beta/nixpkgs/nixos-23.11";
2024-03-02 10:49:51 +08:00
nixpkgs-unstable.url = "github:CHN-beta/nixpkgs/nixos-unstable";
2023-11-22 20:48:12 +08:00
nixpkgs-2305.url = "github:CHN-beta/nixpkgs/nixos-23.05";
2023-12-02 10:52:42 +08:00
home-manager = { url = "github:nix-community/home-manager/release-23.11"; inputs.nixpkgs.follows = "nixpkgs"; };
2023-09-01 21:05:26 +08:00
sops-nix =
{
url = "github:Mic92/sops-nix";
2023-09-07 11:43:05 +08:00
inputs = { nixpkgs.follows = "nixpkgs"; nixpkgs-stable.follows = "nixpkgs"; };
2023-09-01 21:05:26 +08:00
};
aagl = { url = "github:ezKEa/aagl-gtk-on-nix"; inputs.nixpkgs.follows = "nixpkgs"; };
nix-index-database = { url = "github:Mic92/nix-index-database"; inputs.nixpkgs.follows = "nixpkgs-unstable"; };
2023-09-01 21:05:26 +08:00
nur.url = "github:nix-community/NUR";
nixos-cn = { url = "github:nixos-cn/flakes"; inputs.nixpkgs.follows = "nixpkgs"; };
nur-xddxdd = { url = "github:xddxdd/nur-packages"; inputs.nixpkgs.follows = "nixpkgs"; };
2023-11-22 11:39:04 +08:00
nix-vscode-extensions = { url = "github:nix-community/nix-vscode-extensions"; inputs.nixpkgs.follows = "nixpkgs"; };
2023-09-01 21:05:26 +08:00
impermanence.url = "github:nix-community/impermanence";
2024-01-23 13:02:19 +08:00
qchem = { url = "github:Nix-QChem/NixOS-QChem/release-23.11"; inputs.nixpkgs.follows = "nixpkgs"; };
2023-09-08 05:49:52 +08:00
nixd = { url = "github:nix-community/nixd"; inputs.nixpkgs.follows = "nixpkgs"; };
2023-09-01 21:05:26 +08:00
napalm = { url = "github:nix-community/napalm"; inputs.nixpkgs.follows = "nixpkgs"; };
nixpak = { url = "github:nixpak/nixpak"; inputs.nixpkgs.follows = "nixpkgs"; };
deploy-rs = { url = "github:serokell/deploy-rs"; inputs.nixpkgs.follows = "nixpkgs"; };
2023-11-22 16:40:38 +08:00
pnpm2nix-nzbr = { url = "github:CHN-beta/pnpm2nix-nzbr"; inputs.nixpkgs.follows = "nixpkgs"; };
2023-11-19 16:38:21 +08:00
plasma-manager =
{
url = "github:pjones/plasma-manager";
inputs = { nixpkgs.follows = "nixpkgs"; home-manager.follows = "home-manager"; };
};
2023-11-30 14:09:23 +08:00
nix-doom-emacs = { url = "github:nix-community/nix-doom-emacs"; inputs.nixpkgs.follows = "nixpkgs"; };
2024-01-10 20:02:06 +08:00
nur-linyinfeng = { url = "github:linyinfeng/nur-packages"; inputs.nixpkgs.follows = "nixpkgs"; };
2024-02-15 19:22:43 +08:00
nixos-hardware.url = "github:CHN-beta/nixos-hardware";
2024-02-01 00:30:11 +08:00
envfs = { url = "github:Mic92/envfs"; inputs.nixpkgs.follows = "nixpkgs"; };
2024-02-16 16:38:31 +08:00
nix-fast-build = { url = "github:/Mic92/nix-fast-build"; inputs.nixpkgs.follows = "nixpkgs"; };
2024-01-21 23:45:43 +08:00
2024-01-18 14:45:50 +08:00
misskey = { url = "git+https://github.com/CHN-beta/misskey?submodules=1"; flake = false; };
2024-01-21 23:45:43 +08:00
rsshub = { url = "github:DIYgod/RSSHub"; flake = false; };
zpp-bits = { url = "github:eyalz800/zpp_bits"; flake = false; };
2024-01-23 13:02:19 +08:00
citation-style-language = { url = "git+https://github.com/zepinglee/citeproc-lua?submodules=1"; flake = false; };
concurrencpp = { url = "github:David-Haim/concurrencpp"; flake = false; };
cppcoro = { url = "github:Garcia6l20/cppcoro"; flake = false; };
date = { url = "github:HowardHinnant/date"; flake = false; };
eigen = { url = "gitlab:libeigen/eigen"; flake = false; };
matplotplusplus = { url = "github:alandefreitas/matplotplusplus"; flake = false; };
nameof = { url = "github:Neargye/nameof"; flake = false; };
nodesoup = { url = "github:olvb/nodesoup"; flake = false; };
tgbot-cpp = { url = "github:reo7sp/tgbot-cpp"; flake = false; };
v-sim = { url = "gitlab:l_sim/v_sim"; flake = false; };
2024-02-05 17:40:45 +08:00
win11os-kde = { url = "github:yeyushengfan258/Win11OS-kde"; flake = false; };
2024-02-09 14:59:33 +08:00
fluent-kde = { url = "github:vinceliuice/Fluent-kde"; flake = false; };
2024-02-09 22:05:24 +08:00
rycee = { url = "gitlab:rycee/nur-expressions"; flake = false; };
blurred-wallpaper = { url = "github:bouteillerAlan/blurredwallpaper"; flake = false; };
slate = { url = "github:TheBigWazz/Slate"; flake = false; };
2024-02-15 19:22:43 +08:00
linux-surface = { url = "github:linux-surface/linux-surface"; flake = false; };
2024-02-16 15:32:26 +08:00
lepton = { url = "github:black7375/Firefox-UI-Fix"; flake = false; };
2024-02-19 17:25:27 +08:00
lmod = { url = "github:TACC/Lmod"; flake = false; };
2024-02-27 18:51:12 +08:00
mumax = { url = "github:CHN-beta/mumax"; flake = false; };
2023-09-01 21:05:26 +08:00
};
2023-07-08 16:26:12 +08:00
2023-09-01 21:05:26 +08:00
outputs = inputs:
let
localLib = import ./local/lib inputs.nixpkgs.lib;
2024-02-23 12:26:35 +08:00
devices = builtins.attrNames (builtins.readDir ./devices);
2023-09-01 21:05:26 +08:00
in
{
packages.x86_64-linux =
{
default = inputs.nixpkgs.legacyPackages.x86_64-linux.writeText "systems"
(builtins.concatStringsSep "\n" (builtins.map
(system: builtins.toString inputs.self.outputs.nixosConfigurations.${system}.config.system.build.toplevel)
2024-02-25 15:04:44 +08:00
devices));
2023-09-01 21:05:26 +08:00
}
// (
builtins.listToAttrs (builtins.map
(system:
{
name = system;
value = inputs.self.outputs.nixosConfigurations.${system}.config.system.build.toplevel;
})
2024-02-23 12:26:35 +08:00
devices)
2023-09-01 21:05:26 +08:00
);
2023-12-11 17:05:29 +08:00
# ssh-keygen -t rsa -C root@pe -f /mnt/nix/persistent/etc/ssh/ssh_host_rsa_key
# ssh-keygen -t ed25519 -C root@pe -f /mnt/nix/persistent/etc/ssh/ssh_host_ed25519_key
# systemd-machine-id-setup --root=/mnt/nix/persistent
2024-01-16 22:41:03 +08:00
nixosConfigurations = builtins.listToAttrs (builtins.map
(system:
{
name = system;
value = inputs.nixpkgs.lib.nixosSystem
2023-09-01 21:05:26 +08:00
{
2024-01-16 22:41:03 +08:00
system = "x86_64-linux";
specialArgs = { topInputs = inputs; inherit localLib; };
modules = localLib.mkModules
[
2024-01-18 14:45:50 +08:00
(moduleInputs:
{
config.nixpkgs.overlays = [(final: prev: { localPackages =
import ./local/pkgs { inherit (moduleInputs) lib; pkgs = final; topInputs = inputs; };})];
})
2024-01-16 22:41:03 +08:00
./modules
./devices/${system}
];
2023-12-11 19:19:36 +08:00
};
2024-01-16 22:41:03 +08:00
})
2024-02-23 12:26:35 +08:00
devices);
2023-09-01 21:05:26 +08:00
# sudo HTTPS_PROXY=socks5://127.0.0.1:10884 nixos-install --flake .#bootstrap --option substituters http://127.0.0.1:5000 --option require-sigs false --option system-features gccarch-silvermont
# nix-serve -p 5000
# nix copy --substitute-on-destination --to ssh://server /run/current-system
# nix copy --to ssh://nixos@192.168.122.56 ./result
# sudo nixos-install --flake .#bootstrap
# --option substituters http://192.168.122.1:5000 --option require-sigs false
# sudo chattr -i var/empty
# nix-shell -p ssh-to-age --run 'cat /etc/ssh/ssh_host_ed25519_key.pub | ssh-to-age'
# sudo nixos-rebuild switch --flake .#vps6 --log-format internal-json -v |& nom --json
# boot.shell_on_fail systemd.setenv=SYSTEMD_SULOGIN_FORCE=1
# sudo usbipd
# ssh -R 3240:127.0.0.1:3240 root@192.168.122.57
# modprobe vhci-hcd
# sudo usbip bind -b 3-6
# usbip attach -r 127.0.0.1 -b 3-6
# systemd-cryptenroll --fido2-device=auto /dev/vda2
# systemd-cryptsetup attach root /dev/vda2
deploy =
{
sshUser = "root";
user = "root";
fastConnection = true;
autoRollback = false;
magicRollback = false;
2024-02-27 13:21:13 +08:00
nodes = builtins.listToAttrs (builtins.map
2023-09-01 21:05:26 +08:00
(node:
{
name = node;
value =
{
hostname = node;
profiles.system.path = inputs.self.nixosConfigurations.${node}.pkgs.deploy-rs.lib.activate.nixos
2023-11-19 17:44:07 +08:00
inputs.self.nixosConfigurations.${node};
2023-09-01 21:05:26 +08:00
};
})
2024-02-27 13:21:13 +08:00
[ "vps6" "vps7" "nas" "surface" "xmupc1" ]
);
2023-09-01 21:05:26 +08:00
};
2023-10-08 10:57:57 +08:00
checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks inputs.self.deploy) inputs.deploy-rs.lib;
2023-10-13 21:13:28 +08:00
overlays.default = final: prev:
{ localPackages = (import ./local/pkgs { inherit (inputs) lib; pkgs = final; }); };
2024-02-04 11:13:34 +08:00
config.archive = false;
2023-09-01 21:05:26 +08:00
};
2023-07-08 16:56:36 +08:00
}