virtual-dsm/install.sh

178 lines
4.7 KiB
Bash
Raw Normal View History

2023-03-28 07:24:17 +02:00
#!/usr/bin/env bash
set -eu
2023-04-07 18:51:18 +02:00
# Display wait message on port 5000
/run/server.sh 5000 > /dev/null &
2023-04-14 16:12:14 +02:00
if [ -z $URL ]; then
URL="https://global.synologydownload.com/download/DSM/beta/7.2/64216/DSM_VirtualDSM_64216.pat"
#URL="https://global.synologydownload.com/download/DSM/release/7.0.1/42218/DSM_VirtualDSM_42218.pat"
#URL="https://global.synologydownload.com/download/DSM/release/7.1.1/42962-1/DSM_VirtualDSM_42962.pat"
fi
2023-04-02 08:28:31 +02:00
2023-04-14 16:54:41 +02:00
BASE=$(basename "$URL" .pat)
2023-04-14 17:08:55 +02:00
rm -f "$IMG"/"$BASE".pat
rm -f "$IMG"/"$BASE".agent
rm -f "$IMG"/"$BASE".boot.img
rm -f "$IMG"/"$BASE".system.img
2023-04-02 08:28:31 +02:00
echo "Install: Downloading extractor..."
2023-04-14 16:12:14 +02:00
TMP="$IMG/tmp"
2023-04-02 08:28:31 +02:00
rm -rf $TMP && mkdir -p $TMP
2023-04-14 16:12:14 +02:00
RD="$TMP/rd.gz"
curl -r 64493568-69886247 -s -k -o "$RD" https://global.synologydownload.com/download/DSM/release/7.0.1/42218/DSM_VirtualDSM_42218.pat
2023-04-02 08:28:31 +02:00
2023-04-15 01:40:43 +02:00
SUM=$(md5sum $RD | cut -f 1 -d " ")
2023-04-15 01:33:56 +02:00
if [ $SUM != "14fb88cb7cabddb5af1d0269bf032845" ]; then
echo "Invalid extractor, checksum failed." && exit 59
fi
2023-04-02 08:28:31 +02:00
set +e
2023-04-14 16:12:14 +02:00
xz -dc <$RD >$TMP/rd 2>/dev/null
2023-04-02 08:28:31 +02:00
(cd $TMP && cpio -idm <$TMP/rd 2>/dev/null)
set -e
mkdir -p /run/extract
for file in $TMP/usr/lib/libcurl.so.4 $TMP/usr/lib/libmbedcrypto.so.5 $TMP/usr/lib/libmbedtls.so.13 $TMP/usr/lib/libmbedx509.so.1 $TMP/usr/lib/libmsgpackc.so.2 $TMP/usr/lib/libsodium.so $TMP/usr/lib/libsynocodesign-ng-virtual-junior-wins.so.7 $TMP/usr/syno/bin/scemd; do
2023-04-02 08:31:10 +02:00
cp "$file" /run/extract/
2023-04-02 08:28:31 +02:00
done
mv /run/extract/scemd /run/extract/syno_extract_system_patch
chmod +x /run/extract/syno_extract_system_patch
2023-04-14 16:12:14 +02:00
rm -rf $TMP && mkdir -p $TMP
2023-03-28 07:24:17 +02:00
2023-04-15 00:38:24 +02:00
echo "Install: Downloading $(basename $URL)..."
2023-04-15 00:50:53 +02:00
PAT="/$BASE.pat"
rm -f "$PAT"
# Check if running with interactive TTY or redirected to docker log
if [ -t 1 ]; then
2023-04-15 00:50:53 +02:00
wget "$URL" -O $PAT -q --no-check-certificate --show-progress
else
2023-04-15 00:50:53 +02:00
wget "$URL" -O $PAT -q --no-check-certificate --show-progress --progress=dot:giga
fi
2023-03-28 07:24:17 +02:00
2023-04-15 00:50:53 +02:00
[ ! -f "$PAT" ] && echo "Download failed" && exit 61
2023-03-28 22:00:23 +02:00
2023-04-14 16:12:14 +02:00
SIZE=$(stat -c%s "$PAT")
2023-03-28 22:00:23 +02:00
2023-03-30 03:23:54 +02:00
if ((SIZE<250000000)); then
echo "Invalid PAT file: File is an update pack which contains no OS image." && exit 62
fi
2023-03-28 22:00:23 +02:00
2023-04-15 01:33:56 +02:00
echo "Install: Extracting downloaded image..."
2023-03-28 07:24:17 +02:00
2023-04-14 16:12:14 +02:00
if { tar tf "$PAT"; } >/dev/null 2>&1; then
tar xpf $PAT -C $TMP/.
2023-03-30 03:23:54 +02:00
else
export LD_LIBRARY_PATH="/run/extract"
2023-04-14 16:12:14 +02:00
if ! /run/extract/syno_extract_system_patch $PAT $TMP/. ; then
2023-03-30 03:23:54 +02:00
echo "Invalid PAT file: File is an update pack which contains no OS image." && exit 63
fi
export LD_LIBRARY_PATH=""
fi
2023-03-28 07:24:17 +02:00
2023-03-30 03:23:54 +02:00
HDA="$TMP/hda1"
IDB="$TMP/indexdb"
PKG="$TMP/packages"
2023-03-30 03:23:54 +02:00
HDP="$TMP/synohdpack_img"
2023-03-28 22:00:23 +02:00
2023-04-15 00:50:53 +02:00
[ ! -f "$HDA.tgz" ] && echo "Invalid PAT file: contains no OS image." && exit 64
[ ! -f "$HDP.txz" ] && echo "Invalid PAT file: contains no HD pack." && exit 65
[ ! -f "$IDB.txz" ] && echo "Invalid PAT file: contains no IndexDB." && exit 66
[ ! -d "$PKG" ] && echo "Invalid PAT file: contains no packages." && exit 68
2023-03-28 22:00:23 +02:00
2023-03-30 03:23:54 +02:00
BOOT=$(find $TMP -name "*.bin.zip")
2023-03-28 22:00:23 +02:00
2023-04-15 00:50:53 +02:00
[ ! -f "$BOOT" ] && echo "Invalid PAT file: contains no boot file." && exit 67
2023-03-28 22:00:23 +02:00
2023-03-30 20:21:33 +02:00
BOOT=$(echo "$BOOT" | head -c -5)
unzip -q -o "$BOOT".zip -d $TMP
2023-03-28 07:24:17 +02:00
2023-04-15 00:38:24 +02:00
echo "Install: Creating partition table..."
2023-03-28 07:24:17 +02:00
2023-04-15 00:38:24 +02:00
SYSTEM="$TMP/sys.img"
2023-04-15 01:33:56 +02:00
SYSTEM_SIZE="4954537983"
2023-04-15 02:15:18 +02:00
2023-04-15 04:02:07 +02:00
# Check free diskspace
SPACE=$(df --output=avail -B 1 "$TMP" | tail -n 1)
if (( SYSTEM_SIZE > SPACE )); then
echo "ERROR: Not enough free space to create virtual system disk." && exit 87
fi
2023-04-15 02:15:18 +02:00
if ! fallocate -l "${SYSTEM_SIZE}" "${SYSTEM}"; then
rm -f "${SYSTEM}"
2023-04-15 04:02:07 +02:00
echo "ERROR: Could not allocate file for virtual system disk." && exit 88
2023-04-15 02:15:18 +02:00
fi
2023-03-28 07:24:17 +02:00
2023-04-15 00:38:24 +02:00
PART="$TMP/partition.fdisk"
2023-03-28 07:24:17 +02:00
2023-04-15 00:38:24 +02:00
{ echo "label: dos"
echo "label-id: 0x6f9ee2e9"
echo "device: ${SYSTEM}"
echo "unit: sectors"
echo "sector-size: 512"
echo ""
echo "${SYSTEM}1 : start= 2048, size= 4980480, type=83"
echo "${SYSTEM}2 : start= 4982528, size= 4194304, type=82"
} > $PART
2023-04-15 00:38:24 +02:00
sfdisk -q $SYSTEM < $PART
2023-04-15 00:38:24 +02:00
echo "Install: Extracting system partition..."
2023-03-28 07:24:17 +02:00
2023-04-15 00:38:24 +02:00
MOUNT="$TMP/system"
2023-03-28 07:24:17 +02:00
2023-04-15 00:38:24 +02:00
rm -rf $MOUNT && mkdir -p $MOUNT
2023-03-28 07:24:17 +02:00
mv -f $HDA.tgz $HDA.txz
2023-04-01 18:43:53 +02:00
2023-03-30 03:23:54 +02:00
tar xpfJ $HDP.txz --absolute-names -C $MOUNT/
tar xpfJ $HDA.txz --absolute-names -C $MOUNT/
tar xpfJ $IDB.txz --absolute-names -C $MOUNT/usr/syno/synoman/indexdb/
2023-03-28 22:00:23 +02:00
2023-04-15 00:38:24 +02:00
# Install Agent
2023-04-14 16:23:48 +02:00
LOC="$MOUNT/usr/local"
mkdir -p $LOC
mv $PKG/ $LOC/
2023-04-01 18:43:53 +02:00
LOC="$MOUNT/usr/local/bin"
mkdir -p $LOC
2023-04-10 02:01:50 +02:00
cp /agent/agent.sh $LOC/agent.sh
2023-04-01 18:43:53 +02:00
chmod +x $LOC/agent.sh
LOC="$MOUNT/usr/local/etc/rc.d"
mkdir -p $LOC
2023-04-10 02:01:50 +02:00
cp /agent/service.sh $LOC/agent.sh
2023-04-01 18:43:53 +02:00
chmod +x $LOC/agent.sh
2023-04-11 06:00:36 +02:00
# Store agent version
2023-04-14 17:08:55 +02:00
echo "2" > "$IMG"/"$BASE".agent
2023-04-11 06:00:36 +02:00
2023-04-15 00:38:24 +02:00
echo "Install: Installing system partition..."
2023-04-15 00:38:24 +02:00
LABEL="1.44.1-42218"
OFFSET="1048576" # 2048 * 512
NUMBLOCKS="622560" # (4980480 * 512) / 4096
2023-04-15 00:38:24 +02:00
mke2fs -q -t ext4 -b 4096 -d $MOUNT/ -L $LABEL -F -E offset=$OFFSET $SYSTEM $NUMBLOCKS
2023-03-30 03:23:54 +02:00
rm -rf $MOUNT
2023-03-28 07:24:17 +02:00
2023-04-14 16:23:48 +02:00
echo "$BASE" > "$IMG"/dsm.ver
2023-04-14 16:12:14 +02:00
mv -f "$PAT" "$IMG"/"$BASE".pat
2023-04-02 08:56:20 +02:00
mv -f "$BOOT" "$IMG"/"$BASE".boot.img
mv -f "$SYSTEM" "$IMG"/"$BASE".system.img
2023-03-28 07:24:17 +02:00
2023-03-30 03:23:54 +02:00
rm -rf $TMP