Important
This server is still in development and is not ready for production use. Breaking changes may occur at any time.
This server is made for serving Luanti skins to Luanti servers. It is licensed under GPLv3.
- ✅ Easy to use and powerful API
- ✅ Skins compatible with both VoxeLibre and Minetest Game
- ✅ Fast and reliable, thanks to Docker, Golang, Fiber and PostgreSQL
- ✅ Optimised images using Oxipng
The server is build with the Go language on-top of the Fiber framework.
It uses also the GORM library for interacting with the database.
The frontend is build with the React library, the Vite framework and the following libraries:
- TailwindCSS for styling
- HeadlessUI for dialogs, combobox, etc
- Heroicons for most icons
- React Router
- React Three Fiber for the 3D preview of skins
Follow the official guide for your OS.
Note
The installation links are from Docker Engine, which works only under Linux.
Docker Desktop can be used on Windows, MacOS and Linux.
It runs a Linux VM in the background and isn't as performant as the native version, but it's easier to install and use.
Warning
You need a BuildKit enabled version of Docker to build the image.
git clone https://github.com/AFCMS/luanti-skin-server && cd luanti-skin-server
cp exemple.env .env
Edit the .env
file with the config you want.
A typical production config would be:
MT_SKIN_SERVER_DATABASE_LOGGING=false
MT_SKIN_SERVER_ENABLE_OPTIPNG=true
MT_SKIN_SERVER_DB_HOST=db
MT_SKIN_SERVER_DB_USER=user
MT_SKIN_SERVER_DB_PASSWORD=azerty
MT_SKIN_SERVER_DB_PORT=5432
MT_SKIN_SERVER_DB_NAME=skin_server
docker compose -f compose.dev.yml up --build
You will now have access to the app (both frontend and API) at http://localhost:8080
. Doing changes to the frontend
files will trigger fast refresh without needing to restart the entire app.
It's possible to run the server without Docker, but it's not recommended.
Follow the official guides for you OS.
I recommend using NodeJS v20 installed using nvm under linux.
If you want to enable Oxipng, you need to install it.
git clone https://github.com/AFCMS/luanti-skin-server && cd luanti-skin-server
go mod download
cd frontend && npm install --include=dev && cd ..
cp exemple.env .env
Edit the .env
file with the config you want.
A typical development config would be:
MT_SKIN_SERVER_DATABASE_LOGGING=false
MT_SKIN_SERVER_ENABLE_OPTIPNG=true
MT_SKIN_SERVER_DB_HOST=db
MT_SKIN_SERVER_DB_USER=user
MT_SKIN_SERVER_DB_PASSWORD=azerty
MT_SKIN_SERVER_DB_PORT=5432
MT_SKIN_SERVER_DB_NAME=skin_server
You need a PostgreSQL database running on the given host and port.
The frontend served by the Fiber backend can be build before running the app and served statically, the Vite development server can also be proxied by the backend to avoid rebuilding everytime.
Static files can be built like this before launching the server:
cd frontend && npm run build && cd ..
If you want to use Vite's development server, you can run it like this:
cd frontend && npm run dev
With the following additional configuration in the .env
file:
MT_SKIN_SERVER_FRONTEND_DEV_MODE=true
MT_SKIN_SERVER_FRONTEND_URL=http://localhost:5173
Caution
The Vite server configuation makes it exposed on your local network by default to make it accessible in Docker, you can change this behaviour in the Vite configuration.
go build && ./luanti-skin-server
There is an exemple production Docker Compose file in the repository.
It uses the production image built
by the GitHub Actions workflow, which supports amd64
and arm64
architectures.
docker pull ghcr.io/afcms/luanti-skin-server:master
docker compose -f compose.prod.yml up
You can verify that the image have been really built by the GitHub Actions workflow and find the build log using the GitHub CLI:
gh attestation verify oci://ghcr.io/afcms/luanti-skin-server:master --repo AFCMS/luanti-skin-server
For production the server supports some more configuration variables.
The server can use the HTML tag verification method for the Google Search Console (URL prefix).
You can set the MT_SKIN_SERVER_VERIFICATION_GOOGLE_SEARCH_CONSOLE
environment variable to Google's verification token.
You can also use the DNS record method if you want, please checkout Google's documentation for more information.
The server supports OAuth2 for authentication, you can set the following environment variables to enable it.
If one of the two variables (client id, client secret) for a provider are not set, OAuth2 will be disabled for that provider.
MT_SKIN_SERVER_OAUTH_REDIRECT_HOST
: the host where the OAuth2 callback will be redirected to- ContentDB:
MT_SKIN_SERVER_OAUTH_CONTENTDB_CLIENT_ID
: the OAuth2 client ID for the ContentDB APIMT_SKIN_SERVER_OAUTH_CONTENTDB_CLIENT_SECRET
the OAuth2 client secret for the ContentDB APIMT_SKIN_SERVER_OAUTH_CONTENTDB_URL
: the URL of the ContentDB instance, default tohttps://content.luanti.org
- Create Application
- GitHub:
MT_SKIN_SERVER_OAUTH_GITHUB_CLIENT_ID
: the OAuth2 client ID for the GitHub APIMT_SKIN_SERVER_OAUTH_GITHUB_CLIENT_SECRET
the OAuth2 client secret for the GitHub API- Create Application
I recommand using either VSCode or GoLand.
There are multiple VSCode extensions marked as recommended for the workspace.