1
0
Fork 0

Set up sops-nix

This commit is contained in:
Avery 2024-04-03 23:27:14 +02:00
parent 84c3e5a976
commit ca41f6af9e
Signed by: Avery
GPG key ID: B684FD451B692E04
6 changed files with 132 additions and 10 deletions

View file

@ -0,0 +1,57 @@
{ lib, pkgs, ... }:
let
forgejoConfigPath = "/var/lib/forgejo/custom/conf";
arrayToSecrets = elements:
builtins.listToAttrs (map (x: {
name = "forgejo/" + x;
value = {
path = "${forgejoConfigPath}/" + x;
owner = "forgejo";
};
}) elements);
in {
services = {
forgejo = {
enable = true;
settings = {
server = {
DOMAIN = "git.rcia.dev";
ROOT_URL = "https://git.rcia.dev";
HTTP_PORT = 3000;
DISABLE_SSH = true;
LFS_START_SERVER = true;
LFS_JWT_SECRET = "";
LFS_JWT_SECRET_URI = "file://${forgejoConfigPath}/lfs_jwt_secret";
};
security = {
INSTALL_LOCK = true;
INTERNAL_TOKEN = lib.mkForce "";
INTERNAL_TOKEN_URI = "file://${forgejoConfigPath}/internal_token";
SECRET_KEY = lib.mkForce "";
SECRET_KEY_URI = "file://${forgejoConfigPath}/secret_key";
};
oauth2 = {
JWT_SECRET = lib.mkForce "";
JWT_SECRET_URI = "file://${forgejoConfigPath}/oauth2_jwt_secret";
};
};
};
nginx = {
virtualHosts."git.rcia.dev" = {
locations."/" = {
proxyPass = "http://127.0.0.1:3000";
clientMaxBodySize = "200M";
};
};
};
};
systemd.services.forgejo.preStart = ''
${pkgs.forgejo}/bin/gitea migrate
'';
sops.secrets = arrayToSecrets [
"internal_token"
"lfs_jwt_secret"
"oauth2_jwt_secret"
"secret_key"
];
}

View file

@ -99,8 +99,12 @@
};
udisks2.enable = true;
};
systemd = { services = { NetworkManager-wait-online.enable = false; }; };
sops = {
defaultSopsFile = "/etc/nixos/secrets/hosts/totsugeki.yaml";
age.keyFile = "/home/avery/.config/sops/age/keys.txt";
};
system.stateVersion = "24.05";
}