GPG Signed commit check script
This commit is contained in:
54
git-sign-check.sh
Executable file
54
git-sign-check.sh
Executable file
@@ -0,0 +1,54 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Federatif Signed Commit Denetleyici (Etkileşimli versiyon)
|
||||
# Gereksinimler: gpg, git
|
||||
|
||||
echo "🔐 Lütfen GPG key ID'nizi girin (örnek: D200B456637BC4F3):"
|
||||
read -r KEYID
|
||||
|
||||
if [ -z "$KEYID" ]; then
|
||||
echo "❌ GPG key ID girilmedi. Çıkılıyor."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "🔍 GPG Key ID: $KEYID"
|
||||
|
||||
# GPG key'den email'leri çek
|
||||
echo "📧 GPG Key'e bağlı epostalar:"
|
||||
gpg --list-keys "$KEYID" | grep -E 'uid' | sed -E 's/.*<([^>]+)>.*/\1/' | tee /tmp/gpg_emails.txt
|
||||
|
||||
# Git config'deki email ve signing key
|
||||
GIT_EMAIL=$(git config user.email)
|
||||
GIT_SIGNKEY=$(git config user.signingkey)
|
||||
GIT_REMOTE=$(git remote get-url origin)
|
||||
|
||||
echo "📝 Git config email: $GIT_EMAIL"
|
||||
echo "🔐 Git signing key: $GIT_SIGNKEY"
|
||||
echo "🌐 Git remote URL: $GIT_REMOTE"
|
||||
|
||||
# SSH bağlantısı mı?
|
||||
if [[ "$GIT_REMOTE" == git@github.com:* ]]; then
|
||||
echo "✅ SSH bağlantısı kullanılıyor."
|
||||
else
|
||||
echo "⚠️ Uyarı: GitHub bağlantısı SSH değil. HTTPS kullanılıyorsa GPG doğrulama etkilenmez ama SSH tercih edilir."
|
||||
fi
|
||||
|
||||
# Son commit signed mı?
|
||||
echo "🧾 Son commit imza durumu:"
|
||||
git log --show-signature -1
|
||||
|
||||
# Eşleşme kontrolü
|
||||
echo "🔗 GPG ↔ Git eşleşme kontrolü:"
|
||||
MATCH=false
|
||||
while read -r gpg_email; do
|
||||
if [[ "$gpg_email" == "$GIT_EMAIL" ]]; then
|
||||
echo "✅ GPG email Git config ile eşleşiyor: $gpg_email"
|
||||
MATCH=true
|
||||
fi
|
||||
done < /tmp/gpg_emails.txt
|
||||
|
||||
if [ "$MATCH" = false ]; then
|
||||
echo "❌ GPG email Git config ile eşleşmiyor. Commit'ler GitHub'da 'Unverified' olabilir."
|
||||
fi
|
||||
|
||||
echo "🎯 Denetim tamamlandı."
|
Reference in New Issue
Block a user