EvilFreelancer.docker-routeros/scripts/entrypoint.sh

78 lines
2.4 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
2025-02-03 18:49:25 -05:00
if [[ ! -e "/routeros/generate-dhcpd-conf.py" ]]; then
cp -r /routeros_source/. /routeros
fi
2025-02-03 19:10:28 -05:00
cd /routeros
QEMU_BRIDGE_ETH1='qemubr1'
default_dev1='eth0'
# DHCPD must have an IP address to run, but that address doesn't have to
# be valid. This is the dummy address dhcpd is configured to use.
DUMMY_DHCPD_IP='10.0.0.1'
# These scripts configure/deconfigure the VM interface on the bridge.
QEMU_IFUP='/routeros/qemu-ifup'
QEMU_IFDOWN='/routeros/qemu-ifdown'
# The name of the dhcpd config file we make
DHCPD_CONF_FILE='/routeros/dhcpd.conf'
# First step, we run the things that need to happen before we start mucking
# with the interfaces. We start by generating the DHCPD config file based
# on our current address/routes. We "steal" the container's IP, and lease
# it to the VM once it starts up.
/routeros/generate-dhcpd-conf.py $QEMU_BRIDGE_ETH1 >$DHCPD_CONF_FILE
function prepare_intf() {
#First we clear out the IP address and route
ip addr flush dev $1
# Next, we create our bridge, and add our container interface to it.
ip link add $2 type bridge
ip link set dev $1 master $2
# Then, we toggle the interface and the bridge to make sure everything is up
# and running.
ip link set dev $1 up
ip link set dev $2 up
}
prepare_intf $default_dev1 $QEMU_BRIDGE_ETH1
# Finally, start our DHCPD server
udhcpd -I $DUMMY_DHCPD_IP -f $DHCPD_CONF_FILE &
2024-02-03 21:34:25 -07:00
CPU_FEATURES=""
KVM_OPTS=""
if [ -e /dev/kvm ]; then
if grep -q -e vmx -e svm /proc/cpuinfo; then
echo "Enabling KVM"
CPU_FEATURES=",kvm=on"
KVM_OPTS="-machine accel=kvm -enable-kvm"
fi
fi
if [ "$CPU_FEATURES" = "" ]; then
echo "KVM not available, running in emulation mode. This will be slow."
fi
# And run the VM! A brief explanation of the options here:
# -enable-kvm: Use KVM for this VM (much faster for our case).
# -nographic: disable SDL graphics.
# -serial mon:stdio: use "monitored stdio" as our serial output.
# -nic: Use a TAP interface with our custom up/down scripts.
# -drive: The VM image we're booting.
# mac: Set up your own interfaces mac addresses here, cause from winbox you can not change these later.
exec qemu-system-x86_64 \
2024-02-03 21:34:25 -07:00
-serial mon:stdio \
-nographic \
-m 512 \
-smp 4,sockets=1,cores=4,threads=1 \
2024-02-03 21:34:25 -07:00
-cpu host$CPU_FEATURES \
$KVM_OPTS \
-nic tap,id=qemu1,mac=54:05:AB:CD:12:31,script=$QEMU_IFUP,downscript=$QEMU_IFDOWN \
"$@" \
-hda $ROUTEROS_IMAGE