diff options
author | davidovski <david@davidovski.xyz> | 2021-09-29 20:48:36 +0100 |
---|---|---|
committer | davidovski <david@davidovski.xyz> | 2021-09-29 20:48:36 +0100 |
commit | 5b046bf12ce86157c32c68d6981ffe30796183f4 (patch) | |
tree | 73486b1a5f4bc2e986a65780b4bd856c4366aa4d /xibuild |
added key signing
Diffstat (limited to 'xibuild')
-rwxr-xr-x | xibuild | 66 |
1 files changed, 66 insertions, 0 deletions
@@ -0,0 +1,66 @@ +#!/bin/bash + +usage () { + cat << EOF +usage: $0 XIBUILD +EOF +} + +BUILD_FILE=${@: -1} + +[[ $# = 0 ]] && usage && exit 1 +[ -f "$FILE" ] && echo "$BUILD_FILE not found" && exit 1 + +source $BUILD_FILE + +PKG_NAME=$(basename $BUILD_FILE .xibuild) + +XI_ROOT=$(pwd) +PKGS_OUTPUT=$XI_ROOT/xipackages + +PKG_BUILD_DIR=$XI_ROOT/tmp/$PKG_NAME +PKG_DEST=$PKG_BUILD_DIR/package + +# make the directories +mkdir -p $PKG_DEST +cd $PKG_BUILD_DIR + +# fetch, build then package the package +fetch +build +package + + +# go back to root, make things easier +cd $XI_ROOT + +# bundle the package to a targz in the output dir +mkdir -p $PKGS_OUTPUT + +PKG_FILE=$PKGS_OUTPUT/$PKG_NAME.xipkg + +tar -C $PKG_BUILD_DIR/package -czf $PKG_FILE ./ + +# create info file +PKG_INFO=$PKGS_OUTPUT/$PKG_NAME.xipkg.info + +echo "" > $PKG_INFO +echo "NAME=$PKG_NAME" >> $PKG_INFO +echo "PKG_FILE=$PKG_NAME.xipkg" >> $PKG_INFO +echo "CHECKSUM=$(md5sum $PKG_FILE | awk '{ print $1 }')" >> $PKG_INFO +echo "DATE=$(date)" >> $PKG_INFO + +# sign the package +PRIV_KEY=$XI_ROOT/keychain/xi.pem +PUB_KEY=$XI_ROOT/keychain/xi.pub + +if [ -f "$PRIV_KEY" ]; then + echo "SIGNATURE=\n" >> $PKG_INFO + openssl dgst -sign $PRIV_KEY $PKG_FILE >> $PKG_INFO +else + echo "SIGNATURE=\nunsigned">> $PKG_INFO + >&2 echo "WARNING! no private key: unsigned packages!" +fi +# clean up +rm -rf $PKG_BUILD_DIR +rmdir $XI_ROOT/tmp |