GPG Signed commit check script

This commit is contained in:
2025-08-25 12:47:03 +03:00
parent 86c3a06ceb
commit ace4b7dfb0

54
git-sign-check.sh Executable file
View 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ı."