nix-infra/flake.nix

176 lines
5.3 KiB
Nix
Raw Normal View History

2023-03-07 19:24:57 +00:00
{
inputs = {
2023-12-17 20:05:44 +00:00
nixpkgs.url = "nixpkgs/nixos-23.11";
2023-04-30 10:49:28 +00:00
nixpkgs-unstable.url = "nixpkgs/nixpkgs-unstable";
2023-03-07 19:24:57 +00:00
2023-09-17 16:57:46 +00:00
vampysite.url = "git+https://git.lain.faith/sorceress/vampysite";
2023-03-07 19:24:57 +00:00
home-manager = {
2023-12-17 20:05:44 +00:00
url = "github:nix-community/home-manager/release-23.11";
2023-03-07 19:24:57 +00:00
inputs.nixpkgs.follows = "nixpkgs";
};
mms = {
url = "github:mkaito/nixos-modded-minecraft-servers";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-09-17 16:57:46 +00:00
url-eater = {
url = "github:AgathaSorceress/url-eater";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
2023-04-07 16:20:50 +00:00
2023-09-17 16:57:46 +00:00
colorpickle = {
url = "github:AgathaSorceress/colorpickle";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
2023-04-11 17:49:24 +00:00
2023-09-17 16:57:46 +00:00
matrix-ril100 = {
url = "git+https://git.lain.faith/sorceress/matrix-ril100";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
2023-07-07 14:08:54 +00:00
2023-04-19 08:24:08 +00:00
# Latest colmena + prettier loading icons
2023-09-17 16:57:46 +00:00
colmena = {
url = "github:AgathaSorceress/colmena";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
2023-04-19 08:24:08 +00:00
2023-09-17 16:57:46 +00:00
frq-friend = {
url = "git+https://git.xenua.me/xenua/fedi-frq-friend";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
2023-04-13 11:11:32 +00:00
2023-09-17 16:57:46 +00:00
helix = {
url = "github:helix-editor/helix";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
2023-09-29 13:04:31 +00:00
ccase = {
url = "github:rutrum/ccase";
inputs.nixpkgs.follows = "nixpkgs-unstable";
};
2023-03-07 19:24:57 +00:00
};
2023-04-30 10:49:28 +00:00
outputs = { nixpkgs, nixpkgs-unstable, home-manager, mms, helix, url-eater
, colorpickle, matrix-ril100, frq-friend, colmena, vampysite, ccase, ...
}: {
2023-09-17 16:57:46 +00:00
colmena = let
mkDesktop = hostname: {
imports = [
./common
./hosts/${hostname}/configuration.nix
./common/options.nix
(import "${home-manager}/nixos")
2024-01-30 22:16:56 +00:00
url-eater.nixosModules.default
2023-09-17 16:57:46 +00:00
colorpickle.nixosModules.default
];
deployment = {
targetUser = "root";
targetHost = hostname;
tags = [ "home" ];
allowLocalDeployment = true;
2023-10-04 12:58:29 +00:00
keys = {
"restic-password" = {
keyCommand = [ "cat" "./secrets/restic-password" ];
destDir = "/var/lib/secrets/";
};
"restic-env" = {
keyCommand = [ "cat" "./secrets/restic-env" ];
destDir = "/var/lib/secrets/";
};
};
2023-09-17 16:57:46 +00:00
};
};
in {
2023-04-11 17:49:24 +00:00
network = {
description = "Agatha's Nix Infra";
2023-03-07 19:24:57 +00:00
2023-10-22 14:07:34 +00:00
nixpkgs = import nixpkgs rec {
2023-04-11 17:49:24 +00:00
system = "x86_64-linux";
2023-11-09 19:07:06 +00:00
config.allowUnfree = true;
2023-04-11 17:49:24 +00:00
overlays = [
(final: prev: {
2023-09-17 16:57:46 +00:00
helix = let helix-pkgs = helix.packages.${final.system};
in helix-pkgs.helix.passthru.wrapper
(helix-pkgs.helix-unwrapped.overrideAttrs {
preInstall = ''
substituteInPlace contrib/Helix.desktop \
--replace "Exec=hx %F" "Exec=kitty hx %F" \
--replace "Terminal=true" "Terminal=false"
'';
});
2023-04-20 20:22:22 +00:00
colorpickle = colorpickle.packages.${final.system}.default;
2024-01-30 22:16:56 +00:00
frq-friend = frq-friend.packages.${final.system}.default;
2023-04-22 13:12:30 +00:00
vampysite = vampysite.packages.${final.system}.default;
2023-07-07 14:08:54 +00:00
matrix-ril100 = matrix-ril100.packages.${final.system}.default;
2023-09-29 13:04:31 +00:00
ccase = ccase.packages.${final.system}.default;
2023-10-22 14:07:34 +00:00
# Unstable packages
2023-11-09 19:07:06 +00:00
unstable = import nixpkgs-unstable { inherit system config; };
2023-04-11 17:49:24 +00:00
})
2023-04-19 08:24:08 +00:00
colmena.overlay
2023-04-11 17:49:24 +00:00
];
};
2023-03-07 19:24:57 +00:00
};
2023-04-11 17:49:24 +00:00
bloodletting = {
imports = [
./common
./hosts/bloodletting/configuration.nix
(import "${home-manager}/nixos")
mms.module
];
2023-03-07 19:24:57 +00:00
2023-04-11 17:49:24 +00:00
deployment = {
targetUser = "root";
targetHost = "bloodletting";
2023-03-07 19:24:57 +00:00
2023-04-11 17:49:24 +00:00
tags = [ "prod" ];
2023-03-07 19:24:57 +00:00
2023-04-11 17:49:24 +00:00
keys = {
"nyandroid-token" = {
keyCommand = [ "cat" "./secrets/nyandroid-token" ];
destDir = "/var/lib/secrets/";
};
2024-05-22 00:10:22 +00:00
"hurricane-tokens" = {
keyCommand = [ "cat" "./secrets/hurricane-tokens" ];
2023-04-11 17:49:24 +00:00
destDir = "/var/lib/secrets/";
};
2024-05-22 00:11:16 +00:00
"mc-status-bot-env" = {
keyCommand = [ "cat" "./secrets/mc-status-bot-env" ];
destDir = "/var/lib/secrets";
};
2023-04-13 11:11:32 +00:00
"fedi-data.toml" = {
keyCommand = [ "cat" "./secrets/frq-friend-fedi-data.toml" ];
destDir = "/var/lib/frq-friend";
};
2023-07-07 14:08:54 +00:00
"ril100-bot-secrets" = {
keyCommand = [ "cat" "./secrets/ril100-bot-secrets" ];
destDir = "/var/lib/matrix-ril100";
name = ".env";
};
2023-03-07 19:24:57 +00:00
};
};
};
2023-03-26 16:14:49 +00:00
2023-09-17 16:57:46 +00:00
ritual = mkDesktop "ritual";
tears = mkDesktop "tears";
2023-03-26 16:14:49 +00:00
};
2023-04-19 08:24:08 +00:00
devShells."x86_64-linux".default =
let pkgs = import nixpkgs { system = "x86_64-linux"; };
in pkgs.mkShell {
buildInputs = [
(pkgs.writeShellScriptBin "colmena" ''
${
colmena.defaultPackage.${pkgs.system}
}/bin/colmena --disable-emoji $@
'')
];
};
2023-03-07 19:24:57 +00:00
};
}