Compare commits

..

93 Commits

Author SHA1 Message Date
4ad44c6236 README.md aktualisiert 2023-08-29 19:37:48 +02:00
c2f12e4973 Dockerfile aktualisiert 2023-08-29 19:24:00 +02:00
5bb0fd1b97 scripts/start-server.sh aktualisiert 2023-08-29 19:23:38 +02:00
795dd23ff6 scripts/start-server.sh aktualisiert 2023-08-29 19:10:07 +02:00
06a69209e6 scripts/start.sh aktualisiert 2023-08-29 19:05:24 +02:00
3dc0a90fe0 scripts/start-watchdog.sh hinzugefügt 2023-08-29 19:05:09 +02:00
4b6613b811 scripts/start-server.sh aktualisiert 2023-08-29 19:04:24 +02:00
1ad09f8f97 scripts/start-Xvfb.sh hinzugefügt 2023-08-29 17:56:45 +02:00
22f77bcd6a Dockerfile aktualisiert 2023-08-29 17:55:18 +02:00
53f2c85cc3 Dockerfile aktualisiert 2023-08-29 17:04:59 +02:00
1f180eba29 scripts/start.sh aktualisiert 2023-08-29 16:52:33 +02:00
341fe7ab26 Dockerfile aktualisiert 2023-08-29 16:51:21 +02:00
8452d04cd3 Dockerfile aktualisiert 2023-08-29 14:31:29 +02:00
8420cc945a Dockerfile aktualisiert 2023-08-29 14:30:58 +02:00
73f5b651d7 Dockerfile aktualisiert 2023-08-29 14:28:51 +02:00
c695153cb8 Dockerfile aktualisiert 2023-08-29 14:11:37 +02:00
a0952e7858 Dockerfile aktualisiert 2023-08-29 14:09:17 +02:00
29d9a371be Dockerfile aktualisiert 2023-08-28 20:38:31 +02:00
7472226716 Dockerfile aktualisiert 2023-08-28 20:34:31 +02:00
92014b7df1 scripts/start-server.sh aktualisiert 2023-08-28 20:32:06 +02:00
d5ab33a6da scripts/start-server.sh aktualisiert 2023-08-27 18:16:12 +02:00
2066dd1372 README.md aktualisiert 2023-08-27 18:11:08 +02:00
ede2475c59 Dockerfile aktualisiert 2023-08-27 17:59:01 +02:00
77c56e7ddc scripts/start-server.sh aktualisiert 2023-08-27 17:58:05 +02:00
a5fa9fa20b config/ServerSettings.ini gelöscht 2023-08-27 17:57:25 +02:00
f11eaf0015 config/Engine.ini gelöscht 2023-08-27 17:57:22 +02:00
11071e951e Dateien nach "config" hochladen 2023-08-27 17:57:18 +02:00
fa186d191d scripts/start-server.sh aktualisiert 2023-08-27 17:56:25 +02:00
8f93ce03cb scripts/start.sh aktualisiert 2023-08-27 17:53:32 +02:00
454730e8dc Dockerfile aktualisiert 2023-08-27 17:51:57 +02:00
8cda691904 scripts/start-server.sh aktualisiert 2023-08-27 17:14:57 +02:00
6b69441ce5 „scripts/start.sh“ ändern 2022-10-25 11:02:35 +02:00
2562d194f5 „Dockerfile“ ändern 2022-05-06 10:16:46 +02:00
7265410450 „Dockerfile“ ändern 2022-04-25 12:37:07 +02:00
6391c97177 „scripts/start.sh“ ändern 2022-04-18 10:43:02 +02:00
c46277eacf „scripts/start.sh“ ändern 2022-04-07 17:20:00 +02:00
e30084bb15 „README.md“ ändern 2022-01-10 14:14:46 +01:00
02e471d02d „README.md“ ändern 2022-01-10 14:12:04 +01:00
ec253bc1dd „scripts/start-server.sh“ ändern 2022-01-10 14:02:07 +01:00
3578a738a3 „scripts/start.sh“ ändern 2022-01-10 14:01:30 +01:00
cb2ccad743 „Dockerfile“ ändern 2022-01-10 13:54:34 +01:00
b87b184d2b added termination handler 2020-06-12 14:43:23 +02:00
ae0d4cfa5e „scripts/start-server.sh“ ändern 2020-06-12 14:40:42 +02:00
949344ffce „scripts/start.sh“ ändern 2020-04-28 17:05:04 +02:00
17426d6d06 „.drone.yml“ löschen 2020-03-08 20:53:05 +01:00
3eeaa9dbae „.drone.yml“ hinzufügen
All checks were successful
continuous-integration/drone/push Build is passing
2020-03-05 20:30:50 +01:00
c940174895 „scripts/start-server.sh“ ändern 2020-02-25 14:48:45 +01:00
fda697da39 „scripts/start.sh“ hinzufügen 2020-02-25 14:48:29 +01:00
b31652b3a0 „Dockerfile“ ändern 2020-02-25 14:18:59 +01:00
defbab638b „scripts/start-server.sh“ ändern 2020-01-29 08:47:38 +01:00
4adf363774 „Dockerfile“ ändern 2019-12-29 15:24:32 +01:00
6122efa919 switched to debian 2019-12-29 15:18:41 +01:00
3cb1b2316a „scripts/start-server.sh“ ändern 2019-12-29 15:18:13 +01:00
bdb8af76a9 „Dockerfile“ ändern 2019-12-29 14:56:47 +01:00
5be4644a99 „scripts/start-server.sh“ ändern 2019-12-19 17:57:14 +01:00
7b89a10aed „scripts/start-server.sh“ ändern 2019-12-19 16:59:18 +01:00
502950a082 „scripts/start-server.sh“ ändern 2019-12-18 17:57:02 +01:00
c9ace2e467 Dateien hochladen nach „config“ 2019-12-18 17:49:48 +01:00
327a799379 „scripts/start-server.sh“ ändern 2019-12-18 16:38:25 +01:00
f703e6d0f4 „Dockerfile“ ändern 2019-12-18 16:37:46 +01:00
e9a9a4bd80 „Dockerfile“ ändern 2019-12-18 15:35:15 +01:00
cc13e95675 „Dockerfile“ ändern 2019-12-18 15:08:58 +01:00
1d98a05322 „Dockerfile“ ändern 2019-12-18 14:04:52 +01:00
413056a031 „scripts/start-server.sh“ ändern 2019-12-16 21:37:25 +01:00
82f2c4d9ad „Dockerfile“ ändern 2019-12-16 17:42:29 +01:00
b84a7d2997 „Dockerfile“ ändern 2019-12-16 16:33:47 +01:00
45bb4ee3df „Dockerfile“ ändern 2019-12-15 20:33:25 +01:00
1e9bedbdfe „scripts/start-server.sh“ ändern 2019-12-13 13:54:02 +01:00
08f376a341 „Dockerfile“ ändern 2019-12-13 13:48:48 +01:00
30ce73c0a0 „Dockerfile“ ändern 2019-12-13 13:42:56 +01:00
4d64fe3d3f „Dockerfile“ ändern 2019-12-13 13:42:38 +01:00
628d654703 „Dockerfile“ ändern 2019-12-13 12:52:02 +01:00
ddfd6313fa „Dockerfile“ ändern 2019-12-13 12:38:35 +01:00
c9e15ddb1c „scripts/start-server.sh“ ändern 2019-12-13 10:21:33 +01:00
6900edf57f „scripts/start-server.sh“ ändern 2019-12-13 10:19:12 +01:00
58d25411d5 „Dockerfile“ ändern 2019-12-13 08:21:58 +01:00
567da1bd10 „scripts/start-server.sh“ ändern 2019-12-13 08:21:08 +01:00
00f3c453af „scripts/start-server.sh“ ändern 2019-12-13 08:15:49 +01:00
8d89ec077e „Dockerfile“ ändern 2019-12-13 07:52:29 +01:00
bf873f21f3 „scripts/start-server.sh“ ändern 2019-11-11 11:14:38 +01:00
3d7e698bc5 „scripts/start-server.sh“ ändern 2019-11-11 09:07:00 +01:00
a29620dd5a „scripts/start-server.sh“ ändern 2019-11-11 09:02:46 +01:00
8f13b8850d „Dockerfile“ ändern 2019-11-11 09:02:20 +01:00
7d0b2023cc „scripts/start-server.sh“ ändern 2019-06-12 22:36:54 +02:00
a9333a0352 „scripts/start-server.sh“ ändern 2019-05-21 11:57:20 +02:00
f3b120f82d „scripts/start-server.sh“ ändern 2019-05-20 22:58:31 +02:00
b380bc7f24 Update start-server.sh 2019-04-29 17:32:41 +02:00
c463e82651 Update start-server.sh 2019-04-29 13:20:07 +02:00
1c1fbc6826 Update Dockerfile 2019-04-29 12:54:18 +02:00
36be851863 Update start-server.sh 2019-04-29 12:23:48 +02:00
1cb61cf7ec Update Dockerfile 2019-04-29 12:23:07 +02:00
adc4ac4616 Update start-server.sh 2019-04-24 13:01:42 +02:00
c96b1c14b8 Update start-server.sh 2019-04-24 12:15:54 +02:00
9 changed files with 129 additions and 277 deletions

1
.github/FUNDING.yml vendored
View File

@@ -1 +0,0 @@
github: ich777

View File

@@ -1,19 +1,18 @@
FROM ich777/debian-baseimage:bullseye_amd64
FROM ich777/winehq-baseimage
LABEL org.opencontainers.image.authors="admin@minenet.at"
LABEL org.opencontainers.image.source="https://github.com/ich777/docker-steamcmd-server"
RUN apt-get update && \
apt-get -y install --no-install-recommends lib32gcc-s1 lib32stdc++6 lib32z1 && \
RUN dpkg --add-architecture i386 && \
apt-get update && \
apt-get -y install lib32gcc-s1 screen xvfb winbind mariadb-server && \
rm -rf /var/lib/apt/lists/*
ENV DATA_DIR="/serverdata"
ENV STEAMCMD_DIR="${DATA_DIR}/steamcmd"
ENV SERVER_DIR="${DATA_DIR}/serverfiles"
ENV GAME_ID="template"
ENV GAME_NAME="template"
ENV GAME_PARAMS="template"
ENV GAME_PORT=27015
ENV GAME_PARAMS="-world 1"
ENV VALIDATE=""
ENV UMASK=000
ENV UID=99
@@ -28,10 +27,15 @@ RUN mkdir $DATA_DIR && \
mkdir $SERVER_DIR && \
useradd -d $DATA_DIR -s /bin/bash $USER && \
chown -R $USER $DATA_DIR && \
ulimit -n 2048
ulimit -n 2048 && \
/etc/init.d/mariadb start && \
mysql -u root -e "CREATE USER IF NOT EXISTS 'steam'@'%' IDENTIFIED BY 'lifyo';FLUSH PRIVILEGES;" && \
mysql -u root -e "GRANT ALL PRIVILEGES ON *.* TO 'steam'@'%' IDENTIFIED BY 'lifyo';" && \
mysql -u root -e "GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'LiFYO';FLUSH PRIVILEGES;" && \
echo "\n[mysqld]\ndatadir=/serverdata/serverfiles/.database/" >> /etc/alternatives/my.cnf
ADD /scripts/ /opt/scripts/
RUN chmod -R 770 /opt/scripts/
#Server Start
ENTRYPOINT ["/opt/scripts/start.sh"]
ENTRYPOINT ["/opt/scripts/start.sh"]

View File

@@ -1,40 +1,43 @@
# SteamCMD in Docker optimized for Unraid
This Docker will download and install SteamCMD and the according game that is pulled via specifying the Tag.
This Docker will download and install SteamCMD. It will also install Life is Feudal: Your Own and run it.
**Please see the different Tags/Branches which games are available.**
Initial server configuration:
**Servername:** LiF Docker **Password:** Docker **Admin Password:** adminDocker
## Example Env params for CS:Source
**ATTENTION:** First startup can take very long since it downloads the gameserver files and it also installs the runtimes which can take quite some time!
Update Notice: Simply restart the container if a newer version of the game is available.
## Env params
| Name | Value | Example |
| --- | --- | --- |
| STEAMCMD_DIR | Folder for SteamCMD | /serverdata/steamcmd |
| SERVER_DIR | Folder for gamefile | /serverdata/serverfiles |
| GAME_ID | The GAME_ID that the container downloads at startup. If you want to install a static or beta version of the game change the value to: '232330 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 232330 |
| GAME_NAME | SRCDS gamename | cstrike |
| GAME_PARAMS | Values to start the server | -secure +maxplayers 32 +map de_dust2 |
| GAME_PARAMS | Values to start the server if needed. | empty |
| GAME_ID | The GAME_ID that the container downloads at startup. If you want to install a static or beta version of the game change the value to: '320850 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 320850 |
| UID | User Identifier | 99 |
| GID | Group Identifier | 100 |
| GAME_PORT | Port the server will be running on | 27015 |
| VALIDATE | Validates the game data | blank |
| VALIDATE | Validates the game data | false |
| USERNAME | Leave blank for anonymous login | blank |
| PASSWRD | Leave blank for anonymous login | blank |
## Run example for CS:Source
## Run example
```
docker run --name CSSource -d \
-p 27015:27015 -p 27015:27015/udp \
--env 'GAME_ID=232330' \
--env 'GAME_NAME=cstrike' \
--env 'GAME_PORT=27015' \
--env 'GAME_PARAMS=-secure +maxplayers 32 +map de_dust2' \
docker run --name LifeIsFeudal-YourOwn -d \
-p 28000-28003 -p 28000-28003/udp \
--env 'GAME_ID=320850' \
--env 'UID=99' \
--env 'GID=100' \
--volume /path/to/steamcmd:/serverdata/steamcmd \
--volume /path/to/cstrikesource:/serverdata/serverfiles \
ich777/steamcmd:latest
--volume /path/to/lifeisfeudal-yo:/serverdata/serverfiles \
ich777/steamcmd:lifyo
```
This Docker was mainly edited for better use with Unraid, if you don't use Unraid you should definitely try it!
This Docker is forked from mattieserver, thank you for this wonderfull Docker.
#### Support Thread: https://forums.unraid.net/topic/79530-support-ich777-gameserver-dockers/
### Support Thread: https://forums.unraid.net/topic/79530-support-ich777-gameserver-dockers/

2
config/server_config.xml Normal file
View File

@@ -0,0 +1,2 @@
<?xml version="1.0" encoding="UTF-8"?>
<server_data port="25564" name="Stormworks Docker" save_name="autosave_server" max_players="32" password="Docker" day_night_length="60" sunrise="0.25" sunset="0.791" infinite_resources="false" unlock_all_islands="false" settings_menu="false" base_island="data/tiles/island12.xml" settings_menu_lock="false" infinite_batteries="false" infinite_fuel="false" engine_overheating="false" ceasefire="false" infinite_ammo="false" no_clip="false" map_teleport="false" vehicle_spawn="false" photo_mode="false" respawning="false" cleanup_vehicle="false" clear_fow="false" third_person="true" third_person_vehicle="true" vehicle_damage="false" player_damage="false" npc_damage="false" aggressive_animals="false" sea_monsters="false" lightning="true" teleport_vehicle="true" fast_travel="true" starting_currency="20000" despawn_on_leave="false" map_show_players="false" map_show_vehicles="false" show_3d_waypoints="false" show_name_plates="false" override_weather="false" override_time="false" override_wind="false" physics_timestep="0" wildlife_enabled="true" fish_spawn_rate="2" unlock_components="true" dlc_weapons="false" dlc_arid="false"/>

4
scripts/start-Xvfb.sh Normal file
View File

@@ -0,0 +1,4 @@
until Xvfb :99 -screen scrn 640x480x16; do
echo "Xvfb server crashed with exit code $?. Respawning.." >&2
sleep 1
done

View File

@@ -22,12 +22,14 @@ if [ "${USERNAME}" == "" ]; then
if [ "${VALIDATE}" == "true" ]; then
echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \
+@sSteamCmdForcePlatformType windows \
+force_install_dir ${SERVER_DIR} \
+login anonymous \
+app_update ${GAME_ID} validate \
+quit
else
${STEAMCMD_DIR}/steamcmd.sh \
+@sSteamCmdForcePlatformType windows \
+force_install_dir ${SERVER_DIR} \
+login anonymous \
+app_update ${GAME_ID} \
@@ -37,12 +39,14 @@ else
if [ "${VALIDATE}" == "true" ]; then
echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \
+@sSteamCmdForcePlatformType windows \
+force_install_dir ${SERVER_DIR} \
+login ${USERNAME} ${PASSWRD} \
+app_update ${GAME_ID} validate \
+quit
else
${STEAMCMD_DIR}/steamcmd.sh \
+@sSteamCmdForcePlatformType windows \
+force_install_dir ${SERVER_DIR} \
+login ${USERNAME} ${PASSWRD} \
+app_update ${GAME_ID} \
@@ -51,18 +55,79 @@ else
fi
echo "---Prepare Server---"
if [ ! -f ${DATA_DIR}/.steam/sdk32/steamclient.so ]; then
if [ ! -d ${DATA_DIR}/.steam ]; then
mkdir ${DATA_DIR}/.steam
fi
if [ ! -d ${DATA_DIR}/.steam/sdk32 ]; then
mkdir ${DATA_DIR}/.steam/sdk32
fi
cp -R ${STEAMCMD_DIR}/linux32/* ${DATA_DIR}/.steam/sdk32/
export WINEARCH=win64
export WINEPREFIX=/serverdata/serverfiles/WINE64
export DISPLAY=:99
echo "---Checking if WINE workdirectory is present---"
if [ ! -d ${SERVER_DIR}/WINE64 ]; then
echo "---WINE workdirectory not found, creating please wait...---"
mkdir ${SERVER_DIR}/WINE64
else
echo "---WINE workdirectory found---"
fi
echo "---Checking if WINE is properly installed---"
if [ ! -d ${SERVER_DIR}/WINE64/drive_c/windows ]; then
echo "---Setting up WINE---"
cd ${SERVER_DIR}
winecfg > /dev/null 2>&1
sleep 15
else
echo "---WINE properly set up---"
fi
echo "---Checking config---"
if grep -q "<name>My own LiF server</name>" ${SERVER_DIR}/config/world_1.xml ; then
echo "---Adding initial config parameters to config file---"
sed -i 's/\<My own LiF server\>/LiF Docker/g' ${SERVER_DIR}/config/world_1.xml
sed -i s/"<password><\/password>"/"<password>Docker<\/password>"/g ${SERVER_DIR}/config/world_1.xml
sed -i s/"<adminPassword><\/adminPassword>"/"<adminPassword>adminDocker<\/adminPassword>"/g ${SERVER_DIR}/config/world_1.xml
else
echo "---Config check done---"
fi
echo "---Checking if database is in place---"
if [ ! -d ${SERVER_DIR}/.database ]; then
echo "---Database not found, setting up databbase...---"
mkdir -p ${SERVER_DIR}/.database
cp -R /var/lib/mysql/* ${SERVER_DIR}/.database/
else
echo "---Database found---"
fi
echo "---Checking if database configuration is in place---"
if [ ! -f ${SERVER_DIR}/config_local.cs ]; then
echo "---Database configuration not found, configuring...---"
cp ${SERVER_DIR}/docs/config_local.cs ${SERVER_DIR}/config_local.cs
sed -i 's/\<root\>/steam/g' ${SERVER_DIR}/config_local.cs
sed -i 's/\<rootPassword\>/lifyo/g' ${SERVER_DIR}/config_local.cs
else
echo "---Database connection found---"
fi
echo "---Starting MariaDB---"
screen -S MariaDB -d -m mysqld_safe
sleep 2
echo "---Starting Xvfb---"
screen -S Xvfb -d -m /opt/scripts/start-Xvfb.sh
sleep 2
echo "---Checking for old display lock files---"
find /tmp -name ".X99*" -exec rm -f {} \; > /dev/null 2>&1
chmod -R ${DATA_PERM} ${DATA_DIR}
echo "---Server ready---"
echo "---Start Server---"
cd ${SERVER_DIR}
${SERVER_DIR}/srcds_run -game ${GAME_NAME} ${GAME_PARAMS} -console +port ${GAME_PORT}
if [ ! -f ${SERVER_DIR}/ddctd_cm_yo_server.exe ]; then
echo "---Something went wrong, can't find the executable, putting container into sleep mode!---"
sleep infinity
else
cd ${SERVER_DIR}
screen -S LiFYO -d -m wine64 ddctd_cm_yo_server.exe ${GAME_PARAMS}
echo "---Waiting for logs...---"
sleep 3
/opt/scripts/start-watchdog.sh &
cd ${SERVER_DIR}/logs
cd $(ls -1d */ | tail -1)
tail -n 9999 -f $(ls -t | head -n 1)
fi

View File

@@ -0,0 +1,8 @@
#!/bin/bash
killpid="$(pidof ddctd_cm_yo_server.exe)"
while true
do
tail --pid=$killpid -f /dev/null
kill "$(pidof tail)"
exit 0
done

View File

@@ -22,17 +22,16 @@ fi
echo "---Taking ownership of data...---"
chown -R root:${GID} /opt/scripts
chmod -R 750 /opt/scripts
chown -R ${UID}:${GID} /var/lib/mysql
chown -R ${UID}:${GID} /var/run/mysqld
chown -R ${UID}:${GID} ${DATA_DIR}
# Fix for CSDM not working properly
if [ -f "${SERVER_DIR}/cstrike/addons/sourcemod/gamedata/cssdm.games.txt" ]; then
chmod 550 ${SERVER_DIR}/cstrike/addons/sourcemod/gamedata/cssdm.games.txt
fi
chmod -R 770 /var/lib/mysql
chmod -R 770 /var/run/mysqld
echo "---Starting...---"
term_handler() {
kill -SIGTERM "$killpid"
wait "$killpid" -f 2>/dev/null
kill -SIGINT $(pidof ddctd_cm_yo_server.exe)
tail --pid=$(pidof ddctd_cm_yo_server.exe) -f 2>/dev/null
exit 143;
}
@@ -43,4 +42,4 @@ while true
do
wait $killpid
exit 0;
done
done

View File

@@ -1,232 +0,0 @@
#!/bin/bash
# The script will then add the container to your Tailscale network.
#
# For more information see: [Link TBD]
error_handler() {
echo
echo "======================="
exit 1
}
echo "======================="
echo
# Import variables from s6-overlay images
if [ -x "/usr/bin/with-contenv" ]; then
echo "just-containers s6-overlay image found, importing variables..."
ENV_VARS="$(/usr/bin/with-contenv bash -c 'env')"
while IFS='=' read -r KEY VALUE; do
export "${KEY}"="${VALUE}"
done <<< "${ENV_VARS}"
fi
if [[ ! -f /usr/bin/tailscale || ! -f /usr/bin/tailscaled ]]; then
if [ ! -z "${TAILSCALE_EXIT_NODE_IP}" ]; then
if [ ! -c /dev/net/tun ]; then
echo "ERROR: Device /dev/net/tun not found!"
echo " Make sure to pass through /dev/net/tun to the container."
error_handler
fi
APT_IPTABLES="iptables "
fi
echo "Detecting Package Manager..."
if which apt-get >/dev/null 2>&1; then
echo "Detected Advanced Package Tool!"
PACKAGES_UPDATE="apt-get update"
PACKAGES_INSTALL="apt-get -y install --no-install-recommends"
elif which apk >/dev/null 2>&1; then
echo "Detected Alpine Package Keeper!"
PACKAGES_UPDATE="apk update"
PACKAGES_INSTALL="apk add"
else
echo "ERROR: Detection failed!"
error_handler
fi
echo "Installing dependencies..."
echo "Please wait..."
${PACKAGES_UPDATE} >/dev/null 2>&1
${PACKAGES_INSTALL} jq wget ca-certificates ${APT_IPTABLES}>/dev/null 2>&1
echo "Done"
if [ "${APT_IPTABLES}" == "iptables " ]; then
if ! iptables -L >/dev/null 2>&1; then
echo "ERROR: Cap: NET_ADMIN not available!"
echo " Make sure to add --cap-add=NET_ADMIN to the Extra Parameters"
error_handler
fi
fi
echo "Tailscale not found, downloading..."
echo "Please wait..."
TAILSCALE_JSON=$(wget -qO- 'https://pkgs.tailscale.com/stable/?mode=json')
if [ -z "${TAILSCALE_JSON}" ]; then
echo "ERROR: Can't get Tailscale JSON"
error_handler
fi
TAILSCALE_TARBALL=$(echo "${TAILSCALE_JSON}" | jq -r .Tarballs.amd64)
TAILSCALE_VERSION=$(echo "${TAILSCALE_JSON}" | jq -r .TarballsVersion)
if [ ! -d /tmp/tailscale ]; then
mkdir -p /tmp/tailscale
fi
if wget -q -nc --show-progress --progress=bar:force:noscroll -O /tmp/tailscale/tailscale.tgz "https://pkgs.tailscale.com/stable/${TAILSCALE_TARBALL}" ; then
echo "Download from Tailscale version ${TAILSCALE_VERSION} successful!"
else
echo "ERROR: Download from Tailscale version ${TAILSCALE_VERSION} failed!"
rm -rf /tmp/tailscale
error_handler
fi
cd /tmp/tailscale
tar -xf /tmp/tailscale/tailscale.tgz
cp /tmp/tailscale/tailscale_${TAILSCALE_VERSION}_amd64/tailscale /usr/bin/tailscale
cp /tmp/tailscale/tailscale_${TAILSCALE_VERSION}_amd64/tailscaled /usr/bin/tailscaled
rm -rf /tmp/tailscale
echo "Done"
else
echo "Tailscale found, continuing..."
fi
unset TSD_PARAMS
unset TS_PARAMS
if [ ! -z "${TAILSCALE_STATE_DIR}" ]; then
TSD_STATE_DIR="${TAILSCALE_STATE_DIR}"
elif [ -v SERVER_DIR ]; then
TSD_STATE_DIR=${SERVER_DIR}/.tailscale_state
echo "Settings Tailscale state dir to: ${TSD_STATE_DIR}"
elif [ -v DATA_DIR ]; then
TSD_STATE_DIR=${DATA_DIR}/.tailscale_state
echo "Settings Tailscale state dir to: ${TSD_STATE_DIR}"
else
if [ -z "${TAILSCALE_STATE_DIR}" ]; then
TAILSCALE_STATE_DIR="/config/.tailscale_state"
fi
TSD_STATE_DIR=${TAILSCALE_STATE_DIR}
echo "Settings Tailscale state dir to: ${TSD_STATE_DIR}"
fi
if [ ! -d ${TS_STATE_DIR} ]; then
mkdir -p ${TS_STATE_DIR}
fi
if [ ! -z "${TAILSCALE_EXIT_NODE_IP}" ]; then
echo "Using ${TAILSCALE_EXIT_NODE_IP} as Exit Node! See https://tailscale.com/kb/1103/exit-nodes"
TS_PARAMS=" --exit-node=${TAILSCALE_EXIT_NODE_IP}"
if [ ! -z "${TAILSCALE_ALLOW_LAN_ACCESS}" ]; then
echo "Enabling local LAN Access to the container!"
TS_PARAMS+=" --exit-node-allow-lan-access"
fi
else
if [ -z "${TAILSCALE_USERSPACE_NETWORKING}" ] || [ "${TAILSCALE_USERSPACE_NETWORKING}" == "true" ]; then
TSD_PARAMS+="-tun=userspace-networking "
else
if [ ! -c /dev/net/tun ]; then
echo "ERROR: Device /dev/net/tun not found!"
echo " Make sure to pass through /dev/net/tun to the container and add the"
echo " parameter --cap-add=NET_ADMIN to the Extra Parameters!"
error_handler
fi
fi
fi
if [ "${TAILSCALE_USE_SSH}" == "true" ]; then
echo "Enabling SSH. See https://tailscale.com/kb/1193/tailscale-ssh"
TS_PARAMS+=" --ssh"
fi
if [ "${TAILSCALE_LOG}" != "false" ]; then
TSD_PARAMS+=">>/var/log/tailscaled 2>&1 "
TSD_MSG=" with log file /var/log/tailscaled"
else
TSD_PARAMS+=">/dev/null 2>&1 "
fi
if [[ ! -z "${TAILSCALE_AUTHKEY}" && -f ${TSD_STATE_DIR}/.initialized ]]; then
echo
echo "-> It is now save to remove the variable TAILSCALE_AUTHKEY from your template <-"
echo
unset TAILSCALE_AUTHKEY
fi
if [ ! -z "${TAILSCALE_AUTHKEY}" ]; then
TS_AUTH="--authkey=${TAILSCALE_AUTHKEY} "
fi
if [ ! -z "${TAILSCALE_HOSTNAME}" ]; then
echo "Setting host name to ${TAILSCALE_HOSTNAME}"
TS_PARAMS+=" --hostname=${TAILSCALE_HOSTNAME/ /}"
fi
if [ "${TAILSCALE_EXIT_NODE}" == "true" ]; then
echo "Configuring container as Exit Node! See https://tailscale.com/kb/1103/exit-nodes"
TS_PARAMS+=" --advertise-exit-node"
fi
if [ ! -z "${TAILSCALED_PARAMS}" ]; then
TSD_PARAMS="${TAILSCALED_PARAMS} ${TSD_PARAMS}"
fi
if [ ! -z "${TAILSCALE_PARAMS}" ]; then
TS_PARAMS="${TAILSCALE_PARAMS}${TS_PARAMS}"
fi
echo "Starting tailscaled${TSD_MSG}"
eval tailscaled -statedir=${TSD_STATE_DIR} ${TSD_PARAMS}&
echo "Starting tailscale"
eval tailscale up ${TS_AUTH}${TS_PARAMS}
EXIT_STATUS="$?"
if [ "${EXIT_STATUS}" == "0" ]; then
echo "Connecting to Tailscale successful!"
if [ ! -f ${TSD_STATE_DIR}/.initialized ]; then
echo "Please don't remove this file!" > ${TSD_STATE_DIR}/.initialized
fi
else
echo "ERROR: Connecting to Tailscale not successful!"
if [ -f /var/log/tailscaled ]; then
echo "Please check the logs:"
tail -20 /var/log/tailscaled
echo "======================="
fi
error_handler
fi
if [[ ! -z "${TAILSCALE_SERVE_PORT}" && "$(tailscale status --json | jq -r '.CurrentTailnet.MagicDNSEnabled')" == "false" ]] ; then
echo "ERROR: Enable HTTPS on your Tailscale account to use Tailscale Serve/Funnel."
echo "See: https://tailscale.com/kb/1153/enabling-https"
error_handler
fi
if [ ! -z ${TAILSCALE_SERVE_PORT} ]; then
if [ ! -z "${TAILSCALE_SERVE_PATH}" ]; then
TAILSCALE_SERVE_PATH="=${TAILSCALE_SERVE_PATH}"
fi
if [ -z "${TAILSCALE_SERVE_MODE}" ]; then
TAILSCALE_SERVE_MODE="https"
fi
if [ -z "${TAILSCALE_SERVE_PROTOCOL_PORT}" ]; then
TAILSCALE_SERVE_PROTOCOL_PORT="=443"
fi
if [ "${TAILSCALE_FUNNEL}" == "true" ]; then
echo "Enabling Funnel! See https://tailscale.com/kb/1223/funnel"
eval tailscale funnel --bg --"${TAILSCALE_SERVE_MODE}"${TAILSCALE_SERVE_PROTOCOL_PORT}${TAILSCALE_SERVE_PATH} http://localhost:"${TAILSCALE_SERVE_PORT}${TAILSCALE_SERVER_LOCALPATH}"
else
echo "Enabling Serve! See https://tailscale.com/kb/1312/serve"
eval tailscale serve --bg --"${TAILSCALE_SERVE_MODE}"${TAILSCALE_SERVE_PROTOCOL_PORT}${TAILSCALE_SERVE_PATH} http://localhost:"${TAILSCALE_SERVE_PORT}${TAILSCALE_SERVER_LOCALPATH}"
fi
fi
echo
echo "======================="