• Updated input 'catppuccin': 'github:catppuccin/nix/a817009ebfd2cca7f70a77884e5098d0a8c83f8e?narHash=sha256-uX/9m0TbdhEzuWA0muM5mI/AaWcLiDLjCCyu5Qr9MRk%3D' (20 24-11-30) → 'github:catppuccin/nix/1e4c3803b8da874ff75224ec8512cb173036bbd8?narHash=sha256-CFX4diEQHKvZYjnhf7TLg20m3ge1O4vqgplsk/Kuaek%3D' (20 24-12-20) • Updated input 'disko': 'github:nix-community/disko/785c1e02c7e465375df971949b8dcbde9ec362e5?narHash=sha256-8dupm9GfK%2BBowGdQd7EHK5V61nneLfr9xR6sc5vtDi0% 3D' (2024-12-02) → 'github:nix-community/disko/2ee76c861af3b895b3b104bae04777b61397485b?narHash=sha256-hk0roBX10j/hospoWIJIJj3i2skd7Oml6yKQBx7mTFk%3D ' (2024-12-20) • Updated input 'home-manager': 'github:nix-community/home-manager/9ebaa80a227eaca9c87c53ed515ade013bc2bca9?narHash=sha256-3JKzIou54yjiMVmvgdJwopekEvZxX3JDT8DpKZs 4oXY%3D' (2024-12-09) → 'github:nix-community/home-manager/1395379a7a36e40f2a76e7b9936cc52950baa1be?narHash=sha256-OOfI0XhSJGHblfdNDhfnn8QnZxng63rWk9eeJ2t CbiI%3D' (2024-12-19) • Updated input 'my-nixvim': 'git+https://git.xiny.li/xin/nixvim?ref=refs/heads/master&rev=a3709a89797ea094f82d38edeb4a538c07c8c3fa' (2024-11-30) → 'git+https://git.xiny.li/xin/nixvim?ref=refs/heads/master&rev=fdf7775c738e2eb6bb8cb707d35a900bc47cd53e' (2024-12-21) • Updated input 'nix-index-database': 'github:Mic92/nix-index-database/f1e477a7dd11e27e7f98b646349cd66bbabf2fb8?narHash=sha256-U0vivjQFAwjNDYt49Krevs1murX9hKBFe2Ye0cHpg bU%3D' (2024-12-08) → 'github:Mic92/nix-index-database/311d6cf3ad3f56cb051ffab1f480b2909b3f754d?narHash=sha256-icEMqBt4HtGH52PU5FHidgBrNJvOfXH6VQKNtnD1a w8%3D' (2024-12-15) • Updated input 'nix-vscode-extensions': 'github:nix-community/nix-vscode-extensions/66ced222ef9235f90dbdd754ede3d6476722aaa9?narHash=sha256-K595Q2PrZv2iiumdBkwM2G456T2lKs LD71bn/fbJiQ0%3D' (2024-12-10) → 'github:nix-community/nix-vscode-extensions/113779a6601d5b5c8ef7c5b5c4ab3f377fd3e2c3?narHash=sha256-rTGDkcbzfcTL7jE4TtxhNQtDssD1QY 8yLo8ApAv3XRs%3D' (2024-12-21) • Updated input 'nixos-hardware': 'github:NixOS/nixos-hardware/e563803af3526852b6b1d77107a81908c66a9fcf?narHash=sha256-IS3bxa4N1VMSh3/P6vhEAHQZecQ3oAlKCDvzCQSO5Is%3 D' (2024-12-06) → 'github:NixOS/nixos-hardware/b12e314726a4226298fe82776b4baeaa7bcf3dcd?narHash=sha256-mfv%2BJ/vO4nqmIOlq8Y1rRW8hVsGH3M%2BI2ESMjhueb Ds%3D' (2024-12-16) • Updated input 'nixpkgs': 'github:xinyangli/nixpkgs/61b1078fca3a097ce06ada68a6f2766347eed02c?narHash=sha256-AQdCeGt3dMV9/cchlWGMcP0Z8qM47V%2BB0p7cSRr%2BHhA% 3D' (2024-12-10) → 'github:xinyangli/nixpkgs/540fcd82c3de04893afaa30051de48871cc428b4?narHash=sha256-//RKBYxuo0PwIlijrnOr57yNpnp6g1opt3zb3xIS30M%3D' (2024-12-21) • Updated input 'nixpkgs-stable': 'github:nixos/nixpkgs/7109b680d161993918b0a126f38bc39763e5a709?narHash=sha256-dlK7n82FEyZlHH7BFHQAM5tua%2BlQO1Iv7aAtglc1O5s%3D' (2 024-12-09) → 'github:nixos/nixpkgs/72d11d40b9878a67c38f003c240c2d2e1811e72a?narHash=sha256-ze3IJksru9dN0keqUxY0WNf8xrwfs8Ty/z9v/keyBbg%3D' (202 4-12-18) • Updated input 'nur': 'github:nix-community/NUR/b54fa3d8c020e077d88be036a12a711b84fe2031?narHash=sha256-5F49/mOzFb40uUZh71uNr7kBXjDCw5ZfHMbpZjjUVBQ%3D' (2024-12-10) → 'github:nix-community/NUR/db4e0d95cd1f9f77113cd9c3c9de5974fa721a98?narHash=sha256-ZRG0vNJHRyKnzyWOFciCzodQlv4Sb2%2BH5I7xKIH2EL0%3D ' (2024-12-21) • Updated input 'nur/nixpkgs': 'github:nixos/nixpkgs/22c3f2cf41a0e70184334a958e6b124fb0ce3e01?narHash=sha256-Qn3nPMSopRQJgmvHzVqPcE3I03zJyl8cSbgnnltfFDY%3D' (202 4-12-07) → 'github:nixos/nixpkgs/d3c42f187194c26d9f0309a8ecc469d6c878ce33?narHash=sha256-cHar1vqHOOyC7f1%2BtVycPoWTfKIaqkoe1Q6TnKzuti4%3D' (2 024-12-17) • Updated input 'sops-nix': 'github:Mic92/sops-nix/a80af8929781b5fe92ddb8ae52e9027fae780d2a?narHash=sha256-pm4cfEcPXripE36PYCl0A2Tu5ruwHEvTee%2BHzNk%2BSQE%3D' (2024-12-09) → 'github:Mic92/sops-nix/ed091321f4dd88afc28b5b4456e0a15bd8374b4d?narHash=sha256-6OvJbqQ6qPpNw3CA%2BW8Myo5aaLhIJY/nNFDk3zMXLfM%3D' (2024-12-18)
354 lines
8.9 KiB
Nix
354 lines
8.9 KiB
Nix
{
|
|
inputs = {
|
|
# Pin nixpkgs to a specific commit
|
|
nixpkgs.url = "github:xinyangli/nixpkgs/deploy";
|
|
nixpkgs-stable.url = "github:nixos/nixpkgs/nixos-24.05";
|
|
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
nix-vscode-extensions = {
|
|
url = "github:nix-community/nix-vscode-extensions";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
inputs.flake-utils.follows = "flake-utils";
|
|
};
|
|
|
|
nur = {
|
|
url = "github:nix-community/NUR";
|
|
};
|
|
|
|
nixos-hardware = {
|
|
url = "github:NixOS/nixos-hardware/master";
|
|
};
|
|
|
|
sops-nix = {
|
|
url = "github:Mic92/sops-nix";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
flake-utils = {
|
|
url = "github:numtide/flake-utils";
|
|
};
|
|
|
|
colmena = {
|
|
url = "github:zhaofengli/colmena";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
nix-index-database = {
|
|
url = "github:Mic92/nix-index-database";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
my-nixvim = {
|
|
url = "git+https://git.xiny.li/xin/nixvim";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
catppuccin = {
|
|
url = "github:catppuccin/nix";
|
|
};
|
|
|
|
disko = {
|
|
url = "github:nix-community/disko";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
comin = {
|
|
url = "github:xinyangli/comin";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
};
|
|
|
|
outputs =
|
|
{
|
|
self,
|
|
nixpkgs,
|
|
home-manager,
|
|
nixos-hardware,
|
|
sops-nix,
|
|
flake-utils,
|
|
nur,
|
|
catppuccin,
|
|
my-nixvim,
|
|
nix-vscode-extensions,
|
|
colmena,
|
|
nix-index-database,
|
|
disko,
|
|
comin,
|
|
...
|
|
}:
|
|
let
|
|
editorOverlay = (
|
|
final: prev: {
|
|
inherit (nix-vscode-extensions.extensions.${prev.stdenv.system}) vscode-marketplace;
|
|
inherit (self.packages.${prev.stdenv.system}) nixvim;
|
|
}
|
|
);
|
|
overlayModule =
|
|
{ ... }:
|
|
{
|
|
options.my-lib = nixpkgs.lib.mkOption {
|
|
type = nixpkgs.lib.types.attrs;
|
|
default = import ./overlays/my-lib;
|
|
};
|
|
config = {
|
|
nixpkgs.overlays = [
|
|
editorOverlay
|
|
(import ./overlays/add-pkgs.nix)
|
|
];
|
|
};
|
|
};
|
|
deploymentModule = {
|
|
deployment.targetUser = "xin";
|
|
};
|
|
sharedHmModules = [
|
|
self.homeManagerModules.default
|
|
sops-nix.homeManagerModules.sops
|
|
nix-index-database.hmModules.nix-index
|
|
catppuccin.homeManagerModules.catppuccin
|
|
];
|
|
sharedNixosModules = [
|
|
self.nixosModules.default
|
|
sops-nix.nixosModules.sops
|
|
comin.nixosModules.comin
|
|
];
|
|
nodeNixosModules = {
|
|
calcite = [
|
|
nixos-hardware.nixosModules.asus-zephyrus-ga401
|
|
catppuccin.nixosModules.catppuccin
|
|
machines/calcite/configuration.nix
|
|
(mkHome "xin" "calcite")
|
|
];
|
|
hk-00 = [
|
|
./machines/dolomite/claw.nix
|
|
./machines/dolomite/common.nix
|
|
];
|
|
la-00 = [
|
|
./machines/dolomite/bandwagon.nix
|
|
./machines/dolomite/common.nix
|
|
];
|
|
fra-00 = [
|
|
./machines/dolomite/fra.nix
|
|
./machines/dolomite/common.nix
|
|
];
|
|
osmium = [
|
|
./machines/osmium
|
|
];
|
|
thorite = [
|
|
disko.nixosModules.disko
|
|
./machines/thorite
|
|
];
|
|
biotite = [
|
|
disko.nixosModules.disko
|
|
./machines/biotite
|
|
];
|
|
};
|
|
sharedColmenaModules = [
|
|
deploymentModule
|
|
] ++ sharedNixosModules;
|
|
mkHome =
|
|
user: host:
|
|
{ ... }:
|
|
{
|
|
imports = [ home-manager.nixosModules.home-manager ];
|
|
config = {
|
|
home-manager = {
|
|
sharedModules = sharedHmModules;
|
|
useGlobalPkgs = true;
|
|
useUserPackages = true;
|
|
};
|
|
home-manager.users.${user} = (import ./home).${user}.${host};
|
|
};
|
|
};
|
|
mkNixos =
|
|
{
|
|
hostname,
|
|
system ? null,
|
|
}:
|
|
nixpkgs.lib.nixosSystem {
|
|
modules = sharedNixosModules ++ nodeNixosModules.${hostname};
|
|
};
|
|
# TODO:
|
|
mkColmenaHive =
|
|
{
|
|
hostname,
|
|
}:
|
|
colmena.lib.makeHive {
|
|
meta = {
|
|
# FIXME:
|
|
nixpkgs = import nixpkgs { system = "x86_64-linux"; };
|
|
};
|
|
};
|
|
in
|
|
{
|
|
nixosModules.default = {
|
|
imports = [
|
|
./modules/nixos
|
|
overlayModule
|
|
];
|
|
};
|
|
homeManagerModules.default = import ./modules/home-manager;
|
|
|
|
colmenaHive = colmena.lib.makeHive {
|
|
meta = {
|
|
# FIXME:
|
|
nixpkgs = import nixpkgs {
|
|
system = "x86_64-linux";
|
|
};
|
|
};
|
|
|
|
massicot =
|
|
{ ... }:
|
|
{
|
|
deployment.targetHost = "49.13.13.122";
|
|
deployment.buildOnTarget = true;
|
|
|
|
imports = [
|
|
{ nixpkgs.system = "aarch64-linux"; }
|
|
machines/massicot
|
|
] ++ sharedColmenaModules;
|
|
};
|
|
|
|
la-00 =
|
|
{ ... }:
|
|
{
|
|
imports = nodeNixosModules.la-00 ++ sharedColmenaModules;
|
|
nixpkgs.system = "x86_64-linux";
|
|
networking.hostName = "la-00";
|
|
system.stateVersion = "21.05";
|
|
deployment = {
|
|
targetHost = "la-00.video.namely.icu";
|
|
buildOnTarget = false;
|
|
tags = [ "proxy" ];
|
|
};
|
|
};
|
|
|
|
hk-00 =
|
|
{ ... }:
|
|
{
|
|
imports = nodeNixosModules.hk-00 ++ sharedColmenaModules;
|
|
nixpkgs.system = "x86_64-linux";
|
|
networking.hostName = "hk-00";
|
|
system.stateVersion = "24.05";
|
|
deployment = {
|
|
targetHost = "hk-00.video.namely.icu";
|
|
buildOnTarget = false;
|
|
tags = [ "proxy" ];
|
|
};
|
|
};
|
|
|
|
fra-00 =
|
|
{ ... }:
|
|
{
|
|
imports = nodeNixosModules.fra-00 ++ sharedColmenaModules;
|
|
nixpkgs.system = "x86_64-linux";
|
|
networking.hostName = "fra-00";
|
|
system.stateVersion = "24.05";
|
|
deployment = {
|
|
targetHost = "fra-00.video.namely.icu";
|
|
buildOnTarget = false;
|
|
tags = [ "proxy" ];
|
|
};
|
|
};
|
|
|
|
raspite =
|
|
{ ... }:
|
|
{
|
|
deployment = {
|
|
targetHost = "raspite.coho-tet.ts.net";
|
|
buildOnTarget = false;
|
|
};
|
|
nixpkgs.system = "aarch64-linux";
|
|
imports = [
|
|
"${nixpkgs}/nixos/modules/installer/sd-card/sd-image-aarch64.nix"
|
|
nixos-hardware.nixosModules.raspberry-pi-4
|
|
machines/raspite/configuration.nix
|
|
] ++ sharedColmenaModules;
|
|
};
|
|
|
|
weilite =
|
|
{ ... }:
|
|
{
|
|
imports = [ machines/weilite ] ++ sharedColmenaModules;
|
|
deployment = {
|
|
targetHost = "weilite.coho-tet.ts.net";
|
|
targetPort = 22;
|
|
buildOnTarget = false;
|
|
};
|
|
nixpkgs.system = "x86_64-linux";
|
|
};
|
|
thorite =
|
|
{ ... }:
|
|
{
|
|
imports = nodeNixosModules.thorite ++ sharedColmenaModules;
|
|
deployment = {
|
|
buildOnTarget = false;
|
|
};
|
|
};
|
|
biotite =
|
|
{ ... }:
|
|
{
|
|
imports = nodeNixosModules.biotite ++ sharedColmenaModules;
|
|
};
|
|
|
|
osmium =
|
|
{ ... }:
|
|
{
|
|
deployment = {
|
|
targetHost = "osmium.coho-tet.ts.net";
|
|
buildOnTarget = false;
|
|
};
|
|
imports = nodeNixosModules.osmium ++ sharedColmenaModules;
|
|
};
|
|
};
|
|
|
|
nixosConfigurations = {
|
|
calcite = mkNixos {
|
|
hostname = "calcite";
|
|
};
|
|
} // self.colmenaHive.nodes;
|
|
|
|
}
|
|
// flake-utils.lib.eachDefaultSystem (
|
|
system:
|
|
let
|
|
pkgs = nixpkgs.legacyPackages.${system};
|
|
|
|
mkHomeConfiguration = user: host: {
|
|
name = "${user}-${host}";
|
|
value = home-manager.lib.homeManagerConfiguration {
|
|
inherit pkgs;
|
|
modules = [
|
|
(import ./home).${user}.${host}
|
|
overlayModule
|
|
] ++ sharedHmModules;
|
|
};
|
|
};
|
|
in
|
|
{
|
|
devShells = {
|
|
default = pkgs.mkShell {
|
|
packages = with pkgs; [
|
|
nix
|
|
git
|
|
sops
|
|
nix-output-monitor
|
|
nil
|
|
nvd
|
|
nh
|
|
(python3.withPackages (ps: with ps; [ requests ]))
|
|
];
|
|
};
|
|
};
|
|
|
|
homeConfigurations = builtins.listToAttrs [ (mkHomeConfiguration "xin" "calcite") ];
|
|
|
|
packages = {
|
|
nixvim = my-nixvim.packages.${system}.default;
|
|
};
|
|
}
|
|
);
|
|
}
|