nixos-config/home-manager/modules/git/default.nix

186 lines
4.6 KiB
Nix

{
pkgs,
config,
lib,
...
}:
with lib;
let
cfg = config.eboskma.programs.git;
in
{
options.eboskma.programs.git = {
enable = mkEnableOption "enable git";
package = mkOption {
description = "The git package to use";
type = types.package;
default = pkgs.gitFull;
};
name = mkOption {
description = "your name";
type = types.nonEmptyStr;
};
email = mkOption {
description = "your e-mail address";
type = types.nonEmptyStr;
};
signingKey = mkOption {
description = "your signing key";
type = types.nullOr types.str;
default = null;
};
signingKeyFormat = mkOption {
description = "the type of signing key";
type = types.enum [
"openpgp"
"x509"
"ssh"
];
default = "openpgp";
};
};
config = mkIf cfg.enable {
programs.git = {
enable = true;
package = cfg.package;
userName = cfg.name;
userEmail = cfg.email;
signing = mkIf (cfg.signingKey != null) {
key = cfg.signingKey;
signByDefault = true;
};
lfs.enable = true;
delta = {
enable = false;
options = {
side-by-side = false;
};
};
aliases = {
ls = "ls-files";
ignored = "ls-files -o -i --exclude-standard";
st = "status -s -b";
branches = "branch -a";
tags = "tag";
stashes = "stash list";
nevermind = "!git reset --hard HEAD && git clean -d -f";
graph = "log --graph -10 --branches --remotes --tags --format=format:'%Cgreen%h %Creset %<(75,trunc)%s (%cN, %cr) %Cred%d' --date-order";
precommit = "diff --cached --diff-algorithm=minimal -w";
track = "branch -u";
stat = "status -s";
up = "pull --autostash --rebase";
cm = "commit -m";
changelog = "log --oneline --no-merges";
source = "remote get-url origin";
};
extraConfig = {
# credential.helper = "${config.programs.git.package.override {withLibsecret = true;}}/bin/git-credential-libsecret";
credential = {
helper = "${pkgs.git-credential-manager}/bin/git-credential-manager";
credentialStore = "secretservice";
"https://dev.azure.com" = {
useHttpPath = true;
};
"https://git.datarift.nl" = {
provider = "generic";
oauthClientId = "3ae2eee7-1c52-4950-846e-17de716cfe77";
oauthClientSecret = "gto_tgalquoafnphcly4meztaxnfb3p2sq2aajksp7a2d4iu66c3ro2a";
oauthRedirectUri = "http://127.0.0.1:42069/";
oauthAuthorizeEndpoint = "/login/oauth/authorize";
oauthTokenEndpoint = "/login/oauth/access_token";
oauthScopes = "read:user repo";
};
};
init = {
defaultBranch = "main";
};
core = {
editor = "${config.eboskma.programs.emacs.package}/bin/emacsclient";
pager = "${pkgs.bat}/bin/bat";
fsmonitor = true;
};
merge = {
ff = "only";
conflictstyle = "diff3";
tool = "${pkgs.meld}/bin/meld";
};
pull = {
ff = "only";
};
push = {
default = "current";
};
rebase = {
autoStash = true;
};
rerere.enabled = true;
color = {
ui = "auto";
status = {
added = "yellow";
changed = "green";
untracked = "cyan";
};
branch = {
current = "yellow reverse";
local = "yellow";
remote = "green";
};
diff = {
meta = "yellow bold";
frag = "magenta bold";
old = "red bold";
new = "green bold";
};
};
grep = {
lineNumber = true;
column = true;
patternType = "extended";
};
gpg = {
format = cfg.signingKeyFormat;
ssh.allowedSignersFile = "~/.config/git/allowed_signers";
};
url = {
"ssh://git@repohost.bedum.horus.nu/" = {
insteadOf = "rh:";
pushInsteadOf = "rh:";
};
};
};
};
programs.gh = {
enable = true;
settings = {
git_protocol = "ssh";
editor = "nvim";
prompt = "enabled";
pager = "bat";
http_unix_socket = "";
browser = "";
version = "1";
};
};
home.packages = [
pkgs.git-credential-manager
pkgs.gitu
];
};
}