Includes both the authentication and secure servers
Install Go and git, then clone and enter the repository
$ git clone https://github.com/PretendoNetwork/minecraft-wiiu
$ cd minecraft
To compile using Go, go get
the required modules and then go build
to your desired location. You may also want to tidy the go modules, though this is optional
$ go get -u
$ go mod tidy
$ go build -o build/minecraft
The server is now built to build/minecraft
When compiling with only Go, the authentication servers build string is not automatically set. This should not cause any issues with gameplay, but it means that the server build will not be visible in any packet dumps or logs a title may produce
To compile the servers with the authentication server build string, add -ldflags "-X 'main.serverBuildString=BUILD_STRING_HERE'"
to the build command, or use make
to compile the server
Compiling using make
will read the local .git
directory to create a dynamic authentication server build string, based on your repositories remote origin and current commit. It will also use the current folders name as the executables name
Install make
onto your system (this varies by OS), and run make
while inside the repository
$ make
The server is now built to build/minecraft
with the authentication server build string already set
This server depends on nex-protocols-common-go, nex-protocols-go, and nex-go to implement the bulk of its functionality. Sometimes features or bugfixes depend on unreleased development versions of these libraries; or changes have to be made at the library level to work on this server.
To use these unreleased libraries, add a go.work
file with something like the following content:
go 1.21
use (
.
)
replace (
github.com/PretendoNetwork/nex-go/v2 => ../nex-go
github.com/PretendoNetwork/nex-protocols-go/v2 => ../nex-protocols-go
github.com/PretendoNetwork/nex-protocols-common-go/v2 => ../nex-protocols-common-go
)
The build will then build these libraries out of the folders specified instead of pulling the released versions.
All configuration options are handled via environment variables
.env
files are supported
Name | Description | Required |
---|---|---|
PN_MINECRAFT_KERBEROS_PASSWORD |
Password used as part of the internal server data in Kerberos tickets | No (Default password password will be used) |
PN_MINECRAFT_AUTHENTICATION_SERVER_PORT |
Port for the authentication server | Yes |
PN_MINECRAFT_SECURE_SERVER_HOST |
Host name for the secure server (should point to the same address as the authentication server) | Yes |
PN_MINECRAFT_SECURE_SERVER_PORT |
Port for the secure server | Yes |
PN_MINECRAFT_ACCOUNT_GRPC_HOST |
Host name for your account server gRPC service | Yes |
PN_MINECRAFT_ACCOUNT_GRPC_PORT |
Port for your account server gRPC service | Yes |
PN_MINECRAFT_ACCOUNT_GRPC_API_KEY |
API key for your account server gRPC service | No (Assumed to be an open gRPC API) |
PN_MINECRAFT_FRIENDS_GRPC_HOST |
Host name for Friends gRPC service (used for friends matchmaking) | Yes |
PN_MINECRAFT_FRIENDS_GRPC_PORT |
Port for Friends gRPC service | Yes |
PN_MINECRAFT_FRIENDS_GRPC_API_KEY |
API key for Friends gRPC service | No (Assumed to be an open gRPC API) |
PN_MINECRAFT_ALLOW_PUBLIC_MATCHMAKING |
Set to "1" to enable public matchmaking (unsafe - game has 0 anti-cheat) | No (Assumed 0) |