Compare commits
66 Commits
Author | SHA1 | Date | |
---|---|---|---|
30fb3e8a14 | |||
fbf1757392
|
|||
0b1ebdf9fb
|
|||
e07267b93a
|
|||
6522b64982
|
|||
db4e2303d2
|
|||
600f9caadc
|
|||
892816be7e
|
|||
46fcf3d769
|
|||
6246c02044
|
|||
a2345b552e
|
|||
fce9821f43
|
|||
173baf4d96
|
|||
f409228bb3
|
|||
d3ee5490d7
|
|||
7d4fa8812d
|
|||
b7587386f0 | |||
92b4b95d2f | |||
dc9b89b4fe | |||
4da4ec529b | |||
9dfefcfaa2 | |||
3c68953195 | |||
cf68bc167e | |||
a8ea46b8e4 | |||
9bec7ac022 | |||
cca74037c4 | |||
c311c05624 | |||
f8aadf5e4d | |||
489f4b9a49 | |||
3194dbd827 | |||
254c3c96cb | |||
65f5dea1bb | |||
5145e61e53 | |||
2c345b030d | |||
97e49615d5 | |||
93f0b26ec5 | |||
dc026e81f2 | |||
bd366b9e69 | |||
1260871de0 | |||
6c8f0f817d | |||
2629d7d98d | |||
837440948d | |||
65afde7315 | |||
cc36c92f85 | |||
1cdabe044b | |||
4450c358cd | |||
58488e2643 | |||
f3b192247e | |||
d641225bb3 | |||
c9e11a6472 | |||
04402a8afe | |||
fe98b5c36c | |||
2301b82db0 | |||
f768dcc831 | |||
c991a7ce29 | |||
6c34f9ccbd | |||
7d0b2023cc | |||
a9333a0352 | |||
f3b120f82d | |||
b380bc7f24 | |||
c463e82651 | |||
1c1fbc6826 | |||
36be851863 | |||
1cb61cf7ec | |||
adc4ac4616 | |||
c96b1c14b8 |
1
.github/FUNDING.yml
vendored
1
.github/FUNDING.yml
vendored
@@ -1 +0,0 @@
|
||||
github: ich777
|
20
Dockerfile
20
Dockerfile
@@ -1,20 +1,26 @@
|
||||
FROM ich777/debian-baseimage:bullseye_amd64
|
||||
FROM ich777/debian-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 --no-install-recommends lib32gcc-s1 perl-modules curl lsof libc6 libc6-i386 bzip2 jq libssl1.1 libidn11 redis-server screen libtbb2:i386 && \
|
||||
cd /tmp && \
|
||||
wget -q -nc --show-progress --progress=bar:force:noscroll http://ftp.fr.debian.org/debian/pool/main/p/protobuf/libprotobuf10_3.0.0-9_amd64.deb && \
|
||||
dpkg -i /tmp/libprotobuf10_3.0.0-9_amd64.deb && \
|
||||
rm /tmp/libprotobuf10_3.0.0-9_amd64.deb && \
|
||||
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_PARAMS_EXTRA="template"
|
||||
ENV MAP_NAME="Ocean"
|
||||
ENV GAME_PORT=27015
|
||||
ENV VALIDATE=""
|
||||
ENV ENA_REDIS=""
|
||||
ENV UMASK=000
|
||||
ENV UID=99
|
||||
ENV GID=100
|
||||
@@ -28,9 +34,11 @@ 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 1000000
|
||||
|
||||
ADD /scripts/ /opt/scripts/
|
||||
COPY /libcrypto.so.1.0.0 /usr/lib/x86_64-linux-gnu/libcrypto.so.1.0.0
|
||||
COPY /libssl.so.1.0.0 /usr/lib/x86_64-linux-gnu/libssl.so.1.0.0
|
||||
RUN chmod -R 770 /opt/scripts/
|
||||
|
||||
#Server Start
|
||||
|
42
README.md
42
README.md
@@ -1,40 +1,46 @@
|
||||
# DEPRECATED
|
||||
|
||||
# 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 ATLAS and run it (this docker does also have a built in Redis server for quick server setup, you also can disable it in the variables below).
|
||||
|
||||
**Please see the different Tags/Branches which games are available.**
|
||||
**ATTENTION:** First Startup can take very long since it downloads the gameserver files!
|
||||
|
||||
## Example Env params for CS:Source
|
||||
**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_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: '1006030 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 1006030 |
|
||||
| MAP_NAME | Standard Map Name | Ocean |
|
||||
| GAME_PARAMS | Enter your start up commands for the server. | ?ServerX=0?ServerY=0?AltSaveDirectoryName=00?MaxPlayers=50?ReservedPlayerSlots=10?QueryPort=57550?Port=5750 |
|
||||
| EXTRA_GAME_PARAMS | Port the server will be running on | -log -server -NoBattlEye |
|
||||
| ENA_REDIS | If you've set up a external Redis server leave this blank, to enable the built in Redis server enter 'yes' (without quotes). | yes |
|
||||
| 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 | true |
|
||||
| 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 ATLAS -d \
|
||||
-p 57550:57550/udp -p 5750-5751:5750-5751/udp -p 32330:32330/udp -p 27000:27000/udp \
|
||||
--env 'GAME_ID=1006030' \
|
||||
--env 'MAP_NAME=Ocean' \
|
||||
--env 'EXTRA_GAME_PARAMS=-log -server -NoBattlEye' \
|
||||
--env 'GAME_PARAMS=?ServerX=0?ServerY=0?AltSaveDirectoryName=00?MaxPlayers=50?ReservedPlayerSlots=10?QueryPort=57550?Port=5750' \
|
||||
--env 'ENA_REDIS=yes' \
|
||||
--env 'UID=99' \
|
||||
--env 'GID=100' \
|
||||
--volume /path/to/steamcmd:/serverdata/steamcmd \
|
||||
--volume /path/to/cstrikesource:/serverdata/serverfiles \
|
||||
ich777/steamcmd:latest
|
||||
--volume /path/to/atlas:/serverdata/serverfiles \
|
||||
ich777/steamcmd:atlas
|
||||
```
|
||||
|
||||
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/
|
83
grid/ServerGrid.ServerOnly.json
Normal file
83
grid/ServerGrid.ServerOnly.json
Normal file
@@ -0,0 +1,83 @@
|
||||
{
|
||||
"LocalS3URL": "",
|
||||
"LocalS3AccessKeyId": "",
|
||||
"LocalS3SecretKey": "",
|
||||
"LocalS3BucketName": "",
|
||||
"LocalS3Region": "",
|
||||
"TribeLogConfig": {
|
||||
"MaxRedisEntries": 1000,
|
||||
"BackupMode": "off",
|
||||
"MaxFileHistory": 10,
|
||||
"HttpBackupURL": "",
|
||||
"HttpAPIKey": "",
|
||||
"S3URL": "",
|
||||
"S3AccessKeyId": "",
|
||||
"S3SecretKey": "",
|
||||
"S3BucketName": "",
|
||||
"S3KeyPrefix": ""
|
||||
},
|
||||
"SharedLogConfig": {
|
||||
"FetchRateSec": 60,
|
||||
"SnapshotCleanupSec": 900,
|
||||
"SnapshotRateSec": 1800,
|
||||
"SnapshotExpirationHours": 48,
|
||||
"BackupMode": "off",
|
||||
"MaxFileHistory": 10,
|
||||
"HttpBackupURL": "",
|
||||
"HttpAPIKey": "",
|
||||
"S3URL": "",
|
||||
"S3AccessKeyId": "",
|
||||
"S3SecretKey": "",
|
||||
"S3BucketName": "",
|
||||
"S3KeyPrefix": ""
|
||||
},
|
||||
"TravelDataConfig": {
|
||||
"BackupMode": "off",
|
||||
"MaxFileHistory": 10,
|
||||
"HttpBackupURL": "",
|
||||
"HttpAPIKey": "",
|
||||
"S3URL": "",
|
||||
"S3AccessKeyId": "",
|
||||
"S3SecretKey": "",
|
||||
"S3BucketName": "",
|
||||
"S3KeyPrefix": ""
|
||||
},
|
||||
"DatabaseConnections": [
|
||||
{
|
||||
"Name": "TradeDB",
|
||||
"URL": "127.0.0.1",
|
||||
"Port": 6379,
|
||||
"Password": "foobared"
|
||||
},
|
||||
{
|
||||
"Name": "Default",
|
||||
"URL": "127.0.0.1",
|
||||
"Port": 6379,
|
||||
"Password": "foobared"
|
||||
},
|
||||
{
|
||||
"Name": "TribeDB",
|
||||
"URL": "127.0.0.1",
|
||||
"Port": 6379,
|
||||
"Password": "foobared"
|
||||
},
|
||||
{
|
||||
"Name": "TravelDataDB",
|
||||
"URL": "127.0.0.1",
|
||||
"Port": 6379,
|
||||
"Password": "foobared"
|
||||
},
|
||||
{
|
||||
"Name": "TerritoryDB",
|
||||
"URL": "127.0.0.1",
|
||||
"Port": 6379,
|
||||
"Password": "foobared"
|
||||
},
|
||||
{
|
||||
"Name": "LogDB",
|
||||
"URL": "127.0.0.1",
|
||||
"Port": 6379,
|
||||
"Password": "foobared"
|
||||
}
|
||||
]
|
||||
}
|
BIN
grid/ServerGrid.jpg
Normal file
BIN
grid/ServerGrid.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.4 MiB |
1185
grid/ServerGrid.json
Normal file
1185
grid/ServerGrid.json
Normal file
File diff suppressed because it is too large
Load Diff
BIN
libcrypto.so.1.0.0
Normal file
BIN
libcrypto.so.1.0.0
Normal file
Binary file not shown.
BIN
libssl.so.1.0.0
Normal file
BIN
libssl.so.1.0.0
Normal file
Binary file not shown.
@@ -1,4 +1,11 @@
|
||||
#!/bin/bash
|
||||
echo "+---------------------------------"
|
||||
echo "|"
|
||||
echo "| This container is deprecated!"
|
||||
echo "|"
|
||||
echo "+---------------------------------"
|
||||
sleep infinity
|
||||
|
||||
if [ ! -f ${STEAMCMD_DIR}/steamcmd.sh ]; then
|
||||
echo "SteamCMD not found!"
|
||||
wget -q -O ${STEAMCMD_DIR}/steamcmd_linux.tar.gz http://media.steampowered.com/client/steamcmd_linux.tar.gz
|
||||
@@ -50,19 +57,76 @@ else
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "${ENA_REDIS}" == "yes" ]; then
|
||||
echo "---Starting Redis Server---"
|
||||
screen -S RedisServer -d -m /usr/bin/redis-server
|
||||
sleep 5
|
||||
else
|
||||
echo "------------------------------------"
|
||||
echo "-----Internal Redis Server not------"
|
||||
echo "-----enabled, make sure you've------"
|
||||
echo "----configured your ATLAS server----"
|
||||
echo "--for an external REDIS connection--"
|
||||
echo "----otherwise it will not start!----"
|
||||
echo "------------------------------------"
|
||||
sleep 5
|
||||
fi
|
||||
|
||||
echo "---Container under construction!---"
|
||||
sleep infinity
|
||||
|
||||
echo "---Prepare Server---"
|
||||
if [ ! -f ${DATA_DIR}/.steam/sdk32/steamclient.so ]; then
|
||||
if [ ! -d ${DATA_DIR}/.steam ]; then
|
||||
mkdir ${DATA_DIR}/.steam
|
||||
echo "---Searching for grid files...---"
|
||||
if [ ! -f ${SERVER_DIR}/ShooterGame/ServerGrid.jpg ]; then
|
||||
echo "---'ServerGrid.jpg' not found, downloading---"
|
||||
cd ${SERVER_DIR}/ShooterGame
|
||||
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/atlas/grid/ServerGrid.jpg ; then
|
||||
echo "---Sucessfully downloaded 'ServerGrid.jpg'---"
|
||||
else
|
||||
echo "---Can't download 'ServerGrid.jpg', putting server into sleep mode---"
|
||||
sleep infinity
|
||||
fi
|
||||
if [ ! -d ${DATA_DIR}/.steam/sdk32 ]; then
|
||||
mkdir ${DATA_DIR}/.steam/sdk32
|
||||
else
|
||||
echo "---'ServerGrid.jpg' found!---"
|
||||
fi
|
||||
cp -R ${STEAMCMD_DIR}/linux32/* ${DATA_DIR}/.steam/sdk32/
|
||||
if [ ! -f ${SERVER_DIR}/ShooterGame/ServerGrid.json ]; then
|
||||
echo "---'ServerGrid.json' not found, downloading---"
|
||||
cd ${SERVER_DIR}/ShooterGame
|
||||
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/atlas/grid/ServerGrid.json ; then
|
||||
echo "---Sucessfully downloaded 'ServerGrid.json'---"
|
||||
else
|
||||
echo "---Can't download 'ServerGrid.json', putting server into sleep mode---"
|
||||
sleep infinity
|
||||
fi
|
||||
else
|
||||
echo "---'ServerGrid.json' found!---"
|
||||
fi
|
||||
if [ ! -f ${SERVER_DIR}/ShooterGame/ServerGrid.ServerOnly.json ]; then
|
||||
echo "---'ServerGrid.ServerOnly.json' not found, downloading---"
|
||||
cd ${SERVER_DIR}/ShooterGame
|
||||
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/atlas/grid/ServerGrid.ServerOnly.json ; then
|
||||
echo "---Sucessfully downloaded 'ServerGrid.ServerOnly.json'---"
|
||||
else
|
||||
echo "---Can't download 'ServerGrid.ServerOnly.json', putting server into sleep mode---"
|
||||
sleep infinity
|
||||
fi
|
||||
else
|
||||
if [ ! "$(grep '"Name": "TradeDB",' ${SERVER_DIR}/ShooterGame/ServerGrid.ServerOnly.json)" ]; then
|
||||
sed -i '/\"DatabaseConnections\": \[/a\ {\n \"Name\": \"TradeDB\",\n \"URL\": \"127.0.0.1\",\n \"Port"\: 6379,\n \"Password\": \"foobared\"\n },' ${SERVER_DIR}/ShooterGame/ServerGrid.ServerOnly.json
|
||||
fi
|
||||
echo "---'ServerGrid.ServerOnly.json' found!---"
|
||||
fi
|
||||
if [ "${ENA_REDIS}" == "yes" ]; then
|
||||
echo "---Configuring Redis---"
|
||||
sleep 5
|
||||
echo "CONFIG SET dir ${SERVER_DIR}" | redis-cli
|
||||
echo "CONFIG SET dbfilename redis.rdb" | redis-cli
|
||||
echo "BGSAVE" | redis-cli
|
||||
fi
|
||||
sleep 3
|
||||
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}
|
||||
cd ${SERVER_DIR}/ShooterGame/Binaries/Linux
|
||||
./ShooterGameServer ${MAP_NAME}${GAME_PARAMS} ${GAME_PARAMS_EXTRA}
|
@@ -22,13 +22,12 @@ fi
|
||||
echo "---Taking ownership of data...---"
|
||||
chown -R root:${GID} /opt/scripts
|
||||
chmod -R 750 /opt/scripts
|
||||
chown -R ${UID}:${GID} /var/lib/redis
|
||||
chown -R ${UID}:${GID} /usr/bin/redis-server
|
||||
chown -R ${UID}:${GID} /usr/bin/redis-cli
|
||||
chmod -R 770 /var/lib/redis
|
||||
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...---"
|
||||
term_handler() {
|
||||
kill -SIGTERM "$killpid"
|
||||
|
232
tailscale.sh
232
tailscale.sh
@@ -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 "======================="
|
Reference in New Issue
Block a user