Compare commits
	
		
			3 Commits
		
	
	
		
			e04bf4ef57
			...
			2037324375
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						
						
							
						
						2037324375
	
				 | 
					
					
						|||
| 
						
						
							
						
						e6b309d047
	
				 | 
					
					
						|||
| 
						
						
							
						
						d7af43f8b0
	
				 | 
					
					
						
							
								
								
									
										36
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								Dockerfile
									
									
									
									
									
								
							@@ -1,32 +1,36 @@
 | 
				
			|||||||
FROM ubuntu:noble
 | 
					FROM ubuntu:noble
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ARG UID=1000
 | 
				
			||||||
 | 
					ARG GID=1000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ENV DEBIAN_FRONTEND=noninteractive
 | 
					ENV DEBIAN_FRONTEND=noninteractive
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SHELL ["/bin/bash", "-o", "pipefail", "-c"]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# install prerequisites
 | 
					# install prerequisites
 | 
				
			||||||
RUN apt update \
 | 
					RUN apt-get update \
 | 
				
			||||||
    && apt install -y --no-install-recommends \
 | 
					  && apt-get install -y --no-install-recommends \
 | 
				
			||||||
    curl ca-certificates \
 | 
					  curl \
 | 
				
			||||||
 | 
					  ca-certificates \
 | 
				
			||||||
  jq \
 | 
					  jq \
 | 
				
			||||||
  libxml2-utils \
 | 
					  libxml2-utils \
 | 
				
			||||||
    && apt autoremove \
 | 
					  sudo && \
 | 
				
			||||||
    && apt clean \
 | 
					  apt-get autoremove && apt-get clean && \
 | 
				
			||||||
    && rm -rf /var/lib/apt/lists/*
 | 
					  rm -rf /var/lib/apt/lists/*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Remove default ubuntu user
 | 
					# Remove default ubuntu user
 | 
				
			||||||
RUN userdel -r ubuntu \
 | 
					RUN userdel -r ubuntu && \
 | 
				
			||||||
    && useradd --create-home -u 1000 minecraft \
 | 
					  useradd --create-home -u 1000 minecraft && \
 | 
				
			||||||
    && mkdir -p /data \
 | 
					  echo 'minecraft ALL=(ALL) NOPASSWD: ALL' >> /etc/sudoers && \
 | 
				
			||||||
    && chown -R 1000:1000 /data
 | 
					  mkdir -p /data && \
 | 
				
			||||||
 | 
					  chown -R ${UID}:${GID} /data
 | 
				
			||||||
 | 
					
 | 
				
			||||||
USER minecraft
 | 
					RUN su -c "curl -sL https://github.com/Jabba-Team/jabba/raw/main/install.sh | bash && . ~/.jabba/jabba.sh" minecraft
 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN curl -sL https://github.com/Jabba-Team/jabba/raw/main/install.sh | bash \
 | 
					 | 
				
			||||||
    && . ~/.jabba/jabba.sh
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
USER root
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
COPY ./scripts/init /
 | 
					COPY ./scripts/init /
 | 
				
			||||||
COPY ./scripts/mc /usr/local/bin 
 | 
					COPY ./scripts/mc /usr/local/bin 
 | 
				
			||||||
RUN chmod +x /init && chmod +x /usr/local/bin/mc
 | 
					RUN chmod +x /init && chmod +x /usr/local/bin/mc
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					USER minecraft
 | 
				
			||||||
 | 
					
 | 
				
			||||||
CMD ["/init"]
 | 
					CMD ["/init"]
 | 
				
			||||||
							
								
								
									
										12
									
								
								scripts/init
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								scripts/init
									
									
									
									
									
								
							@@ -3,14 +3,16 @@
 | 
				
			|||||||
PUID="${PUID:-1000}"
 | 
					PUID="${PUID:-1000}"
 | 
				
			||||||
PGID="${PGID:-1000}"
 | 
					PGID="${PGID:-1000}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
setperms(){
 | 
					setperms() {
 | 
				
			||||||
  echo "Setting permissions to UID:${PUID} and GID:${PGID}"
 | 
					  echo "Setting permissions to UID:${PUID} and GID:${PGID}"
 | 
				
			||||||
    usermod -u ${PUID} minecraft > /dev/null 2>&1
 | 
					  sudo usermod -u ${PUID} minecraft >/dev/null 2>&1
 | 
				
			||||||
    groupmod -g ${PGID} minecraft > /dev/null 2>&1
 | 
					  sudo groupmod -g ${PGID} minecraft >/dev/null 2>&1
 | 
				
			||||||
    chown -R ${PUID}:${PGID} /data > /dev/null 2>&1
 | 
					  sudo chown -R ${PUID}:${PGID} /data >/dev/null 2>&1
 | 
				
			||||||
 | 
					  echo "DONE"
 | 
				
			||||||
  sleep 2
 | 
					  sleep 2
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
setperms
 | 
					setperms
 | 
				
			||||||
 | 
					
 | 
				
			||||||
su -c "mc" minecraft
 | 
					mc
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										26
									
								
								scripts/mc
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								scripts/mc
									
									
									
									
									
								
							@@ -1,14 +1,14 @@
 | 
				
			|||||||
#!/bin/env bash
 | 
					#!/bin/env bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
MC_LOADER="${MC_LOADER:="paper"}"
 | 
					MC_LOADER="${MC_LOADER:-"paper"}"
 | 
				
			||||||
MC_VERSION=${MC_VERSION:="1.21.4"}
 | 
					MC_VERSION=${MC_VERSION:-"1.21.4"}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
JAVA_VERSION=${JAVA_VERSION:="temurin@21"}
 | 
					JAVA_VERSION=${JAVA_VERSION:-"temurin@21"}
 | 
				
			||||||
JAR=${JAR:="server.jar"}
 | 
					JAR=${JAR:-"server.jar"}
 | 
				
			||||||
MEM=${MEMORY:=2G}
 | 
					MEM=${MEMORY:-2G}
 | 
				
			||||||
ADD_ARGS=${ADD_ARGS:=""}
 | 
					ADD_ARGS=${ADD_ARGS:-""}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
RESTART=${RESTART:="true"}
 | 
					RESTART=${RESTART:-"true"}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
crash() {
 | 
					crash() {
 | 
				
			||||||
  sleep 5
 | 
					  sleep 5
 | 
				
			||||||
@@ -22,7 +22,7 @@ setEula() {
 | 
				
			|||||||
  fi
 | 
					  fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
javaCheck(){
 | 
					javaCheck() {
 | 
				
			||||||
  JAVA_HOME=/data/java/${JAVA_VERSION}
 | 
					  JAVA_HOME=/data/java/${JAVA_VERSION}
 | 
				
			||||||
  if [[ -f "$HOME/.jabba/jabba.sh" ]]; then
 | 
					  if [[ -f "$HOME/.jabba/jabba.sh" ]]; then
 | 
				
			||||||
    source $HOME/.jabba/jabba.sh
 | 
					    source $HOME/.jabba/jabba.sh
 | 
				
			||||||
@@ -62,7 +62,7 @@ getPaper() {
 | 
				
			|||||||
  fi
 | 
					  fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
getFabric(){
 | 
					getFabric() {
 | 
				
			||||||
  LATEST_BUILD=$(curl -s https://meta.fabricmc.net/v2/versions/loader/${MC_VERSION} | jq -s '.[] .[0] .loader .version' | tr -d '"')
 | 
					  LATEST_BUILD=$(curl -s https://meta.fabricmc.net/v2/versions/loader/${MC_VERSION} | jq -s '.[] .[0] .loader .version' | tr -d '"')
 | 
				
			||||||
  LATEST_INSTALLER=$(curl -s https://maven.fabricmc.net/net/fabricmc/fabric-installer/maven-metadata.xml | xmllint --xpath "/metadata/versioning/latest/text()" -)
 | 
					  LATEST_INSTALLER=$(curl -s https://maven.fabricmc.net/net/fabricmc/fabric-installer/maven-metadata.xml | xmllint --xpath "/metadata/versioning/latest/text()" -)
 | 
				
			||||||
  DL_URL=https://meta.fabricmc.net/v2/versions/loader/${MC_VERSION}/${LATEST_BUILD}/${LATEST_INSTALLER}/server/jar
 | 
					  DL_URL=https://meta.fabricmc.net/v2/versions/loader/${MC_VERSION}/${LATEST_BUILD}/${LATEST_INSTALLER}/server/jar
 | 
				
			||||||
@@ -75,7 +75,7 @@ getFabric(){
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
getForge(){
 | 
					getForge() {
 | 
				
			||||||
  LATEST_BUILD=$(curl -s https://files.minecraftforge.net/net/minecraftforge/forge/promotions_slim.json | jq -r ".promos[\"${MC_VERSION}-latest\"]")
 | 
					  LATEST_BUILD=$(curl -s https://files.minecraftforge.net/net/minecraftforge/forge/promotions_slim.json | jq -r ".promos[\"${MC_VERSION}-latest\"]")
 | 
				
			||||||
  DL_BUILD=${MC_VERSION}-${LATEST_BUILD}
 | 
					  DL_BUILD=${MC_VERSION}-${LATEST_BUILD}
 | 
				
			||||||
  DL_URL=https://maven.minecraftforge.net/net/minecraftforge/forge/$DL_BUILD/forge-$DL_BUILD-installer.jar
 | 
					  DL_URL=https://maven.minecraftforge.net/net/minecraftforge/forge/$DL_BUILD/forge-$DL_BUILD-installer.jar
 | 
				
			||||||
@@ -98,7 +98,7 @@ getForge(){
 | 
				
			|||||||
  fi
 | 
					  fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
serverSelect(){
 | 
					serverSelect() {
 | 
				
			||||||
  mkdir -p /data/server
 | 
					  mkdir -p /data/server
 | 
				
			||||||
  cd /data/server
 | 
					  cd /data/server
 | 
				
			||||||
  if [[ ! -f server.jar ]]; then
 | 
					  if [[ ! -f server.jar ]]; then
 | 
				
			||||||
@@ -123,7 +123,7 @@ serverSelect(){
 | 
				
			|||||||
  fi
 | 
					  fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
buildCommand(){
 | 
					buildCommand() {
 | 
				
			||||||
  JAVA_ARGS="-Xms${MEM} -Xmx${MEM}"
 | 
					  JAVA_ARGS="-Xms${MEM} -Xmx${MEM}"
 | 
				
			||||||
  if [[ -z ${ADD_ARGS+x} ]]; then
 | 
					  if [[ -z ${ADD_ARGS+x} ]]; then
 | 
				
			||||||
    RUN_STRING="${ADD_ARGS} ${JAVA_ARGS} -jar ${JAR} nogui"
 | 
					    RUN_STRING="${ADD_ARGS} ${JAVA_ARGS} -jar ${JAR} nogui"
 | 
				
			||||||
@@ -132,7 +132,7 @@ buildCommand(){
 | 
				
			|||||||
  fi
 | 
					  fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
runServer(){
 | 
					runServer() {
 | 
				
			||||||
  setEula
 | 
					  setEula
 | 
				
			||||||
  while true; do
 | 
					  while true; do
 | 
				
			||||||
    if [[ -f $JAR ]]; then
 | 
					    if [[ -f $JAR ]]; then
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user