Wawel Auth
ModAuthentication mod for Minecraft 1.7.10.
Type
Mod
Modrinth Downloads
69
Modrinth ID
LncX1fVM
Last Updated
May 31, 2026
Description
Wawel Auth

Authentication mod for Minecraft 1.7.10. Use Microsoft or any Yggdrasil-compatible provider, or run your own auth server alongside the game server. Includes modern and HD skins, animated capes, and optional 3D skin layers.
Some highlights of what Wawel Auth allows you to do:
- Login into any Yggdrasil-compatible provider on the client (Microsoft, ely.by, drasl, ...)
- Bind accounts to servers
- Host an account and skin provider directly on the game server
- Allow any Yggdrasil-compatible provider to join your server
- Modern and HD skin support
- Animated capes for Wawel Auth accounts
- 3D skin layers implementation
- Admin web UI for server-side management
Wawel Auth does not need to be installed on the client, nor on the server to benefit from a lot of features. You can setup a server that allows Microsoft and ely.by users, without clients having to do anything special. Clients can also benefit from account management, modern skins, and 3d skin layers, even if a server doesn't run Wawel Auth.

Dependencies
- UniMixins

- FentLib

- ModularUI2
(Client only)
[!NOTE] Each release also includes a nodep jar. It does not ship sqlite-jdbc or Bouncy Castle, and relies on FalsePatternLib
![]()
![]()
to supply them.
Client Setup And Use
Wawel Auth stores a small Minecraft instance-bound config file under config/wawelauth/local.json. Most other settings, however, are shared across all Minecraft instances (can be disabled using useOsConfigDir). Those settings live in files stored under the following locations:
- Windows: %APPDATA%/wawelauth/
- macOS: ~/Library/Application Support/wawelauth/
- Linux: $XDG_DATA_HOME/wawelauth/ or ~/.local/share/wawelauth/
The main menu is opened with the Auth button in the multiplayer screen. From there, you can add auth providers, and accounts.
Some things of note:
- Microsoft, Ely.by, and LittleSkin providers are built in.
- Any Yggdrasil / authlib-injector provider can be added by URL.
- The Manage Local Auth... button is the quickest way to use local accounts on a Wawel Auth server.
- Adding the same local server manually as a normal provider is also supported.
- Skin management buttons can be suppressed per provider through client.json, in the case a provider does not provide these functions. This is purely cosmetic.
The following options let you configure this:
- disableSkinUpload
- disableCapeUpload
- disableTextureReset
The disable* lists are regexes matched against provider name or API root.
- Animated capes are only supported by Wawel Auth servers, and are in the minecraftcapes.net format.
[!NOTE] You can also drag and drop skins and capes, if using Java 17+.
Server Setup And Use
Files and locations
- Dedicated servers always use config/wawelauth/ to store their config, and state data
- That state directory contains the SQLite database, generated keys, and stored textures
[!WARNING]
- Your private server key is sensitive information, never share it.
- It is important to not change your server keys, if not absolutely necessary. Wawel Auth client users will need to trust the key again, and authlib-injector users will refuse to connect to a server whose public key has changed.
Example local-only setup
server.json
{ "wawelAuthEnabled": true, "serverName": "My WawelAuth Server", "publicBaseUrl": "auth.example.com:25565", "apiRoot": "auth", "admin": { "enabled": true, "token": "strong_password_best_if_randomly_generated" } }- set online-mode=true in server.properties
- set publicBaseUrl to the real public base URL clients use
- leave apiRoot as a relative path such as auth
- set an admin token through server.admin.token or WAWELAUTH_ADMIN_TOKEN
- restart the server
Notes:
- if publicBaseUrl has no scheme, Wawel Auth assumes http://
- with the example above, the auth API is published at http://auth.example.com:25565/auth
- on dedicated servers, Wawel Auth now hard-stops before world load if online-mode=false, publicBaseUrl is missing, or apiRoot is configured as a full URL
- for CI smoke tests only, WAWELAUTH_CI=true or GITHUB_ACTIONS=true bypasses the missing-publicBaseUrl hard stop
Important server settings
- registration.policy: OPEN, INVITE_ONLY, CLOSED
- textures: max skin / cape dimensions, file limits, animated cape limits
- http: same-port HTTPS enable flag, HTTP read timeout, TLS handshake timeout, and max request body size
- admin: web UI enable flag, login token, session TTL
Admin web UI
If server.admin.enabled=true, the admin UI is available at:
- https://your-host:your-port/admin when server.http.httpsEnabled=true (default)
- http://your-host:your-port/admin for bootstrap/status only; login requires HTTPS
It manages users, textures, invites, whitelist, ops, server.json, and server.properties. Same-port HTTPS uses a self-signed certificate generated in WawelAuth's data directory; verify the SHA-256 fingerprint printed in the server log when accepting the browser warning.
Fallback providers
Fallback providers are defined in fallback-servers.json and checked in order.
{ "fallbackServers": [ ... ] }[!WARNING] name must not contain whitespaces.
[!TIP] name is used in provider-scoped commands such as /op player@provider.
Microsoft fallback example
{ "name": "mojang", "sessionServerUrl": "https://sessionserver.mojang.com", "accountUrl": "https://authserver.mojang.com", "servicesUrl": "https://api.minecraftservices.com", "skinDomains": [ ".minecraft.net", ".mojang.com" ], "cacheTtlSeconds": 300 }Ely.by fallback example
{ "name": "ely.by", "sessionServerUrl": "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": 300 }LittleSkin fallback example
{ "enabled": true, "name": "littleskin", "apiRoot": "https://littleskin.cn/api/yggdrasil", "sessionServerUrl": "https://littleskin.cn/api/yggdrasil/sessionserver", "accountUrl": "https://littleskin.cn/api/yggdrasil/authserver", "servicesUrl": "https://littleskin.cn/api/yggdrasil", "signaturePublicKeyBase64": "", "skinDomains": [ "littleskin.cn" ], "cacheTtlSeconds": 300 }Commands
/wawelauth
- /wawelauth register <username> <password>
- /wawelauth invite create [uses|unlimited]
- /wawelauth invite list
- /wawelauth invite delete <code>
- /wawelauth invite purge
- /wawelauth test
Provider-qualified whitelist and op commands
- /whitelist add <username>@<provider>
- /whitelist remove <username>@<provider>
- /op <username>@<provider>
- /deop <username>@<provider>
<provider> is either a fallbackServers[].name or one of the local aliases: local, localauth, wawelauth, self.
Regular whitelist and op commands are disabled.
[!WARNING] Plain authlib-injector clients (or vanilla) can authenticate against a Wawel Auth server, but mixed-provider skin handling only works if the client and server run Wawel Auth.
Interoperability Notes
Building
./gradlew buildCredits
- Skin layer implementation inspired by last MIT commit of 3D Skin Layers Mod
- Catalogue-Vintage for folder icon and system-open inspiration
- GT:NH buildscript
- Background image
License
LGPLv3
Buy me some creatine
- ko-fi.com
- Monero: 893tQ56jWt7czBsqAGPq8J5BDnYVCg2tvKpvwTcMY1LS79iDabopdxoUzNLEZtRTH4ewAcKLJ4DM4V41fvrJGHgeKArxwmJ

Compatibility
Mod Loaders
Game Versions
Screenshots
Similar Mods
FARWORLD
a mod aiming at expanding and padding out vanilla's content to give a truly full adventuring experience!
Lock And Key
Modern Fabric Minecraft mod for Locks, Keys and other things
Cobblemon No Meat
A generated datapack for Cobblemon that removes drops which would imply killing the Pokémon.
Origin Enhanced
A QoL enhancement mod for the Origin Realms server.
Slime Finder
Craft a Slime Dowsing Staff to find slime chunks !
Ex Deorum Expandere
Fork of "Haven Ex Deorum Expansion", updated, new tier(s?) & more





