2013-01-16 16:34:06 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
2013-02-08 15:38:13 +01:00
|
|
|
set -e
|
2013-02-22 17:35:23 +01:00
|
|
|
#set -x
|
2013-01-16 16:34:06 +01:00
|
|
|
|
2013-02-15 18:47:13 +01:00
|
|
|
source ./constraint.sh
|
2013-02-17 02:16:55 +01:00
|
|
|
if ! [ "${ID}" -ge "1000" ]; then
|
|
|
|
echo "This script cannot run as root."
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
2013-02-22 17:35:23 +01:00
|
|
|
source ./functions.sh
|
2013-01-16 16:34:06 +01:00
|
|
|
|
2013-02-08 15:38:13 +01:00
|
|
|
clean(){
|
|
|
|
echo Cleaning.
|
2013-02-17 02:16:55 +01:00
|
|
|
${SYNC}
|
2013-02-08 18:07:26 +01:00
|
|
|
|
|
|
|
# Cleanup source
|
2013-02-17 02:16:55 +01:00
|
|
|
${SUDO} ${UMOUNT} ${SRC} || true
|
|
|
|
rm -rf ${SRC}
|
2013-02-08 18:07:26 +01:00
|
|
|
|
|
|
|
# Cleanup destination
|
|
|
|
rm -rf ${TEMP}
|
|
|
|
rm -rf ${ZIPTEMP}
|
2013-02-17 02:16:55 +01:00
|
|
|
${SUDO} ${UMOUNT} ${DST} || true
|
|
|
|
rm -rf ${DST}
|
2013-02-08 18:07:26 +01:00
|
|
|
|
2013-02-15 18:47:13 +01:00
|
|
|
exit
|
2013-01-16 16:34:06 +01:00
|
|
|
}
|
|
|
|
|
2013-02-08 15:38:13 +01:00
|
|
|
trap clean EXIT TERM INT
|
2013-01-16 16:34:06 +01:00
|
|
|
|
2013-02-08 18:07:26 +01:00
|
|
|
# De we have a source device
|
2013-02-08 15:38:13 +01:00
|
|
|
if [ ! -b ${DEV_SRC} ]; then
|
2013-02-17 02:16:55 +01:00
|
|
|
echo "Source device (${DEV_SRC}) does not exists."
|
2013-02-08 15:38:13 +01:00
|
|
|
exit
|
|
|
|
fi
|
2013-02-08 18:07:26 +01:00
|
|
|
# Find the partition names on the source device
|
2013-02-17 02:16:55 +01:00
|
|
|
DEV_PARTITIONS=`ls "${DEV_SRC}"* | grep "${DEV_SRC}[1-9][0-6]*" || true`
|
2013-02-08 15:38:13 +01:00
|
|
|
if [ -z ${DEV_PARTITIONS} ]; then
|
2013-02-17 02:16:55 +01:00
|
|
|
echo "${DEV_SRC} does not have any partitions."
|
2013-02-08 15:38:13 +01:00
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
2013-02-08 18:07:26 +01:00
|
|
|
# Do we have a destination device
|
2013-02-08 15:38:13 +01:00
|
|
|
if [ ! -b ${DEV_DST} ]; then
|
2013-02-17 02:16:55 +01:00
|
|
|
echo "Destination device (${DEV_DST}) does not exists."
|
2013-02-08 15:38:13 +01:00
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
2013-02-08 18:07:26 +01:00
|
|
|
# Prepare mount points
|
2013-02-17 02:16:55 +01:00
|
|
|
if [ ! -d ${SRC} ]; then
|
|
|
|
mkdir ${SRC}
|
2013-01-16 16:34:06 +01:00
|
|
|
fi
|
2013-02-17 02:16:55 +01:00
|
|
|
if [ ! -d ${DST} ]; then
|
|
|
|
mkdir ${DST}
|
2013-01-16 16:34:06 +01:00
|
|
|
fi
|
|
|
|
|
2013-02-15 18:47:13 +01:00
|
|
|
# mount and prepare destination device
|
2013-02-17 02:16:55 +01:00
|
|
|
if ${MOUNT}|grep ${DST}; then
|
|
|
|
${SUDO} ${UMOUNT} ${DST} || true
|
2013-02-08 15:38:13 +01:00
|
|
|
fi
|
2013-02-15 18:47:13 +01:00
|
|
|
# uid= only works on a vfat FS. What should wedo if we get an ext* FS ?
|
2013-02-17 02:16:55 +01:00
|
|
|
${SUDO} ${MOUNT_DST} ${ID} ${DEV_DST} ${DST}
|
|
|
|
if [ ${?} -ne 0 ]; then
|
|
|
|
echo "Unable to mount ${DEV_DST} on ${DST}"
|
2013-02-08 18:07:26 +01:00
|
|
|
exit
|
2013-01-16 16:34:06 +01:00
|
|
|
else
|
2013-02-17 02:16:55 +01:00
|
|
|
echo "Target USB device (${DEV_DST}) mounted at ${DST}"
|
|
|
|
rm -rf "${DST}/FROM_PARTITION_"*
|
2013-01-16 16:34:06 +01:00
|
|
|
|
2013-02-17 02:16:55 +01:00
|
|
|
# prepare temp dirs and make sure it's empty
|
|
|
|
mkdir -p "${TEMP}"
|
|
|
|
mkdir -p "${ZIPTEMP}"
|
|
|
|
mkdir -p "${LOGS}"
|
2013-01-16 16:34:06 +01:00
|
|
|
|
2013-02-17 02:16:55 +01:00
|
|
|
rm -rf "${TEMP}/"*
|
|
|
|
rm -rf "${ZIPTEMP}/"*
|
|
|
|
rm -rf "${LOGS}/"*
|
2013-01-16 16:34:06 +01:00
|
|
|
fi
|
|
|
|
|
2013-02-08 18:07:26 +01:00
|
|
|
# Groom da kitteh!
|
|
|
|
|
2013-01-16 16:34:06 +01:00
|
|
|
COPYDIRTYPDF=0
|
|
|
|
PARTCOUNT=1
|
2013-02-08 18:07:26 +01:00
|
|
|
for partition in ${DEV_PARTITIONS}
|
2013-01-16 16:34:06 +01:00
|
|
|
do
|
2013-02-08 18:07:26 +01:00
|
|
|
# Processing a partition
|
2013-02-17 02:16:55 +01:00
|
|
|
echo "Processing partition: ${partition}"
|
|
|
|
if ${MOUNT}|grep ${SRC}; then
|
|
|
|
${SUDO} ${UMOUNT} ${SRC}
|
2013-02-08 15:38:13 +01:00
|
|
|
fi
|
|
|
|
|
2013-02-17 02:16:55 +01:00
|
|
|
${SUDO} ${MOUNT_SRC} ${partition} ${SRC}
|
|
|
|
if [ ${?} -ne 0 ]; then
|
|
|
|
echo "Unable to mount ${partition} on ${SRC}"
|
2013-01-16 16:34:06 +01:00
|
|
|
else
|
2013-02-17 02:16:55 +01:00
|
|
|
echo "${partition} mounted at ${SRC}"
|
2013-02-08 15:38:13 +01:00
|
|
|
|
2013-02-08 18:07:26 +01:00
|
|
|
# Print the filenames on the current partition in a logfile
|
2013-02-17 02:16:55 +01:00
|
|
|
find "${SRC}" -fls "${LOGS}/${PARTCOUNT}"
|
2013-02-08 15:38:13 +01:00
|
|
|
|
2013-02-17 02:16:55 +01:00
|
|
|
# create a directory on ${DST} named PARTION_$PARTCOUNT
|
|
|
|
target_dir="${DST}/FROM_PARTITION_${PARTCOUNT}"
|
|
|
|
echo "copying to: ${target_dir}"
|
|
|
|
mkdir -p "${target_dir}"
|
2013-02-08 15:38:13 +01:00
|
|
|
|
2013-02-22 17:35:23 +01:00
|
|
|
main ${target_dir}
|
|
|
|
|
2013-02-25 01:27:15 +01:00
|
|
|
ls -lR "${target_dir}"
|
2013-01-16 16:34:06 +01:00
|
|
|
fi
|
2013-03-30 19:38:11 +01:00
|
|
|
let PARTCOUNT=`expr $PARTCOUNT + 1`
|
2013-01-16 16:34:06 +01:00
|
|
|
done
|
|
|
|
|
2013-02-17 02:16:55 +01:00
|
|
|
# The cleanup is automatically done in the function clean called when
|
2013-02-08 18:07:26 +01:00
|
|
|
# the program quits
|