Easy to use library for running your HTTP server on the same port as the Minecraft server.
Available for both fabric and paper.
Javadoc is available here
I am hoping to keep this mod supported for 1.19 up to latest.
Players shouldn't ever need to install this mod.
It should be JIJ-ed by mod devs
Add my maven repo to your repositories block:
repositories {
// Others
maven {
name = "OffsetMods538"
url = "https://maven.offsetmonkey538.top/releases"
content {
includeGroup "top.offsetmonkey538.meshlib"
}
}
}
This library is meant to be used as a JIJ (Jar-In-Jar), meaning you include it inside your mod/plugin.
To do that you can use include
for fabric and the shadow gradle plugin for paper:
dependencies {
// For fabric
include modImplementation("top.offsetmonkey538.meshlib:mesh-lib-fabric:1.0.4+1.21.4")
// For paper
implementation "top.offsetmonkey538.meshlib:mesh-lib-paper:1.0.4+1.21.4"
}
Make sure to use the latest version.
Let's write a simple http server that will live at http://server.com:25565/simple-server
and just serve "Hello, World!"
in plain text!
First we'll need the actual HttpHandler
, for that we'll create a new class, let's call it MyHttpHandler
.
This class has to implement the HttpHandler
interface, this will look something like this:
public class MyHttpHandler implements HttpHandler {
@Override
public void handleRequest(@NotNull ChannelHandlerContext ctx, @NotNull FullHttpRequest request) throws Exception {
// Logic will go here
}
}
Now we'll need to actually implement the handler. You can google "HTTP Netty" for more info on how to handle HTTP requests with Netty.
public void handleRequest(@NotNull ChannelHandlerContext ctx, @NotNull FullHttpRequest request) throws Exception {
// Write "Hello, World!" to a buffer, encoded in UTF-8
final ByteBuf content = Unpooled.copiedBuffer("Hello, World!", StandardCharsets.UTF_8);
// Create a response with said buffer
final FullHttpResponse response = new DefaultFullHttpResponse(HTTP_1_1, OK, content);
// Set the "CONTENT_TYPE" header to tell the browser that this is plain text encoded in UTF-8
response.headers().set(CONTENT_TYPE, "text/plain; charset=UTF-8");
// Send the response and close the connection
ctx.writeAndFlush(response).addListener(ChannelFutureListener.CLOSE);
}
Finally, you'll need to actually register your handler. Put this in your mod or plugin initializer:
@Override
public void onInitializeServer() {
// Others
HttpHandlerRegistry.INSTANCE.register("simple-server", new MyHttpHandler());
}
The id is the path that your handler will be able to listen on, in this case server:port/simple-server
. For compatibility reasons, no mod is allowed to occupy the root path.
If you need to listen to multiple paths (server:port/simple-server/test
and server:port/simple-server/test2
), then use request.uri()
inside your handler, do not use simple-server/test
as the id, it will not work.
Now, if you launch the server and try visiting localhost:25565/simple-server
in your browser of choice, you should be greeted with a nice welcome message :D
If not, then come yell at me on my discord.