infra/hosts/gerrit01/default.nix

130 lines
3.2 KiB
Nix
Raw Normal View History

{
config,
lib,
pkgs,
...
}:
{
networking.hostName = "gerrit01";
# TODO: make it the default
networking.domain = "infra.forkos.org";
time.timeZone = "Europe/Paris";
bagel.sysadmin.enable = true;
# Gerrit is proxied.
bagel.raito.v6-proxy-awareness.enable = true;
bagel.hardware.raito-vm = {
enable = true;
networking = {
nat-lan-mac = "bc:24:11:f7:29:6c";
wan = {
address = "2001:bc8:38ee:100:1000::10/64";
mac = "bc:24:11:4a:9d:32";
};
};
};
fileSystems."/gerrit-data" = {
device = "/dev/disk/by-uuid/d1062305-0dea-4740-9a27-b6b1691862a4";
fsType = "ext4";
};
bagel.services.gerrit = {
enable = true;
domains = [
"cl.forkos.org"
];
canonicalDomain = "cl.forkos.org";
data = "/gerrit-data";
};
age.secrets.ows-deploy-key = {
file = ../../secrets/ows-deploy-key.age;
mode = "0600";
owner = "git";
group = "git";
};
bagel.nixpkgs.one-way-sync =
let
2024-08-08 13:16:04 +00:00
mkNixpkgsJob = { timer, fromRefspec, localRefspec ? fromRefspec }: {
fromUri = "https://github.com/NixOS/nixpkgs";
2024-08-08 13:16:04 +00:00
inherit fromRefspec localRefspec timer;
};
mkLocalJob = { timer, fromRefspec, localRefspec }: {
fromUri = "https://cl.forkos.org/nixpkgs";
inherit fromRefspec localRefspec timer;
};
in
{
enable = true;
pushUrl = "ssh://ows_bot@cl.forkos.org:29418/nixpkgs";
deployKeyPath = config.age.secrets.ows-deploy-key.path;
2024-08-08 13:16:04 +00:00
# Sync main -> staging-next -> staging
branches."main-to-staging-next" = mkLocalJob {
2024-08-08 13:22:44 +00:00
timer = "00/8:20:00"; # every 8 hours, 20 minutes past the full hour
2024-08-08 13:16:04 +00:00
fromRefspec = "main";
localRefspec = "staging-next";
};
branches."staging-next-to-staging" = mkLocalJob {
2024-08-08 13:22:44 +00:00
timer = "00/8:40:00"; # every 8 hours, 40 minutes past the full hour
2024-08-08 13:16:04 +00:00
fromRefspec = "staging-next";
localRefspec = "staging";
};
# Sync nixpkgs -> fork
branches."nixpkgs-master" = mkNixpkgsJob {
timer = "hourly";
2024-08-08 13:16:04 +00:00
fromRefspec = "master";
localRefspec = "main";
};
2024-08-08 13:16:04 +00:00
branches."nixpkgs-staging" = mkNixpkgsJob {
timer = "hourly";
2024-08-08 13:16:04 +00:00
fromRefspec = "staging";
};
2024-08-08 13:16:04 +00:00
branches."nixpkgs-release-24.05" = mkNixpkgsJob {
timer = "hourly";
2024-08-08 13:16:04 +00:00
fromRefspec = "release-24.05";
};
2024-08-08 13:16:04 +00:00
branches."nixpkgs-staging-24.05" = mkNixpkgsJob {
timer = "hourly";
2024-08-08 13:16:04 +00:00
fromRefspec = "staging-24.05";
};
2024-08-08 13:16:04 +00:00
branches."nixpkgs-release-23.11" = mkNixpkgsJob {
timer = "hourly";
2024-08-08 13:16:04 +00:00
fromRefspec = "release-23.11";
};
2024-08-08 13:16:04 +00:00
branches."nixpkgs-staging-23.11" = mkNixpkgsJob {
timer = "hourly";
2024-08-08 13:16:04 +00:00
fromRefspec = "staging-23.11";
};
# Testing jobs for personal sandbox branches
2024-08-08 13:16:04 +00:00
branches."raito-unstable-sync" = {
fromUri = "https://github.com/NixOS/nixpkgs";
fromRefspec = "nixos-unstable-small";
localRefspec = "sandbox/raito/raito-unstable-small";
timer = "*-*-* 12:00:00";
};
2024-08-08 13:16:04 +00:00
branches."raito-release-sync" = {
fromUri = "https://github.com/NixOS/nixpkgs";
fromRefspec = "nixos-24.05";
localRefspec = "sandbox/raito/raito-nixos-24.05";
timer = "daily";
};
};
i18n.defaultLocale = "fr_FR.UTF-8";
system.stateVersion = "24.05";
deployment.targetHost = "gerrit01.infra.forkos.org";
}