identity: scaffolding subcommands

This commit is contained in:
kalmenn 2023-12-22 01:54:52 +01:00
parent e9d16de77a
commit 4036ad73fc
Signed by: kalmenn
GPG key ID: F500055C44BC3834

View file

@ -1,43 +1,46 @@
#!/bin/sh #!/bin/sh
if [ -z "$1" ]; then identities="$HOME/.local/share/git/identities";
echo "USAGE:";
echo " git identity <gpg key id>";
echo;
echo "current identity:"; function add_identity() {
echo " name = $(git config user.name)"; uid_regex="([^\(]*)\s*(\((.*)\))?\s*<(.*)>";
echo " email = $(git config user.email)";
echo " key = $(git config user.signingKey)";
exit 1;
fi
uid_regex="([^\(]*)\s*(\((.*)\))?\s*<(.*)>"; uid=$(gpg --with-colons -K $1 | awk -F: '$1=="uid" {print $10; exit}');
uid=$(gpg --with-colons -K $1 | awk -F: '$1=="uid" {print $10; exit}'); if [ -z "$uid" ]; then
if [ -z "$uid" ]; then
echo "ERROR: found no gpg key matching this"; echo "ERROR: found no gpg key matching this";
exit 1; exit 1;
fi fi
name=$(printf "$uid" | sed --regexp-extended -e "s/$uid_regex/\1/"); name=$(printf "$uid" | sed --regexp-extended -e "s/$uid_regex/\1/");
email=$(printf "$uid" | sed --regexp-extended -e "s/$uid_regex/\4/"); email=$(printf "$uid" | sed --regexp-extended -e "s/$uid_regex/\4/");
echo "using this identity:"; echo "using this identity:";
echo " name = $name"; echo " name = $name";
echo " email = $email"; echo " email = $email";
git config --local user.name "$name" git config --local user.name "$name"
git config --local user.email "$email" git config --local user.email "$email"
keyid=$(gpg -K --with-colon $1 | awk -F: '$12~/.*s.*/ {print $5; exit}'); keyid=$(gpg -K --with-colon $1 | awk -F: '$12~/.*s.*/ {print $5; exit}');
# TODO: if multiple found, bring up a dialog to select the right key # TODO: if multiple found, bring up a dialog to select the right key
if [ -z "$keyid" ]; then if [ -z "$keyid" ]; then
echo "WARNING: found no subkey with signing capabilities. No signing key will be set"; echo "WARNING: found no subkey with signing capabilities. No signing key will be set";
git config --local --unset user.signingKey; git config --local --unset user.signingKey;
else else
echo " key = $keyid"; echo " key = $keyid";
git config --local user.signingKey "$keyid"; git config --local user.signingKey "$keyid";
fi fi
}
case $1 in
add)
add_identity $2
;;
*)
echo "USAGE:";
echo " git identity <command>";
exit 1;
;;
esac