This document is intended to exhibit the variety of use cases Drasl can support. Each example includes a complete configuration file and may be used as a starting place to configure your own instance.
See configuration.md for detailed documentation of each config option.
- Private and standalone: does not interact with any other API servers
- Registering a new account requires an invite from an admin
- Users can choose their player's UUID when they register, useful for migrating from Mojang accounts
Domain = "drasl.example.com" # CHANGE ME!
BaseURL = "https://drasl.example.com" # CHANGE ME!
DefaultAdmins = ["myusername"] # CHANGE ME!
[RegistrationNewPlayer]
Allow = true
AllowChoosingUUID = true
RequireInvite = true
- Users can register a new account only if they verify ownership of a Mojang account. Their account will be assigned the UUID of the Mojang account, so servers will see them as the same player. (
RegistrationExistingPlayer
,RegistrationExistingPlayer.RequireSkinVerification
). - Clients logged in with either Drasl or Mojang will be able to play on the same server (
FallbackAPIServers
,ForwardSkins
). - Drasl players will be able to see Mojang players' skins (but not vice-versa) (
[[FallbackAPIServers]]
,ForwardSkins
). - Useful for public instances wanting to limit registration.
Show config.toml
Domain = "drasl.example.com" # CHANGE ME!
BaseURL = "https://drasl.example.com" # CHANGE ME!
DefaultAdmins = ["myusername"] # CHANGE ME!
ForwardSkins = true
AllowChangingPlayerName = false
[RegistrationNewPlayer]
Allow = false
[RegistrationExistingPlayer]
Allow = true
Nickname = "Mojang"
SessionURL = "https://sessionserver.mojang.com"
AccountURL = "https://api.mojang.com"
SetSkinURL = "https://www.minecraft.net/msaprofile/mygames/editskin"
RequireSkinVerification = true
[[FallbackAPIServers]]
Nickname = "Mojang"
SessionURL = "https://sessionserver.mojang.com"
AccountURL = "https://api.mojang.com"
ServicesURL = "https://api.minecraftservices.com"
SkinDomains = ["textures.minecraft.net"]
CacheTTLSeconds = 60
- Allow users to authenticate with either an Ely.by account or a Blessing Skin account (
[[FallbackAPIServers]]
) - Players logged in with Ely.by unfortunately won't see the skins of players logged in with Blessing Skin, and vice versa. You might be able to fix that by using CustomSkinLoader to have the clients load skins through Drasl.
- Registration is disabled (
RegistrationNewPlayer.Allow
) - Warning: Fallback API Servers are tried in the order they are listed in the config file. A malicious user may be able to impersonate a user on the second-listed Fallback API Server by making an account on the first-listed Fallback API Server with the same username (or possibly even the same UUID).
Show config.toml
Domain = "drasl.example.com" # CHANGE ME!
BaseURL = "https://drasl.example.com" # CHANGE ME!
DefaultAdmins = ["myusername"] # CHANGE ME!
[RegistrationNewPlayer]
Allow = false
[[FallbackAPIServers]]
Nickname = "Ely.by"
SessionURL = "https://account.ely.by/api/authlib-injector/sessionserver"
AccountURL = "https://account.ely.by/api"
ServicesURL = "https://account.ely.by/api/authlib-injector/minecraftservices"
SkinDomains = ["ely.by", ".ely.by"]
CacheTTLSeconds = 60
[[FallbackAPIServers]]
Nickname = "Blessing Skin"
SessionURL = "https://skin.example.net/api/yggdrasil/sessionserver"
AccountURL = "https://skin.example.net/api/yggdrasil/api"
ServicesURL = "https://skin.example.net/api/yggdrasl/minecraftservices"
SkinDomains = ["skin.example.net"]
CacheTTLSeconds = 60
- Basic setup, but add a random, secret suffix to the
BaseURL
to limit unwanted access. Everything still works even if/
is not the root of the API.
Show config.toml
Domain = "drasl.example.com" # CHANGE ME!
BaseURL = "https://drasl.example.com/jaek7iNe # CHANGE ME!
DefaultAdmins = ["myusername"] # CHANGE ME!
[RegistrationNewPlayer]
Allow = true
AllowChoosingUUID = true
RequireInvite = true
Note for fallback servers implementing the authlib-injector API: authlib-injector provides the Session
, Account
, and Services
all under one API route. To find the SessionURL
, AccountURL
, and ServicesURL
of an authlib-injector-compatible server hosted at https://example.com:
- Get the canonical authlib-injector API location:
curl --head https://example.com | grep x-authlib-injector-api-location
- Let's say the authlib-injector API location was https://example.com/api/authlib-injector. Then your URLs would be:
SessionURL
: https://example.com/api/authlib-injector/sessionserverAccountURL
: https://example.com/api/authlib-injector/apiServicesURL
: https://example.com/api/authlib-injector/minecraftservices
- The skin domains should be listed at root of the API (https://example.com/api/authlib-injector).
[[FallbackAPIServers]]
Nickname = "Mojang"
SessionURL = "https://sessionserver.mojang.com"
AccountURL = "https://api.mojang.com"
ServicesURL = "https://api.minecraftservices.com"
SkinDomains = ["textures.minecraft.net"]
CacheTTLSeconds = 60
[RegistrationExistingPlayer]
Allow = true
Nickname = "Mojang"
SessionURL = "https://sessionserver.mojang.com"
AccountURL = "https://api.mojang.com"
SetSkinURL = "https://www.minecraft.net/msaprofile/mygames/editskin"
[[FallbackAPIServers]]
Nickname = "Ely.by"
SessionURL = "https://authserver.ely.by/api/authlib-injector/sessionserver"
AccountURL = "https://authserver.ely.by/api"
ServicesURL = "https://authserver.ely.by/api/authlib-injector/minecraftservices"
SkinDomains = ["ely.by", ".ely.by"]
CacheTTLSeconds = 60
[RegistrationExistingPlayer]
Allow = true
Nickname = "Ely.by"
SessionURL = "https://authserver.ely.by/api/authlib-injector/sessionserver"
AccountURL = "https://authserver.ely.by/api"
SetSkinURL = "https://ely.by/skins/add"
# For a Blessing Skin instance hosted at `skin.example.com`:
[[FallbackAPIServers]]
Nickname = "Blessing Skin"
SessionURL = "https://skin.example.com/api/yggdrasil/sessionserver"
AccountURL = "https://skin.example.com/api/yggdrasil/api"
ServicesURL = "https://skin.example.com/api/yggdrasl/minecraftservices"
SkinDomains = ["skin.example.com"]
CacheTTLSeconds = 60
[RegistrationExistingPlayer]
Allow = true
Nickname = "Blessing Skin"
SessionURL = "https://skin.example.com/api/yggdrasil/sessionserver"
AccountURL = "https://skin.example.com/api/yggdrasil/api"
SetSkinURL = "https://skin.example.com/skinlib/upload"