Compare commits

...

94 Commits

Author SHA1 Message Date
565d9911fd „scripts/start-server.sh“ ändern 2023-01-29 18:00:56 +01:00
75453b0238 „scripts/start.sh“ ändern 2022-10-25 11:04:17 +02:00
4acdcec698 Dateien hochladen nach „config“ 2022-10-23 08:29:38 +02:00
cf97389bd2 „scripts/start-server.sh“ ändern 2022-10-23 08:29:03 +02:00
ce6a120c4a „scripts/start-server.sh“ ändern 2022-10-22 10:18:26 +02:00
64c9f7095b „scripts/start.sh“ ändern 2022-05-07 08:47:01 +02:00
6256cc273a „scripts/start-watchdog.sh“ ändern 2022-05-07 08:44:12 +02:00
aa9e4cabb2 „scripts/start-server.sh“ ändern 2022-05-07 08:41:48 +02:00
ac87eaf47b „scripts/start-server.sh“ ändern 2022-05-07 08:38:21 +02:00
ed68a98cc4 „scripts/start-watchdog.sh“ ändern 2022-05-07 08:38:16 +02:00
2325f95a4d „Dockerfile“ ändern 2022-05-07 08:31:15 +02:00
af14bdf0eb „Dockerfile“ ändern 2022-05-06 10:28:12 +02:00
b4f9c3fe9f „README.md“ ändern 2022-04-18 11:28:15 +02:00
64639579ad „scripts/start.sh“ ändern 2022-04-18 11:24:21 +02:00
c50b314860 „scripts/start-server.sh“ ändern 2022-04-07 17:37:20 +02:00
5344d18739 „Dockerfile“ ändern 2022-04-07 17:36:39 +02:00
923f1c34f6 „scripts/start.sh“ ändern 2022-04-07 17:18:53 +02:00
ebc907d136 „scripts/start-server.sh“ ändern 2021-07-22 20:18:49 +02:00
7c1b15aee2 „scripts/start-watchdog.sh“ hinzufügen 2021-07-22 20:18:14 +02:00
fb34ebaa28 „scripts/start.sh“ ändern 2021-07-22 20:08:03 +02:00
224a63e255 „config/cluster.ini“ ändern 2021-07-22 19:59:38 +02:00
393d1335c1 „scripts/start.sh“ ändern 2020-04-28 17:04:03 +02:00
d9b6b36faa „.drone.yml“ löschen 2020-03-08 20:58:23 +01:00
2882412fc2 „.drone.yml“ hinzufügen
Some checks reported errors
continuous-integration/drone/push Build was killed
2020-03-05 20:27:35 +01:00
c86381dbf1 „scripts/start-server.sh“ ändern 2020-02-25 14:22:30 +01:00
6ddb953f57 „scripts/start.sh“ hinzufügen 2020-02-25 14:22:11 +01:00
a524869870 „Dockerfile“ ändern 2020-02-25 14:21:31 +01:00
33c55735a1 „scripts/start-server.sh“ ändern 2020-01-19 10:18:28 +01:00
4e42287773 „Dockerfile“ ändern 2020-01-19 10:10:36 +01:00
3ed2c17ade „Dockerfile“ ändern 2019-11-11 11:33:37 +01:00
538d59b337 „scripts/start-server.sh“ ändern 2019-11-11 11:21:03 +01:00
9045b3c5cd „scripts/start-server.sh“ ändern 2019-05-21 11:54:29 +02:00
ff1c13fd95 „scripts/start-server.sh“ ändern 2019-05-15 20:58:03 +02:00
c844d38a72 Update start-server.sh 2019-05-13 20:05:57 +02:00
8ed914b145 Update cluster.ini 2019-05-13 19:52:27 +02:00
5bca5629ea Update start-server.sh 2019-05-13 13:37:42 +02:00
ff40e07faa Update start-server.sh 2019-05-13 13:35:23 +02:00
eb5a305dcb Update caves_server.ini 2019-05-13 13:33:27 +02:00
e08aeb6d4b Update server.ini 2019-05-13 13:30:58 +02:00
a96d05b6ab Update caves_server.ini 2019-05-13 13:30:41 +02:00
a67764318d Update server.ini 2019-05-13 13:30:23 +02:00
231ba33c9c Update server.ini 2019-05-13 13:28:53 +02:00
1990ca4aa7 Update server.ini 2019-05-13 13:26:33 +02:00
214c3424c8 Update caves_worldgenoverride.lua 2019-05-13 13:25:08 +02:00
45cf9962f8 Update worldgenoverride.lua 2019-05-13 13:24:37 +02:00
241d7ddeaf Update Dockerfile 2019-05-13 13:19:54 +02:00
d78bf5ca13 Update start-server.sh 2019-05-13 13:17:51 +02:00
7a67f4c01e Update Dockerfile 2019-05-13 13:10:33 +02:00
221d487c7e Update caves_server.ini 2019-05-10 07:45:50 +02:00
efcc791f3f Update caves_server.ini 2019-05-09 13:21:55 +02:00
8040ce7453 Update server.ini 2019-05-09 13:21:41 +02:00
0a368b3a9a Update start-server.sh 2019-05-09 13:00:20 +02:00
48f618c44b Create caves_worldgenoverride.lua 2019-05-09 12:14:15 +02:00
6f23f7bd95 Create worldgenoverride.lua 2019-05-09 12:13:40 +02:00
959996b5c0 Create caves_server.ini 2019-05-09 12:13:08 +02:00
28398947b3 Delete worldgenoverride.lua 2019-05-09 11:45:55 +02:00
7005f15c7c Create worldgenoverride.lua 2019-05-09 11:45:08 +02:00
7f94eebbe8 Create adminlist.txt 2019-05-09 11:42:54 +02:00
8a75a6291d Update start-server.sh 2019-05-07 21:34:18 +02:00
d434872597 Update Dockerfile 2019-05-07 21:26:16 +02:00
5035775bec Update start-server.sh 2019-05-07 21:25:56 +02:00
bc3c04d7d8 Update start-server.sh 2019-05-07 21:18:16 +02:00
b0cbb61f03 Update start-server.sh 2019-05-07 21:17:30 +02:00
1cfe0c75c4 Update Dockerfile 2019-05-07 21:08:48 +02:00
48aa1c5304 Create server.ini 2019-05-07 21:06:40 +02:00
9e4382d8b0 Update and rename settings.ini to cluster.ini 2019-05-07 21:01:08 +02:00
359087efde Create cluster_token.txt 2019-05-07 20:59:45 +02:00
f63412c875 Update start-server.sh 2019-05-07 20:32:20 +02:00
debd7ec9ef Update Dockerfile 2019-05-07 20:31:21 +02:00
7e9b7433e9 Update Dockerfile 2019-05-07 20:24:50 +02:00
45f4aa9b6e Update Dockerfile 2019-05-07 19:59:01 +02:00
3874bacd36 Update start-server.sh 2019-05-07 19:46:24 +02:00
cedf23c45f Create settings.ini 2019-05-07 13:28:35 +02:00
fdb8622cc6 Update Dockerfile 2019-05-07 13:27:00 +02:00
1af4324c74 Update start-server.sh 2019-04-29 17:30:58 +02:00
83c8ce9cc4 Update start-server.sh 2019-04-24 12:59:19 +02:00
5fe96b0b12 Update start-server.sh 2019-04-24 12:13:20 +02:00
d755ec14fa Merge pull request #3 from ich777/beta
Updated to support login
2019-04-23 18:10:56 +02:00
d5fa207964 Update README.md 2019-04-23 18:03:13 +02:00
26ca9f1ad0 Update README.md 2019-04-23 18:02:45 +02:00
d50caefedd Update README.md 2019-04-23 18:02:15 +02:00
3a2fd6a598 Update start-server.sh 2019-04-23 17:38:06 +02:00
a7f37fcf85 Update Dockerfile 2019-04-23 17:35:08 +02:00
d5d85ac911 Update start-server.sh 2019-04-23 17:26:45 +02:00
f6900bf5a5 Update Dockerfile 2019-04-23 17:17:42 +02:00
546dc7c319 Update start-server.sh 2019-04-23 17:08:45 +02:00
74d636577e Update start-server.sh 2019-04-23 16:54:42 +02:00
d448df5801 Update Dockerfile 2019-04-23 11:48:08 +02:00
a663bbb7fa Update start-server.sh 2019-04-23 11:47:05 +02:00
53a86c7ea2 Update start-server.sh 2019-04-23 10:07:34 +02:00
d7e0a36f88 Update Dockerfile 2019-04-23 10:01:28 +02:00
83d06598c4 Update README.md 2019-04-23 09:41:05 +02:00
45a951f94e Update Dockerfile 2019-04-23 09:40:24 +02:00
51c9ecf700 Update start-server.sh 2019-04-23 09:39:37 +02:00
12 changed files with 422 additions and 49 deletions

View File

@@ -1,9 +1,12 @@
FROM ubuntu
FROM ich777/debian-baseimage
MAINTAINER ich777
LABEL org.opencontainers.image.authors="admin@minenet.at"
LABEL org.opencontainers.image.source="https://github.com/ich777/docker-steamcmd-server"
RUN apt-get update
RUN apt-get -y install lib32gcc1 libc6-i386 wget language-pack-en lib32stdc++6
RUN dpkg --add-architecture i386 && \
apt-get update && \
apt-get -y install --no-install-recommends lib32gcc-s1 lib32stdc++6 libcurl4-gnutls-dev:i386 libcurl4-gnutls-dev screen && \
rm -rf /var/lib/apt/lists/*
ENV DATA_DIR="/serverdata"
ENV STEAMCMD_DIR="${DATA_DIR}/steamcmd"
@@ -11,23 +14,29 @@ ENV SERVER_DIR="${DATA_DIR}/serverfiles"
ENV GAME_ID="template"
ENV GAME_NAME="template"
ENV GAME_PARAMS="template"
ENV FORCE_X64="true"
ENV GAME_PORT=27015
ENV CAVES=""
ENV VALIDATE=""
ENV UMASK=000
ENV UID=99
ENV GID=100
ENV USERNAME=""
ENV PASSWRD=""
ENV USER="steam"
ENV DATA_PERM=770
RUN mkdir $DATA_DIR
RUN mkdir $STEAMCMD_DIR
RUN mkdir $SERVER_DIR
RUN useradd -d $DATA_DIR -s /bin/bash --uid $UID --gid $GID steam
RUN chown -R steam $DATA_DIR
RUN ulimit -n 2048
RUN mkdir $DATA_DIR && \
mkdir $STEAMCMD_DIR && \
mkdir $SERVER_DIR && \
mkdir $DATA_DIR/.klei && \
mkdir $DATA_DIR/.klei/DoNotStarveTogether && \
useradd -d $DATA_DIR -s /bin/bash $USER && \
chown -R $USER $DATA_DIR && \
ulimit -n 2048
ADD /scripts/ /opt/scripts/
RUN chmod -R 774 /opt/scripts/
RUN chown -R steam /opt/scripts
USER steam
RUN chmod -R 770 /opt/scripts/
#Server Start
ENTRYPOINT ["/opt/scripts/start-server.sh"]
ENTRYPOINT ["/opt/scripts/start.sh"]

View File

@@ -1,40 +1,41 @@
# SteamCMD in Docker optimized for Unraid
This Docker will download and install SteamCMD. It will also install Counter-Strike: Source and run it. Update Notice: Simply restart the container if a newer version of the game is available.
This Docker will download and install SteamCMD. It will also install Don't Starve Together and run it.
**ATTENTION:** After the first complete startup (you can see it in the log) copy your 'cluster_token.txt' in the 'token/Cluster_1' folder and restart the container.
**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 | SteamID for server | 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: '343050 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 343050 |
| CAVES | Delete 'true' if you don't want Caves on your Server. | true |
| GAME_PARAMS | Values to start the server | empty |
| UID | User Identifier | 99 |
| GID | Group Identifier | 100 |
| GAME_PORT | Port the server will be running on | 27015 |
>**NOTE** GAME_ID values can be found [here](https://developer.valvesoftware.com/wiki/Dedicated_Servers_List)
> And for GAME_NAME there is no list, so a quick search should give you the result
| VALIDATE | Validates the game data | true |
| USERNAME | Leave blank for anonymous login | blank |
| PASSWRD | Leave blank for anonymous login | blank |
## 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 DontStarveTogether -d \
-p 10890:10890/udp -p 27016:27016/udp -p 8766:8766/udp \
--env 'GAME_ID=343050' \
--env 'CAVES=true' \
--env 'UID=99' \
--env 'GID=100' \
--volume /mnt/user/appdata/steamcmd:/serverdata/steamcmd \
--volume /mnt/user/appdata/cstrikesource:/serverdata/serverfiles \
ich777/steamcmd:latest
--volume /path/to/dontstarve:/serverdata/serverfiles \
--volume /path/to/dontstarve/token:/serverdata/.klei/DoNotStarveTogether \
ich777/steamcmd:dontstarve
```
>**NOTE** port 26900 is the port for vac, in case of multiple servers make sure these are not the same
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/

1
config/adminlist.txt Normal file
View File

@@ -0,0 +1 @@
Put the KU_xx identitifers of the server admins here (one by line).

11
config/caves_server.ini Normal file
View File

@@ -0,0 +1,11 @@
[NETWORK]
server_port = 10891
[SHARD]
is_master = false
name = Caves
id = 2
[STEAM]
master_server_port = 27017
authentication_port = 8767

View File

@@ -0,0 +1,7 @@
KLEI 1 return {
override_enabled = true,
worldgen_preset = "DST_CAVE",
settings_preset = "DST_CAVE",
overrides = {
},
}

24
config/cluster.ini Normal file
View File

@@ -0,0 +1,24 @@
[GAMEPLAY]
game_mode = survival
max_players = 6
pvp = false
pause_when_empty = true
[NETWORK]
cluster_description = Simple Unraid Docker Server
cluster_name = Docker Server
cluster_intention = cooperative
cluster_password = Docker
[MISC]
console_enabled = true
[SHARD]
shard_enabled = true
bind_ip = 127.0.0.1
master_ip = 127.0.0.1
master_port = 10892
cluster_key = supersecretkey

1
config/cluster_token.txt Normal file
View File

@@ -0,0 +1 @@
Replace this file with your 'cluster_token.txt'

11
config/server.ini Normal file
View File

@@ -0,0 +1,11 @@
[NETWORK]
server_port = 10890
[SHARD]
is_master = true
[STEAM]
master_server_port = 27016
authentication_port = 8766

106
config/worldgenoverride.lua Normal file
View File

@@ -0,0 +1,106 @@
return {
override_enabled = true,
preset = "SURVIVAL_TOGETHER", -- "SURVIVAL_TOGETHER", "MOD_MISSING", "SURVIVAL_TOGETHER_CLASSIC", "SURVIVAL_DEFAULT_PLUS", "COMPLETE_DARKNESS", "DST_CAVE", "DST_CAVE_PLUS"
overrides = {
-- MISC
task_set = "default", -- "classic", "default", "cave_default"
start_location = "default", -- "caves", "default", "plus", "darkness"
world_size = "default", -- "small", "medium", "default", "huge"
branching = "default", -- "never", "least", "default", "most"
loop = "default", -- "never", "default", "always"
specialevent = "default", -- "none", "default", "hallowed_nights", "winters_feast", "year_of_the_gobbler"
autumn = "default", -- "noseason", "veryshortseason", "shortseason", "default", "longseason", "verylongseason", "random"
winter = "default", -- "noseason", "veryshortseason", "shortseason", "default", "longseason", "verylongseason", "random"
spring = "default", -- "noseason", "veryshortseason", "shortseason", "default", "longseason", "verylongseason", "random"
summer = "default", -- "noseason", "veryshortseason", "shortseason", "default", "longseason", "verylongseason", "random"
season_start = "default", -- "default", "winter", "spring", "summer", "autumnorspring", "winterorsummer", "random"
day = "default", -- "default", "longday", "longdusk", "longnight", "noday", "nodusk", "nonight", "onlyday", "onlydusk", "onlynight"
weather = "default", -- "never", "rare", "default", "often", "always"
earthquakes = "default", -- "never", "rare", "default", "often", "always"
lightning = "default", -- "never", "rare", "default", "often", "always"
frograin = "default", -- "never", "rare", "default", "often", "always"
wildfires = "default", -- "never", "rare", "default", "often", "always"
regrowth = "default", -- "veryslow", "slow", "default", "fast", "veryfast"
touchstone = "default", -- "never", "rare", "default", "often", "always"
boons = "default", -- "never", "rare", "default", "often", "always"
cavelight = "default", -- "veryslow", "slow", "default", "fast", "veryfast"
disease_delay = "default", -- "none", "random", "long", "default", "short"
prefabswaps_start = "default", -- "classic", "default", "highly random"
petrification = "default", -- "none", "few", "default", "many", "max"
-- RESOURCES
flowers = "default", -- "never", "rare", "default", "often", "always"
grass = "default", -- "never", "rare", "default", "often", "always"
sapling = "default", -- "never", "rare", "default", "often", "always"
marshbush = "default", -- "never", "rare", "default", "often", "always"
tumbleweed = "default", -- "never", "rare", "default", "often", "always"
reeds = "default", -- "never", "rare", "default", "often", "always"
trees = "default", -- "never", "rare", "default", "often", "always"
flint = "default", -- "never", "rare", "default", "often", "always"
rock = "default", -- "never", "rare", "default", "often", "always"
rock_ice = "default", -- "never", "rare", "default", "often", "always"
meteorspawner = "default", -- "never", "rare", "default", "often", "always"
meteorshowers = "default", -- "never", "rare", "default", "often", "always"
mushtree = "default", -- "never", "rare", "default", "often", "always"
fern = "default", -- "never", "rare", "default", "often", "always"
flower_cave = "default", -- "never", "rare", "default", "often", "always"
wormlights = "default", -- "never", "rare", "default", "often", "always"
-- UNPREPARED
berrybush = "default", -- "never", "rare", "default", "often", "always"
carrot = "default", -- "never", "rare", "default", "often", "always"
mushroom = "default", -- "never", "rare", "default", "often", "always"
cactus = "default", -- "never", "rare", "default", "often", "always"
banana = "default", -- "never", "rare", "default", "often", "always"
lichen = "default", -- "never", "rare", "default", "often", "always"
-- ANIMALS
rabbits = "default", -- "never", "rare", "default", "often", "always"
moles = "default", -- "never", "rare", "default", "often", "always"
butterfly = "default", -- "never", "rare", "default", "often", "always"
birds = "default", -- "never", "rare", "default", "often", "always"
buzzard = "default", -- "never", "rare", "default", "often", "always"
catcoon = "default", -- "never", "rare", "default", "often", "always"
perd = "default", -- "never", "rare", "default", "often", "always"
pigs = "default", -- "never", "rare", "default", "often", "always"
lightninggoat = "default", -- "never", "rare", "default", "often", "always"
beefalo = "default", -- "never", "rare", "default", "often", "always"
beefaloheat = "default", -- "never", "rare", "default", "often", "always"
hunt = "default", -- "never", "rare", "default", "often", "always"
alternatehunt = "default", -- "never", "rare", "default", "often", "always"
penguins = "default", -- "never", "rare", "default", "often", "always"
cave_ponds = "default", -- "never", "rare", "default", "often", "always"
ponds = "default", -- "never", "rare", "default", "often", "always"
bees = "default", -- "never", "rare", "default", "often", "always"
angrybees = "default", -- "never", "rare", "default", "often", "always"
tallbirds = "default", -- "never", "rare", "default", "often", "always"
slurper = "default", -- "never", "rare", "default", "often", "always"
bunnymen = "default", -- "never", "rare", "default", "often", "always"
slurtles = "default", -- "never", "rare", "default", "often", "always"
rocky = "default", -- "never", "rare", "default", "often", "always"
monkey = "default", -- "never", "rare", "default", "often", "always"
-- MONSTERS
spiders = "default", -- "never", "rare", "default", "often", "always"
cave_spiders = "default", -- "never", "rare", "default", "often", "always"
hounds = "default", -- "never", "rare", "default", "often", "always"
houndmound = "default", -- "never", "rare", "default", "often", "always"
merm = "default", -- "never", "rare", "default", "often", "always"
tentacles = "default", -- "never", "rare", "default", "often", "always"
chess = "default", -- "never", "rare", "default", "often", "always"
lureplants = "default", -- "never", "rare", "default", "often", "always"
walrus = "default", -- "never", "rare", "default", "often", "always"
liefs = "default", -- "never", "rare", "default", "often", "always"
deciduousmonster = "default", -- "never", "rare", "default", "often", "always"
krampus = "default", -- "never", "rare", "default", "often", "always"
bearger = "default", -- "never", "rare", "default", "often", "always"
deerclops = "default", -- "never", "rare", "default", "often", "always"
goosemoose = "default", -- "never", "rare", "default", "often", "always"
dragonfly = "default", -- "never", "rare", "default", "often", "always"
antliontribute = "default", -- "never", "rare", "default", "often", "always"
bats = "default", -- "never", "rare", "default", "often", "always"
fissure = "default", -- "never", "rare", "default", "often", "always"
wormattacks = "default", -- "never", "rare", "default", "often", "always"
worms = "default", -- "never", "rare", "default", "often", "always"
},
}

View File

@@ -1,26 +1,171 @@
#!/bin/bash
if [ ! -f ${STEAMCMD_DIR}/steamcmd.sh ]; then
echo "Steamcmd not found!"
echo "SteamCMD not found!"
wget -q -O ${STEAMCMD_DIR}/steamcmd_linux.tar.gz http://media.steampowered.com/client/steamcmd_linux.tar.gz
tar --directory ${STEAMCMD_DIR} -xvzf /serverdata/steamcmd/steamcmd_linux.tar.gz
rm ${STEAMCMD_DIR}/steamcmd_linux.tar.gz
fi
echo "---Update steamcmd---"
${STEAMCMD_DIR}/steamcmd.sh \
echo "---Update SteamCMD---"
if [ "${USERNAME}" == "" ]; then
${STEAMCMD_DIR}/steamcmd.sh \
+login anonymous \
+quit
else
${STEAMCMD_DIR}/steamcmd.sh \
+login ${USERNAME} ${PASSWRD} \
+quit
fi
echo "---Update server---"
${STEAMCMD_DIR}/steamcmd.sh \
echo "---Update Server---"
if [ "${USERNAME}" == "" ]; then
if [ "${VALIDATE}" == "true" ]; then
echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \
+force_install_dir ${SERVER_DIR} \
+login anonymous \
+force_install_dir $SERVER_DIR \
+app_update $GAME_ID \
+app_update ${GAME_ID} validate \
+quit
else
${STEAMCMD_DIR}/steamcmd.sh \
+force_install_dir ${SERVER_DIR} \
+login anonymous \
+app_update ${GAME_ID} \
+quit
fi
else
if [ "${VALIDATE}" == "true" ]; then
echo "---Validating installation---"
${STEAMCMD_DIR}/steamcmd.sh \
+force_install_dir ${SERVER_DIR} \
+login ${USERNAME} ${PASSWRD} \
+app_update ${GAME_ID} validate \
+quit
else
${STEAMCMD_DIR}/steamcmd.sh \
+force_install_dir ${SERVER_DIR} \
+login ${USERNAME} ${PASSWRD} \
+app_update ${GAME_ID} \
+quit
fi
fi
echo "---Prepare Server---"
mkdir ${DATA_DIR}/.steam/sdk32
cp -R ${SERVER_DIR}/bin/* ${DATA_DIR}/.steam/sdk32/
if [ "${FORCE_X64}" == "true" ]; then
X64_MODE="_x64"
X64_PATH="64"
fi
if [ ! -f ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/cluster_token.txt ]; then
echo "---No cluster_token.txt found, downloading template, please create your own to run the server!!!...---"
if [ ! -d ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1 ]; then
mkdir ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1
fi
cd ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/dontstarve/config/cluster_token.txt ; then
echo "---Sucessfully downloaded 'cluster_token.ini'---"
else
echo "---Can't download 'cluster_token.ini', putting server into sleep mode---"
sleep infinity
fi
fi
if [ ! -f ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/cluster.ini ]; then
echo "---No cluster.ini found, downloading template...---"
if [ ! -d ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1 ]; then
mkdir ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1
fi
cd ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/dontstarve/config/cluster.ini ; then
echo "---Sucessfully downloaded 'cluster.ini'---"
else
echo "---Can't download 'cluster.ini', putting server into sleep mode---"
sleep infinity
fi
fi
if [ ! -f ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/adminlist.txt ]; then
echo "---No adminlist.txt found, downloading template...---"
if [ ! -d ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1 ]; then
mkdir ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1
fi
cd ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/dontstarve/config/adminlist.txt ; then
echo "---Sucessfully downloaded 'adminlist.txt'---"
else
echo "---Can't download 'adminlist.txt', putting server into sleep mode---"
sleep infinity
fi
fi
if [ ! -f ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master/server.ini ]; then
echo "---No server.ini found, downloading template...---"
if [ ! -d ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master ]; then
mkdir ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master
fi
cd ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/dontstarve/config/server.ini ; then
echo "---Sucessfully downloaded 'server.ini'---"
else
echo "---Can't download 'server.ini', putting server into sleep mode---"
sleep infinity
fi
fi
if [ ! -f ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master/worldgenoverride.lua ]; then
echo "---No worldgenoverride.lua found, downloading template...---"
if [ ! -d ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master ]; then
mkdir ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master
fi
cd ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Master
if wget -q -nc --show-progress --progress=bar:force:noscroll https://raw.githubusercontent.com/ich777/docker-steamcmd-server/dontstarve/config/worldgenoverride.lua ; then
echo "---Sucessfully downloaded 'worldgenoverride.lua'---"
else
echo "---Can't download 'worldgenoverride.lua', putting server into sleep mode---"
sleep infinity
fi
fi
if [ "${CAVES}" == "true" ]; then
if [ ! -f ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves/server.ini ]; then
echo "---No Caves/server.ini found, downloading template...---"
if [ ! -d ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves ]; then
mkdir ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves
fi
cd ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves
if wget -q -nc --show-progress --progress=bar:force:noscroll -O ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves/server.ini https://raw.githubusercontent.com/ich777/docker-steamcmd-server/dontstarve/config/caves_server.ini ; then
echo "---Sucessfully downloaded 'caves_server.ini'---"
else
echo "---Can't download 'caves_server.ini', putting server into sleep mode---"
sleep infinity
fi
fi
if [ ! -f ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves/worldgenoverride.lua ]; then
echo "---No Caves/worldgenoverride.lua found, downloading template...---"
if [ ! -d ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves ]; then
mkdir ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves
fi
cd ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves
if wget -q -nc --show-progress --progress=bar:force:noscroll -O ${DATA_DIR}/.klei/DoNotStarveTogether/Cluster_1/Caves/worldgenoverride.lua https://raw.githubusercontent.com/ich777/docker-steamcmd-server/dontstarve/config/caves_worldgenoverride.lua ; then
echo "---Sucessfully downloaded 'caves_worldgenoverride.lua'---"
else
echo "---Can't download 'caves_worldgenoverride.lua', putting server into sleep mode---"
sleep infinity
fi
fi
fi
chmod -R ${DATA_PERM} ${DATA_DIR}
echo "---Server ready---"
echo "---Start Server---"
${SERVER_DIR}/srcds_run -game $GAME_NAME $GAME_PARAMS -console +port $GAME_PORT
if [ "${CAVES}" == "true" ]; then
echo "---Checking for old logs---"
find $SERVER_DIR -name "masterLog.*" -exec rm -f {} \;
find $SERVER_DIR -name "cavesLog.*" -exec rm -f {} \;
echo "---Start Server---"
cd ${SERVER_DIR}/bin${X64_PATH}
screen -S Master -L -Logfile $SERVER_DIR/masterLog.0 -d -m ${SERVER_DIR}/bin${X64_PATH}/dontstarve_dedicated_server_nullrenderer${X64_MODE} -shard Master
screen -S Caves -L -Logfile $SERVER_DIR/cavesLog.0 -d -m ${SERVER_DIR}/bin${X64_PATH}/dontstarve_dedicated_server_nullrenderer${X64_MODE} -shard Caves
sleep 2
screen -S watchdog -d -m /opt/scripts/start-watchdog.sh
tail -f ${SERVER_DIR}/masterLog.0 ${SERVER_DIR}/cavesLog.0
else
find $SERVER_DIR -name "masterLog.*" -exec rm -f {} \;
find $SERVER_DIR -name "cavesLog.*" -exec rm -f {} \;
echo "---Start Server---"
cd ${SERVER_DIR}/bin${X64_PATH}
${SERVER_DIR}/bin${X64_PATH}/dontstarve_dedicated_server_nullrenderer${X64_MODE} -shard Master
fi

12
scripts/start-watchdog.sh Normal file
View File

@@ -0,0 +1,12 @@
#!/bin/bash
if [ "${FORCE_X64}" == "true" ]; then
killpid="$(pidof dontstarve_dedicated_server_nullrenderer_x64)"
else
killpid="$(pidof dontstarve_dedicated_server_nullrenderer)"
fi
while true
do
tail --pid=${killpid%% *} --pid=${killpid##* } -f /dev/null
kill "$(pidof tail)"
exit 0
done

45
scripts/start.sh Normal file
View File

@@ -0,0 +1,45 @@
#!/bin/bash
echo "---Ensuring UID: ${UID} matches user---"
usermod -u ${UID} ${USER}
echo "---Ensuring GID: ${GID} matches user---"
groupmod -g ${GID} ${USER} > /dev/null 2>&1 ||:
usermod -g ${GID} ${USER}
echo "---Setting umask to ${UMASK}---"
umask ${UMASK}
echo "---Checking for optional scripts---"
cp -f /opt/custom/user.sh /opt/scripts/start-user.sh > /dev/null 2>&1 ||:
cp -f /opt/scripts/user.sh /opt/scripts/start-user.sh > /dev/null 2>&1 ||:
if [ -f /opt/scripts/start-user.sh ]; then
echo "---Found optional script, executing---"
chmod -f +x /opt/scripts/start-user.sh ||:
/opt/scripts/start-user.sh || echo "---Optional Script has thrown an Error---"
else
echo "---No optional script found, continuing---"
fi
echo "---Taking ownership of data...---"
chown -R root:${GID} /opt/scripts
chmod -R 750 /opt/scripts
chown -R ${UID}:${GID} ${DATA_DIR}
echo "---Starting...---"
term_handler() {
if [ "${FORCE_X64}" == "true" ]; then
kill -SIGTERM $(pidof dontstarve_dedicated_server_nullrenderer_x64)
else
kill -SIGTERM $(pidof dontstarve_dedicated_server_nullrenderer)
fi
wait "$killpid" -f 2>/dev/null
exit 143;
}
trap 'kill ${!}; term_handler' SIGTERM
su ${USER} -c "/opt/scripts/start-server.sh" &
killpid="$!"
while true
do
wait $killpid
exit 0;
done