Compare commits
70 Commits
starbound
...
creativers
Author | SHA1 | Date | |
---|---|---|---|
8ec031aac5 | |||
427347eab6 | |||
4e9ec2b0c9 | |||
6ab646d1d7 | |||
252ebcf726 | |||
cd1bba939e | |||
fa847defd7 | |||
ef8d26deae | |||
3349ad3f73 | |||
89b32451e3 | |||
ce05327350 | |||
6e4c7e7458 | |||
14e7978f05 | |||
065593cbf4 | |||
b49f3ce359 | |||
323c618e13 | |||
a554a14a6b | |||
c7ae56830a | |||
d98fa2f717 | |||
e77a8bcfe6 | |||
ca0c8fefe6
|
|||
e7c87bd8f1
|
|||
2432940e23
|
|||
89598a9710
|
|||
83992eb6cb
|
|||
5e4b466e76
|
|||
72a0e28c71
|
|||
82dea2c6af
|
|||
16d782c55e
|
|||
58f34acf41
|
|||
f0ea49bad6 | |||
d25c781c22 | |||
056f05756a | |||
1c79a312d2 | |||
41df27576a | |||
ad3762e4c0 | |||
821c430387 | |||
37e416a7b1 | |||
8d4d03b438 | |||
20a77cae00 | |||
2e9463a721 | |||
d62dca657f | |||
a7a8798ea8 | |||
94a9d103b6 | |||
25509af841 | |||
a82efe30be | |||
704525d91c | |||
252605ca63 | |||
eb266c39f6 | |||
57865f566b | |||
d22246d105 | |||
f0137cf7b6 | |||
0f592029f1 | |||
8d283cfe53 | |||
becf5dc1a7 | |||
4278fc8884 | |||
700351ff61 | |||
ed40f24e06 | |||
8b70b11884 | |||
d71ca52efe | |||
075799da02 | |||
1fea73c677 | |||
d8471aadf3 | |||
500275b668 | |||
f603c5a482 | |||
20e2a492b6 | |||
1af4324c74 | |||
83c8ce9cc4 | |||
5fe96b0b12 | |||
d755ec14fa |
1
.github/FUNDING.yml
vendored
Normal file
1
.github/FUNDING.yml
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
github: ich777
|
41
Dockerfile
41
Dockerfile
@@ -1,36 +1,39 @@
|
|||||||
FROM ubuntu
|
FROM ich777/debian-baseimage:bullseye_amd64
|
||||||
|
|
||||||
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 update && \
|
||||||
RUN apt-get -y install lib32gcc1 libc6-i386 wget language-pack-en lib32stdc++6
|
apt-get -y install --no-install-recommends lib32gcc-s1 lib32stdc++6 && \
|
||||||
|
wget -q -O /tmp/packages-microsoft-prod.deb https://packages.microsoft.com/config/debian/11/packages-microsoft-prod.deb && \
|
||||||
|
dpkg -i /tmp/packages-microsoft-prod.deb && \
|
||||||
|
rm -rf /tmp/packages-microsoft-prod.de && \
|
||||||
|
apt-get update && apt-get -y install aspnetcore-runtime-3.1 && \
|
||||||
|
rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
ENV DATA_DIR="/serverdata"
|
ENV DATA_DIR="/serverdata"
|
||||||
ENV STEAMCMD_DIR="${DATA_DIR}/steamcmd"
|
ENV STEAMCMD_DIR="${DATA_DIR}/steamcmd"
|
||||||
ENV SERVER_DIR="${DATA_DIR}/serverfiles"
|
ENV SERVER_DIR="${DATA_DIR}/serverfiles"
|
||||||
ENV GAME_ID="template"
|
ENV GAME_PARAMS="-worldId=unraid_world"
|
||||||
ENV GAME_NAME="template"
|
|
||||||
ENV GAME_PARAMS="template"
|
|
||||||
ENV GAME_PORT=27015
|
|
||||||
ENV VALIDATE=""
|
ENV VALIDATE=""
|
||||||
|
ENV UMASK=000
|
||||||
ENV UID=99
|
ENV UID=99
|
||||||
ENV GID=100
|
ENV GID=100
|
||||||
ENV USERNAME=""
|
ENV USERNAME=""
|
||||||
ENV PASSWRD=""
|
ENV PASSWRD=""
|
||||||
|
ENV USER="steam"
|
||||||
|
ENV DATA_PERM=770
|
||||||
|
|
||||||
RUN mkdir $DATA_DIR
|
RUN mkdir $DATA_DIR && \
|
||||||
RUN mkdir $STEAMCMD_DIR
|
mkdir $STEAMCMD_DIR && \
|
||||||
RUN mkdir $SERVER_DIR
|
mkdir $SERVER_DIR && \
|
||||||
RUN useradd -d $DATA_DIR -s /bin/bash --uid $UID --gid $GID steam
|
useradd -d $DATA_DIR -s /bin/bash $USER && \
|
||||||
RUN chown -R steam $DATA_DIR
|
chown -R $USER $DATA_DIR && \
|
||||||
|
ulimit -n 2048
|
||||||
RUN ulimit -n 2048
|
|
||||||
|
|
||||||
ADD /scripts/ /opt/scripts/
|
ADD /scripts/ /opt/scripts/
|
||||||
RUN chmod -R 770 /opt/scripts/
|
RUN chmod -R 770 /opt/scripts/
|
||||||
RUN chown -R steam /opt/scripts
|
COPY world.tar /opt/world.tar
|
||||||
|
|
||||||
USER steam
|
|
||||||
|
|
||||||
#Server Start
|
#Server Start
|
||||||
ENTRYPOINT ["/opt/scripts/start-server.sh"]
|
ENTRYPOINT ["/opt/scripts/start.sh"]
|
48
README.md
48
README.md
@@ -1,45 +1,45 @@
|
|||||||
# SteamCMD in Docker optimized for Unraid
|
# 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 Creativerse and run it.
|
||||||
|
|
||||||
## Env params
|
**ATTENTION:** First Startup can take very long since it downloads the gameserver files and the world template!
|
||||||
|
|
||||||
|
**Update Notice:** Simply restart the container if a newer version of the game is available.
|
||||||
|
|
||||||
|
You can also run multiple servers with only one SteamCMD directory!
|
||||||
|
|
||||||
|
**ServerAdmin:** To become server admin please open up the file '.../PlayfulCorp/CreativerseServer/worlddata/worlds/unraid_world/config_world.json' and change the value from 'WorldOwnerSteamId' to your SteamID64 (you can get your SteamID here: https://steamid.io/).
|
||||||
|
|
||||||
|
**Note:** As time of creating the container the WebGUI isn't working but you should be able to do all things from in game. The developers from the game will implement this later on.
|
||||||
|
|
||||||
|
## Example 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 | SteamID for server | 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: '1098260 -beta YOURBRANCH' (without quotes, replace YOURBRANCH with the branch or version you want to install). | 1098260 |
|
||||||
| GAME_NAME | SRCDS gamename | cstrike |
|
| GAME_PARAMS | Enter your game parameters (only change the worldId if you know what you are doing!) | -worldId=unraid_world |
|
||||||
| 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 |
|
| GAME_PORT | Port the server will be running on | 27015 |
|
||||||
| VALIDATE | Validates the game data | true |
|
| VALIDATE | Validates the game data | false |
|
||||||
| 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 |
|
||||||
|
|
||||||
***ATTENTION: You have to disable Steam Guard for games that require authentication, Steam recommends to create a seperate account for dedicated servers***
|
|
||||||
|
|
||||||
>**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
|
|
||||||
|
|
||||||
## Run example
|
## Run example
|
||||||
```
|
```
|
||||||
docker run --name CSSource -d \
|
docker run --name Creativerse -d \
|
||||||
-p 27015:27015 -p 27015:27015/udp \
|
-p 26900:26900/udp -p 26901:26901/udp -p 26902:26902 \
|
||||||
--env 'GAME_ID=232330' \
|
--env 'GAME_ID=1098260' \
|
||||||
--env 'GAME_NAME=cstrike' \
|
--env 'GAME_PARAMS=-worldId=unraid_world' \
|
||||||
--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 /mnt/user/appdata/steamcmd:/serverdata/steamcmd \
|
--volume /path/to/steamcmd:/serverdata/steamcmd \
|
||||||
--volume /mnt/user/appdata/cstrikesource:/serverdata/serverfiles \
|
--volume /path/to/creativerse:/serverdata/serverfiles \
|
||||||
ich777/steamcmd:latest
|
ich777/steamcmd:creativerse
|
||||||
```
|
```
|
||||||
>**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 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/
|
@@ -13,48 +13,82 @@ if [ "${USERNAME}" == "" ]; then
|
|||||||
+quit
|
+quit
|
||||||
else
|
else
|
||||||
${STEAMCMD_DIR}/steamcmd.sh \
|
${STEAMCMD_DIR}/steamcmd.sh \
|
||||||
+login $USERNAME $PASSWRD \
|
+login ${USERNAME} ${PASSWRD} \
|
||||||
+quit
|
+quit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "---Update Server---"
|
echo "---Update Server---"
|
||||||
if [ "${USERNAME}" == "" ]; then
|
if [ "${USERNAME}" == "" ]; then
|
||||||
if [ "${VALIDATE}" == "true" ]; then
|
if [ "${VALIDATE}" == "true" ]; then
|
||||||
|
echo "---Validating installation---"
|
||||||
${STEAMCMD_DIR}/steamcmd.sh \
|
${STEAMCMD_DIR}/steamcmd.sh \
|
||||||
|
+force_install_dir ${SERVER_DIR} \
|
||||||
+login anonymous \
|
+login anonymous \
|
||||||
+force_install_dir $SERVER_DIR \
|
+app_update ${GAME_ID} validate \
|
||||||
+app_update $GAME_ID validate \
|
|
||||||
+quit
|
+quit
|
||||||
else
|
else
|
||||||
${STEAMCMD_DIR}/steamcmd.sh \
|
${STEAMCMD_DIR}/steamcmd.sh \
|
||||||
|
+force_install_dir ${SERVER_DIR} \
|
||||||
+login anonymous \
|
+login anonymous \
|
||||||
+force_install_dir $SERVER_DIR \
|
+app_update ${GAME_ID} \
|
||||||
+app_update $GAME_ID \
|
|
||||||
+quit
|
+quit
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
if [ "${VALIDATE}" == "true" ]; then
|
if [ "${VALIDATE}" == "true" ]; then
|
||||||
|
echo "---Validating installation---"
|
||||||
${STEAMCMD_DIR}/steamcmd.sh \
|
${STEAMCMD_DIR}/steamcmd.sh \
|
||||||
+login $USERNAME $PASSWRD \
|
+force_install_dir ${SERVER_DIR} \
|
||||||
+force_install_dir $SERVER_DIR \
|
+login ${USERNAME} ${PASSWRD} \
|
||||||
+app_update $GAME_ID validate \
|
+app_update ${GAME_ID} validate \
|
||||||
+quit
|
+quit
|
||||||
else
|
else
|
||||||
${STEAMCMD_DIR}/steamcmd.sh \
|
${STEAMCMD_DIR}/steamcmd.sh \
|
||||||
+login $USERNAME $PASSWRD \
|
+force_install_dir ${SERVER_DIR} \
|
||||||
+force_install_dir $SERVER_DIR \
|
+login ${USERNAME} ${PASSWRD} \
|
||||||
+app_update $GAME_ID \
|
+app_update ${GAME_ID} \
|
||||||
+quit
|
+quit
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "---Prepare Server---"
|
echo "---Prepare Server---"
|
||||||
mkdir ${DATA_DIR}/.steam/sdk32
|
if [ ! -f ${DATA_DIR}/.steam/sdk64/steamclient.so ]; then
|
||||||
cp -R ${SERVER_DIR}/bin/* ${DATA_DIR}/.steam/sdk32/
|
if [ ! -d ${DATA_DIR}/.steam/sdk64 ]; then
|
||||||
chmod -R 770 ${DATA_DIR}
|
mkdir -p ${DATA_DIR}/.steam/sdk64
|
||||||
|
fi
|
||||||
|
cp -R ${STEAMCMD_DIR}/linux64/* ${DATA_DIR}/.steam/sdk64/
|
||||||
|
fi
|
||||||
|
echo "---Looking if World is already in place---"
|
||||||
|
if [ ! -d ${SERVER_DIR}/PlayfulCorp/CreativerseServer/worlddata/worlds ]; then
|
||||||
|
mkdir -p ${SERVER_DIR}/PlayfulCorp/CreativerseServer/worlddata/worlds
|
||||||
|
fi
|
||||||
|
WORLD_NAME="$(grep -oE '\-worldId\S+' <<< ${GAME_PARAMS})"
|
||||||
|
if [ "${WORLD_NAME#*=}" == "unraid_world" ]; then
|
||||||
|
if [ ! -d ${SERVER_DIR}/PlayfulCorp/CreativerseServer/worlddata/worlds/unraid_world ]; then
|
||||||
|
echo "---Default world 'unraid_world' not found, please wait, installing...---"
|
||||||
|
mkdir -p ${SERVER_DIR}/PlayfulCorp/CreativerseServer/worlddata/worlds/unraid_world
|
||||||
|
tar -C ${SERVER_DIR}/PlayfulCorp/CreativerseServer/worlddata/worlds/unraid_world -xvf /opt/world.tar
|
||||||
|
else
|
||||||
|
echo "---Default world 'unraid_world' found!---"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if [ ! -d ${SERVER_DIR}/PlayfulCorp/CreativerseServer/worlddata/worlds/${WORLD_NAME#*=} ]; then
|
||||||
|
echo
|
||||||
|
echo "+-------------------------------------------------------------------------------"
|
||||||
|
echo "| World '${WORLD_NAME#*=}' not found, please copy it over to:"
|
||||||
|
echo "| '.../PlayfulCorp/CreativerseServer/worlddata/worlds/${WORLD_NAME#*=}'"
|
||||||
|
echo "| and restart the container!"
|
||||||
|
echo "|"
|
||||||
|
echo "| Putting Container into sleep mode!"
|
||||||
|
echo "+-------------------------------------------------------------------------------"
|
||||||
|
chmod -R ${DATA_PERM} ${SERVER_DIR}/PlayfulCorp
|
||||||
|
sleep infinity
|
||||||
|
else
|
||||||
|
echo "---World '${WORLD_NAME#*=}' found!---"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
chmod -R ${DATA_PERM} ${DATA_DIR}
|
||||||
|
echo "---Server ready---"
|
||||||
|
|
||||||
echo "---Start Server---"
|
echo "---Start Server---"
|
||||||
${SERVER_DIR}/srcds_run -game $GAME_NAME $GAME_PARAMS -console +port $GAME_PORT
|
cd ${SERVER_DIR}
|
||||||
|
${SERVER_DIR}/CreativerseServer ${GAME_PARAMS}
|
||||||
|
|
||||||
|
|
44
scripts/start.sh
Normal file
44
scripts/start.sh
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/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 ${UID}:${GID} /opt/world.tar
|
||||||
|
chmod 750 /opt/world.tar
|
||||||
|
chown -R ${UID}:${GID} ${DATA_DIR}
|
||||||
|
|
||||||
|
echo "---Starting...---"
|
||||||
|
term_handler() {
|
||||||
|
kill -SIGINT $(pidof CreativerseServer)
|
||||||
|
tail --pid=$(pidof CreativerseServer) -f 2>/dev/null
|
||||||
|
sleep 0.5
|
||||||
|
exit 143;
|
||||||
|
}
|
||||||
|
|
||||||
|
trap 'kill ${!}; term_handler' SIGTERM
|
||||||
|
su ${USER} -c "/opt/scripts/start-server.sh" &
|
||||||
|
killpid="$!"
|
||||||
|
while true
|
||||||
|
do
|
||||||
|
wait $killpid
|
||||||
|
exit 0;
|
||||||
|
done
|
Reference in New Issue
Block a user