nixos-config/modules/home/programs/git.nix

52 lines
1.3 KiB
Nix

{ config, lib, ... }:
{
options.custom.programs.git.enable = lib.mkEnableOption "";
config = lib.mkIf config.custom.programs.git.enable {
sops.secrets =
config.custom.sops.secrets.ssh-key
|> lib.mapAttrs' (
name: _: lib.nameValuePair "ssh-key/${name}" { path = "${config.home.homeDirectory}/.ssh/${name}"; }
);
programs = {
git = {
enable = true;
settings = {
init.defaultBranch = "main";
user = {
name = "SebastianStork";
email = "sebastian.stork@pm.me";
};
};
signing = {
format = "ssh";
key = config.sops.secrets."ssh-key/git.sstork.dev".path;
signByDefault = true;
};
includes = lib.singleton {
condition = "gitdir:~/Projects/h-da/**";
contents = {
user = {
name = "Sebastian Stork";
email = "sebastian.stork@stud.h-da.de";
signingkey = config.sops.secrets."ssh-key/code.fbi.h-da.de".path;
};
};
};
};
ssh = {
enable = true;
matchBlocks =
config.custom.sops.secrets.ssh-key
|> lib.mapAttrs (name: _: { identityFile = config.sops.secrets."ssh-key/${name}".path; });
};
lazygit.enable = true;
};
};
}