diff options
author | Raymaekers Luca <raymaekers.luca@gmail.com> | 2024-10-07 23:03:29 +0200 |
---|---|---|
committer | Raymaekers Luca <raymaekers.luca@gmail.com> | 2024-10-07 23:03:29 +0200 |
commit | 7a91a55b79f828017b38c9f0af479b25c89bf6a9 (patch) | |
tree | dc6b1ab546c185f6d51527e838b0f9839ca2a9e0 /bin/common/gt-cmd | |
parent | bc97060419c4f70bd88f4b91eab82e0bb09e11c8 (diff) | |
parent | da6de4214938df5e59cc716dc0a336d9da28e9d0 (diff) |
Merge branch 'main' of db:dotfiles
Diffstat (limited to 'bin/common/gt-cmd')
-rwxr-xr-x | bin/common/gt-cmd | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/bin/common/gt-cmd b/bin/common/gt-cmd index 74b5f78..8cf30ae 100755 --- a/bin/common/gt-cmd +++ b/bin/common/gt-cmd @@ -17,13 +17,13 @@ fi # Check if repo's remote's key is in ssh-agent # If key is not registered and command is push/pull we exit with error +# Note: +# path to key: ~/.ssh/<hostname>.pub +# where <hostname> is the same in ssh config r="$(grep "$repo" "$REPOS" | cut -f 2 -d ' ' | cut -f 2 -d '@' | cut -f 1 -d ':')" -if { [ "$command" = "push" ] || [ "$command" = "pull" ]; } && - # In my ssh config every Host has the same name as its private key. This means remotes in - # "$REPOS" (here "$r") + .pub is the public key, so we convert the name to what would be the - # public key's name and check if its contents are registered in the ssh-agent. - [ -r "$HOME/.ssh/$r.pub" ] && - ! ssh-add -L | grep "$(cat "$HOME/.ssh/$r.pub")" > /dev/null +if { [ "$command" = "push" ] || [ "$command" = "pull" ] || [ "$command" = "fetch" ]; } && + # key not registered in agent + ! { ssh-add -L | grep "$(cat "$HOME/.ssh/$r.pub")" > /dev/null; } then printf '%s: '\''%s'\'' not in ssh-agent\n' "$repo_pretty" "$r" exit 1 |