Parse and serialize minecraft packets, plus authentication and encryption.
Find a file
2013-01-02 01:47:18 -05:00
test test passing: connects successfully - online mode 2013-01-02 01:12:42 -05:00
.gitignore getting encryption request 2012-12-31 20:33:35 -05:00
index.js test passing: connects successfully - online mode 2013-01-02 01:12:42 -05:00
package.json test passing: connects successfully - online mode 2013-01-02 01:12:42 -05:00
packets.json refactor into nice npm module. closes #7 2013-01-01 23:39:31 -05:00
README.md add a new section to README 2013-01-02 01:47:18 -05:00

minecraft protocol

Parse and serialize minecraft packets, plus authentication and encryption.

Features

  • Parses all packets and emits packet events with packet fields as JavaScript objects.
  • Send a packet by supplying fields as a JavaScript object.
  • Supports authenticating and logging in.
    • Supports encryption enabled
    • Supports encryption disabled (TODO #2)
    • Supports online mode
    • Supports offline mode (TODO #1)
  • Send keep-alive packet at the correct interval.
  • Reasonable amount of test coverage (TODO #3)
  • Optimized for rapidly staying up to date with Minecraft protocol updates.

Minecraft Compatibility

Supports Minecraft version 1.4.6

Usage

Echo example

Listen for chat messages and echo them back.

var mc = require('minecraft-protocol');
var client = mc.createClient({
  host: "localhost", // optional
  port: 25565,       // optional
  username: "player",
  email: "email@example.com", // email and password are required only for
  password: "12345678",       // encrypted and online servers
});
client.on('packet', function(packet) {
  if (packet.id !== 0x03) return;
  if (packet.message.indexOf(client.session.username) !== -1) return;
  client.writePacket(0x03, {
    message: packet.message,
  });
});

Testing

  • Ensure your system has the java executable in PATH.
  • Download the appropriate version of minecraft_server.jar.
  • MC_SERVER_JAR=path/to/minecraft_server.jar MC_USERNAME=username MC_EMAIL=email@example.com MC_PASSWORD=password npm test

Updating to a newer protocol version

In most cases you should only have to do the following:

  1. In packets.json:
  • Update protocolVersion to the correct number.
  • Edit the data structure to reflect the new packet layout.
  1. Update the "Minecraft Compatibility" section above in this README.
  2. Run the test suite to make sure everything still works. See "Testing" above.