2022-11-13 21:45:50 +00:00
|
|
|
{
|
|
|
|
description = "hacc infra stuff";
|
|
|
|
|
|
|
|
inputs = {
|
2023-01-02 21:51:16 +00:00
|
|
|
mattermost-webapp.url = "https://releases.mattermost.com/7.1.5/mattermost-7.1.5-linux-amd64.tar.gz";
|
2022-11-13 21:45:50 +00:00
|
|
|
mattermost-webapp.flake = false;
|
2023-01-02 21:51:16 +00:00
|
|
|
mattermost-server.url = "github:mattermost/mattermost-server?ref=v7.1.5";
|
2022-11-13 21:45:50 +00:00
|
|
|
mattermost-server.flake = false;
|
|
|
|
|
2022-11-23 23:03:16 +00:00
|
|
|
nixpkgs.url = "nixpkgs/nixos-22.11";
|
2022-11-14 17:19:26 +00:00
|
|
|
nixpkgs-unstable.url = "nixpkgs/nixpkgs-unstable";
|
|
|
|
nix-hexchen.url = "gitlab:hexchen/nixfiles";
|
|
|
|
nixos-mailserver.url = "gitlab:simple-nixos-mailserver/nixos-mailserver/nixos-22.05";
|
2023-01-22 01:25:07 +00:00
|
|
|
tracktrain.url = "git+https://stuebinm.eu/git/tracktrain?ref=main";
|
|
|
|
tracktrain.flake = false;
|
2022-11-13 22:04:55 +00:00
|
|
|
|
|
|
|
deploy-rs.url = "github:serokell/deploy-rs";
|
|
|
|
deploy-rs.inputs.nixpkgs.follows = "nixpkgs";
|
2022-11-25 21:48:27 +00:00
|
|
|
|
|
|
|
# these exist mostly to make the flake.lock somewhat more human-friendly
|
|
|
|
# note that in theory doing this might break things, but it seems fairly unlikely
|
|
|
|
nix-hexchen.inputs = {
|
|
|
|
nixos-mailserver.follows = "nixos-mailserver";
|
|
|
|
nixpkgs.follows = "nixpkgs-unstable";
|
|
|
|
deploy-rs.follows = "deploy-rs";
|
|
|
|
doom-emacs.follows = "nix-hexchen/nix-doom-emacs/doom-emacs";
|
|
|
|
emacs-overlay.follows = "nix-hexchen/nix-doom-emacs/emacs-overlay";
|
|
|
|
flake-utils.follows = "/deploy-rs/utils";
|
|
|
|
};
|
|
|
|
nixos-mailserver.inputs = {
|
|
|
|
"nixpkgs-22_05".follows = "nixpkgs";
|
|
|
|
nixpkgs.follows = "nixpkgs-unstable";
|
|
|
|
};
|
2022-11-13 21:45:50 +00:00
|
|
|
};
|
|
|
|
|
2022-11-13 22:04:55 +00:00
|
|
|
outputs = { self, nixpkgs, nix-hexchen, deploy-rs, ... }@inputs:
|
2022-11-13 21:45:50 +00:00
|
|
|
let modules = nix-hexchen.nixosModules;
|
|
|
|
profiles = nix-hexchen.nixosModules.profiles;
|
|
|
|
pkgs = import ./pkgs {
|
|
|
|
sources = inputs;
|
|
|
|
system = "x86_64-linux";
|
|
|
|
};
|
|
|
|
# simulate the evalConfig as contained in nix-hexchen/lib/hosts.nix,
|
|
|
|
# but compatible with flakes
|
|
|
|
evalConfig = extraSpecial: config: nixpkgs.lib.nixosSystem {
|
|
|
|
system = "x86_64-linux";
|
|
|
|
modules = [
|
|
|
|
config
|
|
|
|
nix-hexchen.nixosModules.network.nftables
|
|
|
|
{ nixpkgs.pkgs = pkgs; }
|
|
|
|
];
|
|
|
|
specialArgs = {
|
|
|
|
inherit modules profiles evalConfig;
|
|
|
|
sources = inputs;
|
|
|
|
} // extraSpecial;
|
|
|
|
};
|
|
|
|
in {
|
|
|
|
# do this by hand instead of via nix-hexchen/lib/hosts.nix, since that one
|
|
|
|
# apparently can't support pkgs depending on flake inputs
|
|
|
|
nixosConfigurations.parsons = nixpkgs.lib.nixosSystem {
|
|
|
|
system = "x86_64-linux";
|
|
|
|
modules = [
|
|
|
|
./hosts/parsons/configuration.nix
|
|
|
|
{ nixpkgs.pkgs = pkgs; }
|
|
|
|
];
|
|
|
|
specialArgs = {
|
|
|
|
# with a few exceptions, the flake inputs can be used the same
|
|
|
|
# as the niv-style (import nix/sources.nix {})
|
|
|
|
sources = inputs;
|
|
|
|
inherit modules profiles evalConfig;
|
|
|
|
};
|
|
|
|
};
|
2022-11-13 22:04:55 +00:00
|
|
|
|
|
|
|
deploy.nodes.parsons = {
|
|
|
|
hostname = "parsons";
|
|
|
|
profiles.system = {
|
|
|
|
user = "root";
|
2022-11-15 14:19:36 +00:00
|
|
|
autoRollback = false;
|
2022-11-13 22:04:55 +00:00
|
|
|
path = deploy-rs.lib.x86_64-linux.activate.nixos
|
|
|
|
self.nixosConfigurations.parsons;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# This is highly advised, and will prevent many possible mistakes
|
|
|
|
checks = builtins.mapAttrs
|
|
|
|
(system: deployLib: deployLib.deployChecks self.deploy)
|
|
|
|
deploy-rs.lib;
|
2022-11-13 21:45:50 +00:00
|
|
|
};
|
2022-11-13 22:04:55 +00:00
|
|
|
|
2022-11-13 21:45:50 +00:00
|
|
|
}
|