xref: /aosp_15_r20/external/toybox/mkroot/packages/dropbear (revision cf5a6c84e2b8763fc1a7db14496fd4742913b199)
1#!/bin/echo Try "mkroot/mkroot.sh dropbear"
2
3# Example overlay file, adding dropbear (which requires zlib)
4
5echo === download source
6
7download e6d119755acdf9104d7ba236b1242696940ed6dd \
8  http://downloads.sf.net/libpng/zlib-1.2.11.tar.gz
9
10download 9719ea91b5ce8d93ee9a50b5c3a5bcd628736181 \
11  https://matt.ucc.asn.au/dropbear/releases/dropbear-2022.82.tar.bz2
12
13echo === Native build static zlib
14
15setupfor zlib
16# They keep checking in broken generated files.
17rm -f Makefile zconf.h &&
18CC=${CROSS_COMPILE}cc LD=${CROSS_COMPILE}ld AS=${CROSS_COMPILE}as ./configure &&
19make -j $(nproc) || exit 1
20
21# do _not_ cleanup zlib, we need the files we just built for dropbear
22
23echo === $HOST Native build static dropbear
24
25setupfor dropbear
26# Repeat after me: "autoconf is useless"
27echo 'echo "$@"' > config.sub &&
28ZLIB="$(echo ../zlib*)" &&
29CC="$CROSS_COMPILE"cc CFLAGS="-I $ZLIB -O2" LDFLAGS="-L $ZLIB" ./configure --enable-static \
30  --disable-wtmp --host="$(basename "$CROSS_COMPILE" | sed 's/-$//')" &&
31sed -i 's@/usr/bin/dbclient@ssh@' options.h &&
32sed -i 's@\(#define NON_INETD_MODE\) 1@\1 0@' default_options.h &&
33make -j $(nproc) PROGRAMS="dropbear dbclient dropbearkey dropbearconvert scp" MULTI=1 SCPPROGRESS=1 &&
34${CROSS_COMPILE}strip dropbearmulti &&
35mkdir -p "$ROOT"/{bin,etc/{rc,dropbear},var/log} &&
36touch "$ROOT"/var/log/lastlog &&
37cp dropbearmulti "$ROOT"/bin || exit 1
38for i in "$ROOT"/bin/{ssh,dropbear,scp,dropbearkey}
39do
40  ln -s dropbearmulti $i || exit 1
41done
42# We didn't cleanup zlib
43unset ZLIB
44rm -rf ../zlib-*
45# cleanup dropbear
46cleanup
47
48# user root password root, user guest no password
49echo -e 'root:$1$939UTPzb$/PfVYAsF2Hqi/AQ3UBjbK/:::::::\nguest::::::::' > "$ROOT"/etc/shadow &&
50chmod 600 "$ROOT"/etc/shadow &&
51
52echo 'netcat -p 22 -L dropbear -iRB &' > "$ROOT"/etc/rc/dropbear &&
53
54# file to run on host to ssh into guest
55echo 'ssh -o "UserKnownHostsFile=/dev/null" -o "StrictHostKeyChecking=no" ${1:+$1@}127.0.0.1 -p 2222' > "$OUTPUT"/ssh2dropbear.sh &&
56chmod +x "$OUTPUT"/ssh2dropbear.sh
57
58# Forward 127.0.0.1:2222 into qemu instance
59QEMU_MORE+=" -nic user,hostfwd=tcp:127.0.0.1:2222-:22"
60