wok-current annotate boxbackup-server/receipt @ rev 20447
Up tazusb (201)
author | Richard Dunbar <mojo@slitaz.org> |
---|---|
date | Thu Sep 20 12:10:01 2018 -0400 (2018-09-20) |
parents | ed8073aa8cf0 |
children | a01ff9505078 |
rev | line source |
---|---|
domcox@1357 | 1 # SliTaz package receipt. |
domcox@1357 | 2 |
domcox@1357 | 3 PACKAGE="boxbackup-server" |
domcox@10920 | 4 VERSION="0.11.1" |
domcox@1357 | 5 CATEGORY="network" |
domcox@1357 | 6 SHORT_DESC="Server for the BoxBackup on-line backup system" |
domcox@12350 | 7 MAINTAINER="domcox@slitaz.org" |
pascal@15202 | 8 LICENSE="GPL2" |
al@19288 | 9 WEB_SITE="http://www.boxbackup.org/" |
domcox@1357 | 10 SOURCE="boxbackup" |
domcox@1357 | 11 TARBALL="$SOURCE-$VERSION.tgz" |
domcox@5320 | 12 # stable |
domcox@5320 | 13 # WGET_URL="$SF_MIRROR/$SOURCE/$TARBALL" |
domcox@12350 | 14 #WGET_URL="http://www.boxbackup.org/svn/box/packages/$TARBALL" |
pascal@12663 | 15 WGET_URL="http://www.boxbackup.org/export/3106/box/packages/$TARBALL" |
jozee@3568 | 16 TAGS="backup automatic server network" |
domcox@1357 | 17 |
pascal@15202 | 18 DEPENDS="db libedit openssl perl zlib gcc-lib-base" |
pascal@15202 | 19 BUILD_DEPENDS="db-dev libedit-dev openssl-dev zlib-dev" |
pascal@15202 | 20 |
domcox@1357 | 21 # Configuration variables |
domcox@12350 | 22 HOSTNAME=$(ifconfig | awk -F ":" '/cast/ {print substr($2,0, index($2," ")-1) }') |
domcox@12350 | 23 CONF_DIR="/etc/boxbackup" |
domcox@1357 | 24 DATA_DIR="/var/lib/bbstored" |
domcox@1357 | 25 CA_DIR="${CONF_DIR}/ca" |
domcox@1357 | 26 BBUSER="bbstored" |
domcox@1357 | 27 |
domcox@1357 | 28 # Rules to configure and make the package. |
domcox@1357 | 29 compile_rules() |
domcox@1357 | 30 { |
pascal@4998 | 31 ./configure --prefix=/usr $CONFIGURE_ARGS && |
pascal@9047 | 32 make -j1 && { |
pascal@9047 | 33 mkdir -p $DESTDIR |
pascal@9099 | 34 cp -a parcels/boxbackup-${VERSION}-backup-client-linux-gnu $DESTDIR |
pascal@9099 | 35 cp -a parcels/boxbackup-${VERSION}-backup-server-linux-gnu $DESTDIR |
pascal@9099 | 36 rm -f $DESTDIR/boxbackup-${VERSION}-backup-server-linux-gnu/*.* |
pascal@9047 | 37 } |
al@19288 | 38 |
al@19288 | 39 cook_pick_manpages $src/docs/man/* |
domcox@1357 | 40 } |
domcox@1357 | 41 |
domcox@1357 | 42 # Rules to gen a SliTaz package suitable for Tazpkg. |
domcox@1357 | 43 genpkg_rules() |
domcox@1357 | 44 { |
domcox@1357 | 45 mkdir -p $fs/usr/bin |
pascal@15202 | 46 cp -a $install/boxbackup-${VERSION}-backup-server-linux-gnu/bb* $fs/usr/bin |
pascal@15202 | 47 cp -a $install/boxbackup-${VERSION}-backup-server-linux-gnu/ra* $fs/usr/bin |
domcox@1357 | 48 mkdir -p $fs/etc/init.d |
pankso@9697 | 49 cp -a $stuff/bbstored $fs/etc/init.d |
domcox@1357 | 50 } |
domcox@1357 | 51 |
domcox@1357 | 52 |
domcox@1357 | 53 # Pre and post install commands for Tazpkg. |
domcox@1357 | 54 |
domcox@1357 | 55 pre_install() |
domcox@1357 | 56 { |
domcox@1357 | 57 # Stop daemon |
al@18668 | 58 if [ -z "$1" -a -e /var/run/bbstored.pid ]; then |
domcox@1357 | 59 /etc/init.d/bbstored stop |
domcox@1357 | 60 fi |
domcox@1357 | 61 } |
domcox@1357 | 62 |
domcox@1357 | 63 post_install() |
domcox@1357 | 64 { |
domcox@12350 | 65 # default conf dir is now /etc/boxbackup |
pascal@18730 | 66 if [ ! -e "$1/etc/box/bbstored.conf" ]; then |
pascal@18732 | 67 mv "$1/etc/box" "$1$CONF_DIR" |
domcox@12350 | 68 fi |
domcox@12350 | 69 |
domcox@1357 | 70 # adduser BBUSER if needed |
pascal@18730 | 71 if ! grep -q $BBUSER "$1/etc/passwd"; then |
al@18668 | 72 echo |
al@18668 | 73 action "Adding user '$BBUSER'..." |
pascal@18730 | 74 echo $BBUSER':x:505:505:BoxBackup Network Backup:/dev/null:/bin/false' >> "$1/etc/passwd" |
pascal@18730 | 75 echo $BBUSER':!:14013:0:99999:7:::' >> "$1/etc/shadow" |
pascal@18730 | 76 echo $BBUSER':x:505:' >> "$1/etc/group" |
pascal@18730 | 77 echo $BBUSER':!::' >> "$1/etc/gshadow" |
domcox@1357 | 78 status |
domcox@1357 | 79 fi |
domcox@1357 | 80 |
domcox@1357 | 81 # Create config is needed |
pascal@18730 | 82 if [ ! -e "$1$CONF_DIR" ]; then |
pascal@18730 | 83 mkdir -p "$1$CONF_DIR" && |
pascal@18730 | 84 chroot "$1/" chown $BBUSER $CONF_DIR && |
pascal@18730 | 85 chmod 700 "$1$CONF_DIR" |
domcox@1357 | 86 fi |
domcox@1357 | 87 |
pascal@18730 | 88 if [ ! -e "$1$DATA_DIR/backup" ]; then |
domcox@1357 | 89 # Creating backup dir |
al@18668 | 90 action "Creating backup directory..." |
pascal@18730 | 91 mkdir -p "$1$DATA_DIR/backup" && |
pascal@18730 | 92 chroot "$1/" chown -R $BBUSER $DATA_DIR && |
pascal@18730 | 93 chmod -R 700 "$1$DATA_DIR" |
domcox@1357 | 94 status |
domcox@1357 | 95 fi |
domcox@1357 | 96 |
pascal@18730 | 97 if [ ! -e "$1$CONF_DIR/raidfile.conf" ]; then |
domcox@1357 | 98 # RAID Setup |
al@18668 | 99 action "Disabling deprecated userland RAID..." |
pascal@18730 | 100 chroot "$1/" /usr/bin/raidfile-config $CONF_DIR 2048 $DATA_DIR 2>1 > /dev/null |
domcox@1357 | 101 status |
pascal@18730 | 102 chroot "$1/" chown -R $BBUSER $CONF_DIR/raidfile.conf && |
pascal@18730 | 103 chmod 700 -R "$1$CONF_DIR/raidfile.conf" |
domcox@1357 | 104 fi |
domcox@1357 | 105 |
pascal@18730 | 106 if [ ! -e "$1$CONF_DIR/bbstored.conf" ]; then |
domcox@1357 | 107 # Setting hostname |
al@18668 | 108 action "Setting hostname... " |
pascal@18730 | 109 if [ $(chroot "$1/" hostname -f 2>1 > /dev/null;echo $?) -eq 0 ]; then |
pascal@18730 | 110 HOSTNAME=$(chroot "$1/" hostname -f) |
domcox@1357 | 111 fi |
domcox@1357 | 112 if [ -z $HOSTNAME ]; then |
domcox@1357 | 113 HOSTNAME="127.0.0.1" |
domcox@1357 | 114 fi |
pascal@17940 | 115 export $HOSTNAME |
domcox@1357 | 116 echo $HOSTNAME |
domcox@1357 | 117 |
domcox@1357 | 118 # Setting up the CA environment |
al@18668 | 119 action "Creating certificates..." |
pascal@18730 | 120 chroot "$1/" /usr/bin/bbstored-certs $CA_DIR init 2>1 > /dev/null |
domcox@1357 | 121 status |
domcox@1357 | 122 |
domcox@1357 | 123 # Generate server certificate request |
al@18668 | 124 action "Generate server certificate request..." |
pascal@18730 | 125 chroot "$1/" bbstored-config $CONF_DIR $HOSTNAME $BBUSER 2>1 > /dev/null |
domcox@1357 | 126 status |
domcox@1357 | 127 |
domcox@1357 | 128 # Sign the server certificate |
al@18668 | 129 action "Sign the server certificate..." |
pascal@18730 | 130 chroot "$1/" openssl x509 -req -sha1 -extensions usr_crt \ |
domcox@1357 | 131 -in $CONF_DIR/$BBUSER/${HOSTNAME}-csr.pem \ |
domcox@1357 | 132 -CA $CA_DIR/roots/serverCA.pem \ |
domcox@1357 | 133 -CAkey $CA_DIR/keys/serverRootKey.pem \ |
domcox@1357 | 134 -out $CA_DIR/servers/${HOSTNAME}-cert.pem \ |
domcox@1357 | 135 -days 5000 2>1 > /dev/null |
domcox@1357 | 136 status |
domcox@1357 | 137 |
domcox@1357 | 138 # Preparing the server certificates |
al@18668 | 139 action "Installing server certificate..." |
pascal@18730 | 140 cp -a "$1$CA_DIR/servers/${HOSTNAME}-cert.pem" "$1$CONF_DIR/$BBUSER" |
domcox@1357 | 141 status |
al@18668 | 142 action "Installing client certificate..." |
pascal@18730 | 143 cp -a "$1$CA_DIR/roots/clientCA.pem" "$1$CONF_DIR/$BBUSER" |
domcox@1357 | 144 status |
domcox@1357 | 145 |
domcox@1357 | 146 # Securing $CONF_DIR |
pascal@18730 | 147 chroot "$1/" chown -R $BBUSER $CONF_DIR/bbstored* && |
pascal@18730 | 148 chmod 700 -R "$1$CONF_DIR/bbstored"* |
domcox@1357 | 149 fi |
domcox@1357 | 150 |
pascal@18730 | 151 if [ -e "$1$CA_DIR" ]; then |
domcox@1357 | 152 # Warning |
domcox@1357 | 153 echo |
domcox@1357 | 154 echo "IMPORTANT NOTE:" |
domcox@1357 | 155 echo "--------------" |
domcox@1357 | 156 echo "The certificate authority directory $CA_DIR is intended to be" |
domcox@1357 | 157 echo "moved to another system. It should not be kept on the backup server" |
domcox@1357 | 158 echo "to limit the impact of a server compromise." |
domcox@1357 | 159 fi |
domcox@1357 | 160 } |
domcox@1357 | 161 |
domcox@1357 | 162 # Pre and post remove commands for Tazpkg |
domcox@1357 | 163 |
domcox@1357 | 164 pre_remove() |
domcox@1357 | 165 { |
domcox@1357 | 166 /etc/init.d/bbstored stop |
domcox@1357 | 167 } |
domcox@1357 | 168 |
domcox@1357 | 169 post_remove() |
domcox@1357 | 170 { |
al@18668 | 171 echo |
pascal@18730 | 172 if grep -q $BBUSER /etc/passwd; then |
al@18668 | 173 action "Removing $BBUSER user..." |
domcox@1357 | 174 deluser bbstored |
domcox@1357 | 175 status |
domcox@1357 | 176 fi |
domcox@1357 | 177 # Delete data |
domcox@1357 | 178 if [ -e $DATA_DIR ]; then |
al@18668 | 179 action "Removing all backup data..." |
domcox@1357 | 180 rm -r $DATA_DIR |
domcox@1357 | 181 status |
domcox@1357 | 182 fi |
domcox@1357 | 183 # Delete bbstored conf files |
domcox@1357 | 184 if [ -e $CONF_DIR/bbstored.conf ]; then |
al@18668 | 185 action "Removing config files..." |
domcox@1357 | 186 rm -rf $CONF_DIR/bbstored |
domcox@1357 | 187 rm -f $CONF_DIR/raidfile.conf |
domcox@1357 | 188 rm -f $CONF_DIR/bbstored.conf |
domcox@1357 | 189 status |
domcox@1357 | 190 fi |
domcox@1357 | 191 # Delete certificates |
domcox@1357 | 192 if [ -e $CA_DIR ]; then |
al@18668 | 193 action "Removing certificates..." |
al@18668 | 194 rm -r $CA_DIR |
domcox@1357 | 195 status |
al@18668 | 196 fi |
domcox@1357 | 197 # Delete $CONF_DIR (if empty) |
domcox@12350 | 198 if [ $(ls -lA $CONF_DIR | wc -l) -eq 0 ]; then |
al@18668 | 199 action "Removing $CONF_DIR..." |
domcox@1357 | 200 rm -r $CONF_DIR |
domcox@1357 | 201 status |
domcox@1357 | 202 fi |
domcox@1357 | 203 # Delete PID, sock files |
domcox@1357 | 204 rm -f /var/run/bbstored.* |
jozee@3568 | 205 } |