summaryrefslogtreecommitdiff
path: root/psibuild
blob: 567fd2bead03cd9fcae69be8823fac144b39198d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/bin/bash

usage () {
 cat << EOF
usage: $0 PSIBUILD 
EOF
}

BUILD_FILE=${@: -1}

[[ $# = 0 ]] && usage && epsit 1
[ -f "$FILE" ] && echo "$BUILD_FILE not found" && epsit 1

source $BUILD_FILE

PKG_NAME=$(basename $BUILD_FILE .psibuild)

PSI_ROOT=$(pwd)
PKGS_OUTPUT=$PSI_ROOT/psipkgs

PKG_BUILD_DIR=$PSI_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 $PSI_ROOT

# bundle the package to a targz in the output dir
mkdir -p $PKGS_OUTPUT

PKG_FILE=$PKGS_OUTPUT/$PKG_NAME.psipkg

tar -C $PKG_BUILD_DIR/package -czf $PKG_FILE ./

# create info file
PKG_INFO=$PKGS_OUTPUT/$PKG_NAME.psipkg.info

echo "" > $PKG_INFO
echo "NAME=$PKG_NAME" >> $PKG_INFO
echo "PKG_FILE=$PKG_NAME.psipkg" >> $PKG_INFO
echo "CHECKSUM=$(md5sum $PKG_FILE | awk '{ print $1 }')" >> $PKG_INFO
echo "DATE=$(date)" >> $PKG_INFO
echo "DEPS=(${DEPS[*]})" >> $PKG_INFO

# sign the package
PRIV_KEY=$PSI_ROOT/keychain/psi.pem
PUB_KEY=$PSI_ROOT/keychain/psi.pub

if [ -f "$PRIV_KEY" ]; then
    echo "SIGNATURE=" >> $PKG_INFO
    openssl dgst -sign $PRIV_KEY $PKG_FILE >> $PKG_INFO
else
    echo "SIGNATURE=">> $PKG_INFO
    echo "unsigned">> $PKG_INFO
    >&2 echo "WARNING! no private key: unsigned packages!"
fi
# clean up
rm -rf $PKG_BUILD_DIR
rmdir $PSI_ROOT/tmp