Compare commits

..

36 Commits

Author SHA1 Message Date
6ca8699e05 Dockerfile aktualisiert 2023-12-26 22:55:34 +01:00
6f3534835d Dockerfile aktualisiert 2023-12-26 22:54:26 +01:00
e97b3f56f2 Update Dockerfile 2023-06-13 09:18:39 +02:00
7c6e1bfead „scripts/start.sh“ ändern 2022-10-25 11:10:15 +02:00
20b5e10b7b „Dockerfile“ ändern 2022-05-06 10:56:57 +02:00
e4baec135e „scripts/start-server.sh“ ändern 2022-04-18 14:34:33 +02:00
050a9ec9a0 „scripts/start.sh“ ändern 2022-04-18 14:34:13 +02:00
89d35469e6 „Dockerfile“ ändern 2022-04-18 14:33:57 +02:00
cfc425ce49 „.drone.yml“ löschen 2022-04-18 14:33:48 +02:00
63c55f7325 „README.md“ ändern 2022-04-18 14:33:37 +02:00
b832477e5e „scripts/start.sh“ ändern 2020-04-28 17:00:45 +02:00
467c4a4603 „.drone.yml“ hinzufügen
All checks were successful
continuous-integration/drone/push Build is passing
2020-03-05 20:16:53 +01:00
1fa27f9500 „scripts/start.sh“ hinzufügen 2020-02-25 14:34:29 +01:00
c40f1ef582 „scripts/start-server.sh“ ändern 2020-02-25 14:34:20 +01:00
2d1c9172ca „Dockerfile“ ändern 2020-02-25 14:29:55 +01:00
3d04b1a04c „Dockerfile“ ändern 2020-01-05 16:03:31 +01:00
dff488865c „scripts/start-server.sh“ ändern 2020-01-05 16:00:50 +01:00
a44fd45f22 „Dockerfile“ ändern 2020-01-05 16:00:21 +01:00
ae2a174e1b „Dockerfile“ ändern 2019-12-22 22:15:22 +01:00
6f35f4f445 „scripts/start-server.sh“ ändern 2019-12-22 21:56:24 +01:00
31bfef7afc Dateien hochladen nach „config“ 2019-12-22 21:52:13 +01:00
9c70b2c68f „Dockerfile“ ändern 2019-12-22 21:52:02 +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
7 changed files with 207 additions and 264 deletions

1
.github/FUNDING.yml vendored
View File

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

View File

@@ -3,8 +3,9 @@ FROM ich777/debian-baseimage:bullseye_amd64
LABEL org.opencontainers.image.authors="admin@minenet.at" LABEL org.opencontainers.image.authors="admin@minenet.at"
LABEL org.opencontainers.image.source="https://github.com/ich777/docker-steamcmd-server" LABEL org.opencontainers.image.source="https://github.com/ich777/docker-steamcmd-server"
RUN apt-get update && \ RUN dpkg --add-architecture i386 && \
apt-get -y install --no-install-recommends lib32gcc-s1 lib32stdc++6 lib32z1 && \ apt-get update && \
apt-get -y install --no-install-recommends lib32gcc-s1 libssl1.1:i386 libstdc++6:i386 zlib1g:i386 libxrandr2:i386 libxi6:i386 && \
rm -rf /var/lib/apt/lists/* rm -rf /var/lib/apt/lists/*
ENV DATA_DIR="/serverdata" ENV DATA_DIR="/serverdata"
@@ -34,4 +35,4 @@ ADD /scripts/ /opt/scripts/
RUN chmod -R 770 /opt/scripts/ RUN chmod -R 770 /opt/scripts/
#Server Start #Server Start
ENTRYPOINT ["/opt/scripts/start.sh"] ENTRYPOINT ["/opt/scripts/start.sh"]

View File

@@ -1,40 +1,36 @@
# SteamCMD in Docker optimized for Unraid # 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 Sven CO-OP and run it.
**Please see the different Tags/Branches which games are available.** **Update Notice:** Simply restart the container if a newer version of the game is available.
## Example Env params for CS:Source ## Env params
| Name | Value | Example | | Name | Value | Example |
| --- | --- | --- | | --- | --- | --- |
| STEAMCMD_DIR | Folder for SteamCMD | /serverdata/steamcmd | | STEAMCMD_DIR | Folder for SteamCMD | /serverdata/steamcmd |
| SERVER_DIR | Folder for gamefile | /serverdata/serverfiles | | 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_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: '276060 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 276060 |
| GAME_NAME | SRCDS gamename | cstrike | | GAME_PARAMS | Values to start the server | +maxplayers 20 +map hl_c00.bsp +servercfgfile servers/server.cfg |
| GAME_PARAMS | Values to start the server | -secure +maxplayers 32 +map de_dust2 |
| UID | User Identifier | 99 | | UID | User Identifier | 99 |
| GID | Group Identifier | 100 | | 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 | blank |
| USERNAME | Leave blank for anonymous login | blank | | USERNAME | Leave blank for anonymous login | blank |
| PASSWRD | 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 \ docker run --name SvenCOOP -d \
-p 27015:27015 -p 27015:27015/udp \ -p 27015:27015 -p 27015:27015/udp \
--env 'GAME_ID=232330' \ --env 'GAME_ID=276060' \
--env 'GAME_NAME=cstrike' \ --env 'GAME_PARAMS=+maxplayers 20 +map hl_c00.bsp +servercfgfile servers/server.cfg' \
--env 'GAME_PORT=27015' \
--env 'GAME_PARAMS=-secure +maxplayers 32 +map de_dust2' \
--env 'UID=99' \ --env 'UID=99' \
--env 'GID=100' \ --env 'GID=100' \
--volume /path/to/steamcmd:/serverdata/steamcmd \ --volume /path/to/steamcmd:/serverdata/steamcmd \
--volume /path/to/cstrikesource:/serverdata/serverfiles \ --volume /path/to/svencoop:/serverdata/serverfiles \
ich777/steamcmd:latest ich777/steamcmd:svencoop
``` ```
This Docker was mainly edited for better use with Unraid, if you don't use Unraid you should definitely try it! 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. 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/

171
config/server.cfg Normal file
View File

@@ -0,0 +1,171 @@
// -----------------------------------------------------------------------------
// Anything you place in here will be shared among all servers you choose to
// include this in. To include this add this line to their "servercfgfile":
//
// exec "servers/server.cfg"
// -----------------------------------------------------------------------------
// Essentials
hostname "Docker Sven Co-op "
// Configuration files
servercfgfile "servers/server.cfg"
lservercfgfile "servers/listenserver.cfg"
mapvotecfgfile "servers/mapvote.cfg"
skillcfgfile "servers/skill.cfg"
bannedcfgfile "servers/banned.cfg"
listipcfgfile "servers/listip.cfg"
motdfile "servers/motd.txt"
mapcyclefile "servers/mapcycle.txt"
adminsfile "servers/admins.txt"
plugin_list_file "servers/default_plugins.txt"
logsdir "logs"
// Passwords
rcon_password "adminDocker"
sv_password "Docker"
sv_spectator_password ""
// Core variables
sys_ticrate 100
fps_max 100
developer 0
sv_region 255
sv_contact ""
sv_downloadurl ""
allow_spectators 1
deathmatch 1
decalfrequency 30
hpk_maxsize 10
pausable 0
skill 3
// Server variables
sv_accelerate 10
sv_aim 0
sv_airaccelerate 10
sv_allowdownload 1
sv_alltalk 1
sv_allowupload 1
sv_bounce 1
sv_challengetime 15
sv_cheats 0
sv_clienttrace 1
sv_clipmode 0
sv_enableoldqueries 0
sv_failuretime 0.5
sv_filetransfercompression 1
sv_filterban 1
sv_friction 4
sv_gravity 800
sv_instancedbaseline 1
sv_lagcompensation 5
sv_lan 0
sv_lan_rate 100000
sv_log_client_commands 0
sv_log_monster_damage 1
sv_log_monster_monster_kills 1
sv_log_onefile 0
sv_log_player_frequency 30
sv_log_singleplayer 0
sv_logbans 1
sv_logblocks 1
sv_logrelay 0
sv_maxrate 100000
sv_maxspectators 0
sv_maxspeed 270
sv_maxunlag 1
sv_maxupdaterate 50
sv_maxvelocity 2000
sv_minrate 4000
sv_minupdaterate 10
sv_newunit 0
sv_notransition 0
sv_outofdatetime 1800
sv_proxies 0
sv_rcon_banpenalty 0
sv_rcon_maxfailures 10
sv_rcon_minfailures 5
sv_rcon_minfailuretime 30
sv_send_logos 1
sv_send_resources 1
sv_sendvelocity 1
sv_spectatormaxspeed 600
sv_spectalk 1
sv_stats 1
sv_stepsize 18
sv_stopspeed 100
sv_timeout 90
sv_unlag 1
sv_unlagpush 0
sv_unlagsamples 2
sv_uploadmax 0.5
sv_voiceenable 1
sv_wateraccelerate 10
sv_wateramp 0
sv_waterfriction 1
sv_zmax 32768
// Multi-player variables
mp_allowmonsters 1
mp_autocrosshair 1
mp_consistency 1
mp_decals 2048
mp_disablegaussjump 0
mp_falldamage 1
mp_flashlight 1
mp_footsteps 1
mp_forcerespawn 0
mp_fraglimit 0
mp_friendlyfire 0
mp_logdetail 3
mp_logfile 1
mp_teamplay 1
mp_telefrag 1
mp_timelimit 60
mp_timelimit_empty 10
mp_weaponstay 1
// Sven Co-op variables
mp_allowmonsterinfo 1
mp_banana 1
mp_chattime 8
mp_disable_autoclimb 0
mp_disable_pcbalancing 0
mp_disable_player_rappel 0
mp_dropweapons 1
mp_grapple_mode 1
mp_multiplespawn 1
mp_no_akimbo_uzis 0
mp_noblastgibs 0
mp_npckill 2
mp_playervotedelay 300
mp_respawndelay 5
mp_voteallow 1
mp_votebanrequired 100
mp_votekickrequired 66
mp_votekill_respawndelay 15
mp_votekillrequired 51
mp_votemaprequired 66
mp_votetimebetween 60
mp_votetimecheck 20
// **********************
// Execute Configurations
// **********************
// Load ban lists
exec "servers/banned.cfg" // Ensure this matches your "bannedcfgfile" value.
exec "servers/listip.cfg" // Ensure this matches your "listipcfgfile" value.

View File

@@ -52,17 +52,30 @@ fi
echo "---Prepare Server---" echo "---Prepare Server---"
if [ ! -f ${DATA_DIR}/.steam/sdk32/steamclient.so ]; then 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 if [ ! -d ${DATA_DIR}/.steam/sdk32 ]; then
if [ ! -d ${DATA_DIR}/.steam ]; then
mkdir ${DATA_DIR}/.steam
fi
mkdir ${DATA_DIR}/.steam/sdk32 mkdir ${DATA_DIR}/.steam/sdk32
fi fi
cp -R ${STEAMCMD_DIR}/linux32/* ${DATA_DIR}/.steam/sdk32/ cp ${STEAMCMD_DIR}/linux32/steamclient.so ${DATA_DIR}/.steam/sdk32/steamclient.so
fi
echo "---Checking if server configuration file is present---"
if [ ! -f ${SERVER_DIR}/svencoop/servers/server.cfg ]; then
echo "---No 'server.cfg' found, downloading template---"
if [ ! -d ${SERVER_DIR}/svencoop/servers ]; then
mkdir ${SERVER_DIR}/svencoop/servers
fi
cd ${SERVER_DIR}/svencoop/servers
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/svencoop/config/server.cfg ; then
echo "---Sucessfully downloaded 'server.cfg'---"
else
echo "---Something went wrong, can't download 'server.cfg' starting without configuration file---"
fi
fi fi
chmod -R ${DATA_PERM} ${DATA_DIR} chmod -R ${DATA_PERM} ${DATA_DIR}
echo "---Server ready---" echo "---Server ready---"
echo "---Start Server---" echo "---Start Server---"
cd ${SERVER_DIR} cd ${SERVER_DIR}
${SERVER_DIR}/srcds_run -game ${GAME_NAME} ${GAME_PARAMS} -console +port ${GAME_PORT} ${SERVER_DIR}/svends_run -svencoop ${GAME_PARAMS}

View File

@@ -24,11 +24,6 @@ chown -R root:${GID} /opt/scripts
chmod -R 750 /opt/scripts chmod -R 750 /opt/scripts
chown -R ${UID}:${GID} ${DATA_DIR} 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
echo "---Starting...---" echo "---Starting...---"
term_handler() { term_handler() {
kill -SIGTERM "$killpid" kill -SIGTERM "$killpid"
@@ -43,4 +38,4 @@ while true
do do
wait $killpid wait $killpid
exit 0; 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 "======================="