Skip to content
/ mcpews Public
forked from mcpews/mcpews

A library that supports MCPE Websocket Protocol

License

Notifications You must be signed in to change notification settings

soumame/mcpews

 
 

Repository files navigation

MCPEWS

A library that supports MCPE Websocket Protocol.

Usage

Server-side:

import { WSServer, Version } from 'mcpews';
const server = new WSServer(19134); // port

server.on('client', ({ session }) => {
    // someone type "/connect <ip address>:19134" in the game console

    // execute a command
    session.sendCommand('say Connected!');

    // execute a command and receive the response
    session.sendCommand('list', ({ body }) => {
        console.log(`currentPlayerCount = ${body.currentPlayerCount}`);
    });

    // subscribe a event
    session.subscribe('PlayerMessage', (event) => {
        // when event triggered
        const { body, version } = event;
        let message, messageType;
        if (version === Version.V1_1_0) {
            message = body.message;
            messageType = body.type;
        } else {
            message = body.properties.Message;
            messageType = body.properties.MessageType;
        }
        if (message === 'close') {
            // disconnect from the game
            session.disconnect();
        } else if (messageType === 'chat') {
            session.sendCommand('say You just said ' + message);
        }
    });

    // enable encrypted connection
    session.enableEncryption();
});

Client-side:

import { WSClient } from "mcpews";
const client = new WSClient('ws://127.0.0.1:19134'); // address

process.stdin.on('data', (buffer) => {
    // trigger a event (will be ignored if not subscribed)
    client.publishEvent('input', {
        data: buffer.toString()
    });
});

client.on('command', (event) => {
    const { commandLine } = event;

    // pass encryption handshake to client itself
    if (event.handleEncryptionHandshake()) return;

    // command received
    console.log('command: ' + commandLine);

    // respond the command, must be called after handling
    event.respond({
        length: commandLine.length
    });
});

WSApp, optimized for async/await:

import { WSApp } from "mcpews";

const app = new WSApp(19134);
app.on('session', async ({ session }) => {
    const playerNames = (await session.command('testfor @a')).body.victim;
    const names = await Promise.all(
        playerNames.map(async (playerName) => {
            await session.command(`tell ${playerName} What's your name?`);
            try {
                const name = (await session.waitForEvent('PlayerMessage', 30000, (ev) => ev.body.sender === playerName))
                    .body.message;
                await session.command(`tell ${playerName} Your name is ${name}`);
                return name;
            } catch (err) {
                return playerName;
            }
        })
    );
    console.log(names);
    await session.disconnect();
});

REPL:

mcpews [<custom port>]

MITM:

mcpewsmitm <destination address> [<listen port>]

About

A library that supports MCPE Websocket Protocol

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 83.9%
  • JavaScript 16.1%