Crafty 4 is the next iteration of our Minecraft Server Wrapper / Controller / Launcher. Boasting a clean new look, rebuilt from the ground up. Crafty 4 brings a whole host of new features such as Bedrock support. With SteamCMD support on the way!
Go to file
Iain Powrie e4f96f9118 Merge branch 'dev' into 'master'
v4.4.0

See merge request crafty-controller/crafty-4!758
2024-05-11 23:33:52 +00:00
.github Strip meta from sem version 2022-10-08 18:34:38 +01:00
.gitlab Re-tag test jobs to new shared runner standard (GL17) 2024-05-09 20:11:46 +01:00
app Sort unsorted es_ES lang 2024-05-12 00:14:16 +01:00
config_examples Add link to documentation to WSS error 2022-05-23 21:23:29 -04:00
docker adjustment for !672 2023-11-16 18:10:15 +00:00
.dockerignore Add lang sort log to ignore files 2023-10-09 21:27:38 +00:00
.editorconfig Amend editor config for black 2022-03-23 01:53:43 +00:00
.gitignore Add json sort script 2023-12-11 15:15:26 -05:00
.gitlab-ci.yml Add release pipes & CHANGELOG.md 2022-06-16 18:33:57 +01:00
.pylintrc Update overgeneral-exceptions 2023-06-18 15:36:49 +01:00
CHANGELOG.md Update changelog !759 2024-05-11 23:32:20 +01:00
CONTRIBUTING.md Remove beta naming from intro 2023-01-02 14:01:33 -05:00
DBCHANGES.md Update DBCHANGES.md 2021-08-22 10:00:39 +00:00
Dockerfile Add openjdk-21 to docker img 2024-04-07 00:36:10 +01:00
LICENSE Add LICENSE 2022-05-11 12:26:23 +00:00
README.md Close changelog v4.4.0 2024-05-10 21:56:06 +01:00
docker-compose.yml.example Include service restart option 2022-04-15 15:29:59 +00:00
docker_launcher.sh Replace echo with printf to account for environment inconsistencies. 2023-10-08 18:29:28 +01:00
main.py Merge branch 'refactor/big-bucket' of gitlab.com:crafty-controller/crafty-4 into refactor/big-bucket 2024-05-09 17:36:59 -04:00
requirements.txt Bump orjson for CVE-2024-27454 2024-04-06 22:32:14 +01:00
sonar-project.properties Close changelog v4.4.0 2024-05-10 21:56:06 +01:00

README.md

Crafty Logo

Crafty Controller 4.4.0

Python based Control Panel for your Minecraft Server

What is Crafty Controller?

Crafty Controller is a Minecraft Server Control Panel / Launcher. The purpose of Crafty Controller is to launch a Minecraft Server in the background and present a web interface for the server administrators to interact with their servers. Crafty is compatible with Docker, Linux, Windows 7, Windows 8 and Windows 10.

Documentation

Documentation available on Crafty Docs

Meta

Project Homepage - https://craftycontrol.com

Discord Server - https://discord.gg/9VJPhCE

Git Repository - https://gitlab.com/crafty-controller/crafty-4

Docker Hub - arcadiatechnology/crafty-4


Basic Docker Usage 🐳

With Crafty Controller 4.0 we have focused on building our DevOps Principles, implementing build automation, and securing our containers, with the hopes of making our Container user's lives abit easier.

- Two big changes you will notice is:

  • We now provide pre-built images for you guys.
  • Containers now run as non-root, using practices used by OpenShift & Kubernetes (root group perms).

🔻WARNING: [WSL/WSL2 | WINDOWS 11 | DOCKER DESKTOP]🔻
BE ADVISED! Upstream is currently broken for Minecraft running on Docker under WSL/WSL2, Windows 11 / DOCKER DESKTOP!
On 'Stop' or 'Restart' of the MC Server, there is a 90% chance the World's Chunks will be shredded irreparably!
Please only run Docker on Linux, If you are using Windows we have a portable installs found here: Latest-Stable, Latest-Development


- To get started with docker 🛫

All you need to do is pull the image from this git repository's registry. This is done by using 'docker-compose' or 'docker run' (You don't need to clone the Repository and build, like in 3.x ).

If you have a config folder already from previous local installation or docker setup*, the image should mount this volume and fix the permission as required, if no config present then it will populate its own config folder for you.

As the Dockerfile uses the permission structure of crafty:root internally there is no need to worry about matching the UID or GID on the host system :)


- Using the registry image 🌎

The provided image supports both arm64 and amd64 out the box, if you have issues though you can build it yourself with the compose file in docker/.

The image is located at: registry.gitlab.com/crafty-controller/crafty-4:latest or arcadiatechnology/crafty-4

Branch Status
:latest pipeline status
:dev pipeline status

Here are some example methods for getting started🚀:

docker-compose.yml:

# Make your compose file
$ vim docker-compose.yml
version: '3'

services:
  crafty:
    container_name: crafty_container
    image: registry.gitlab.com/crafty-controller/crafty-4:latest
    restart: always
    environment:
      - TZ=Etc/UTC
    ports:
      - "8000:8000" # HTTP
      - "8443:8443" # HTTPS
      - "8123:8123" # DYNMAP
      - "19132:19132/udp" # BEDROCK
      - "25500-25600:25500-25600" # MC SERV PORT RANGE
    volumes:
      - ./docker/backups:/crafty/backups
      - ./docker/logs:/crafty/logs
      - ./docker/servers:/crafty/servers
      - ./docker/config:/crafty/app/config
      - ./docker/import:/crafty/import
$ docker-compose up -d && docker-compose logs -f

docker run:

$ docker run \
	--name crafty_container \
	--detach \
	--restart always \
	-p 8000:8000 \
	-p 8443:8443 \
	-p 8123:8123 \
	-p 19132:19132/udp \
	-p 25500-25600:25500-25600 \
	-e TZ=Etc/UTC \
	-v "/$(pwd)/docker/backups:/crafty/backups" \
	-v "/$(pwd)/docker/logs:/crafty/logs" \
	-v "/$(pwd)/docker/servers:/crafty/servers" \
	-v "/$(pwd)/docker/config:/crafty/app/config" \
	-v "/$(pwd)/docker/import:/crafty/import" \
	registry.gitlab.com/crafty-controller/crafty-4:latest

Building from the cloned repository:

If you are building from docker-compose you can find the compose file in ./docker/docker-compose.yml just cd to the docker directory and docker-compose up -d

If you'd rather not use docker-compose you can use the following docker run in the directory where the Dockerfile is:

# REMEMBER, Build your image first!
$ docker build . -t crafty

$ docker run \
	--name crafty_container \
	--detach \
	--restart always \
	-p 8000:8000 \
	-p 8443:8443 \
	-p 8123:8123 \
	-p 19132:19132/udp \
	-p 25500-25600:25500-25600 \
	-e TZ=Etc/UTC \
	-v "/$(pwd)/docker/backups:/crafty/backups" \
	-v "/$(pwd)/docker/logs:/crafty/logs" \
	-v "/$(pwd)/docker/servers:/crafty/servers" \
	-v "/$(pwd)/docker/config:/crafty/app/config" \
	-v "/$(pwd)/docker/import:/crafty/import" \
	crafty

A fresh build will take several minutes depending on your system, but will be rapid thereafter.