}
+function repo_gpg_key {
+
+ # usage: repo_gpg_key <folder>
+
+ local folder="$1"
+
+ if [ $SIGN_PACKAGES -eq $on ]; then
+ if [ -f "$folder/GPG-KEY" ]; then
+ if ! gpg --with-colons < $folder/GPG-KEY | cut -d : -f 5 | grep -q -e "$SIGN_KEYID$"; then
+ echo "Adding OpenPGP key id $SIGN_KEYID to $folder/GPG-KEY file..."
+ if [ ! -z "$SIGN_PACKAGES_USER" ]; then
+ su $SIGN_PACKAGES_USER -c "gpg --export --armor $SIGN_KEY_ID" >> $folder/GPG-KEY
+ else
+ gpg --export --armor $SIGN_KEY_ID >> $folder/GPG-KEY
+ fi
+ fi
+ else
+ echo "Adding OpenPGP key id $SIGN_KEYID to $folder/GPG-KEY file..."
+ if [ ! -z "$SIGN_PACKAGES_USER" ]; then
+ su $SIGN_PACKAGES_USER -c "gpg --export --armor $SIGN_KEY_ID" > $folder/GPG-KEY
+ else
+ gpg --export --armor $SIGN_KEY_ID > $folder/GPG-KEY
+ fi
+ fi
+ svn_add $folder/GPG-KEY
+ fi
+
+}
+
# -----------------------------------------------
# Error functions
# -----------------------------------------------
fi
}
+
+function check_gnupg {
+
+ # check if there's a keyring
+ # usage: check_gnupg [username]
+
+ local user="$1" home
+
+ if [ ! -z "$user" ]; then
+ echo "Setting up gnupg..."
+ home="`grep "^$user:" /etc/passwd | cut -d : -f 6`"
+ if [ ! -d "$home/.gnupg" ]; then
+ su $user -c "gpg --list-keys"
+ fi
+ else
+ if [ ! -d "$HOME/.gnupg" ]; then
+ echo "Setting up gnupg..."
+ gpg --list-keys
+ fi
+ fi
+
+}
cd $makepkg_repos
+ repo_gpg_key $makepkg_repos
gen_meta $SUBFOLDER/$PKG_NAME
gen_filelist
update_md5_checksum $makepkg_repos $SUBFOLDER/$PKG_NAME
echo "Signing package..."
+ check_gnupg $SIGN_PACKAGES_USER
+
if [ ! -z "$SIGN_PACKAGES_KEYID" ]; then
SIGN_KEYID="-u $SIGN_PACKAGES_KEYID"
else
- SIGN_KEYID=""
+ if [ ! -z "$SIGN_PACKAGES_USER" ]; then
+ SIGN_KEYID="-u `su $SIGN_PACKAGES_USER -c "gpg --list-secret-keys --with-colons | grep ^sec | head -n 1 | cut -d : -f 5"`"
+ else
+ SIGN_KEYID="-u `gpg --list-secret-keys --with-colons | grep ^sec | head -n 1 | cut -d : -f 5`"
+ fi
fi
if [ ! -z "$SIGN_PACKAGES_USER" ]; then
function simplaret_check_index {
for file in `simplaret_metafiles`; do
- if [ ! -f "$1/$file" ] && [ -f "$1/$file" ]; then
- echo restoring old $file to $1...
+ if [ ! -f "$1/$file" ] && [ -f "$1/$file.old" ]; then
+ echo Restoring old $file to $1...
mv $1/$file.old $1/$file
else
rm -f $1/$file.old
}
+function simplaret_import_gpg_keys {
+
+ if [ "$SIGNATURE_CHECKING" == "$on" ]; then
+ check_gnupg
+ if [ -f "$1/GPG-KEY" ] && [ -f "$1/GPG-KEY.old" ]; then
+ if diff $1/GPG-KEY $1/GPG-KEY.old &> /dev/null; then
+ gpg --import < $1/GPG-KEY
+ fi
+ elif [ -f "$1/GPG-KEY" ]; then
+ gpg --import < $1/GPG-KEY
+ fi
+ fi
+
+}
+
function simplaret_download {
# download a file from a repo to a folder
simplaret_get_index $repository_url $storage/$repository_name
simplaret_check_index $storage/$repository_name
+ simplaret_import_gpg_keys $storage/$repository_name
unset repository_name repository_url repository_protocol
function simplaret_metafiles {
- echo `simplaret_filelist` CHECKSUMS.md5
+ if [ "$SIGNATURE_CHECKING" == "$on" ]; then
+ echo `simplaret_filelist` CHECKSUMS.md5 GPG-KEY
+ else
+ echo `simplaret_filelist` CHECKSUMS.md5
+ fi
}