mirror of
https://github.com/PrismarineJS/node-minecraft-protocol.git
synced 2024-12-12 17:01:02 -05:00
eb5764e7ab
Explanation: in this specific case, we were changing the state of the client to hanshaking (in autoVersion.js) before a connection was made (using setSocket), the consequence is the serializer was already piped to the framer when setSocket was called, and setSocket doesn't unpipe before piping. The consequence of that was the framer was piped 2 times, the packet was sent 2 times and the server kicked us. My solution is piping the serializer to the framer in Client constructor. Then if the state is changed, it will anyway automatically unpipe before repiping. Other places correctly unpipe before piping. Autoversion is now the default in nmp too
32 lines
913 B
JavaScript
32 lines
913 B
JavaScript
'use strict';
|
|
|
|
var mc = require('minecraft-protocol');
|
|
|
|
if(process.argv.length < 4 || process.argv.length > 6) {
|
|
console.log("Usage : node echo.js <host> <port> [<name>] [<password>]");
|
|
process.exit(1);
|
|
}
|
|
|
|
var client = mc.createClient({
|
|
version: false,
|
|
host: process.argv[2],
|
|
port: parseInt(process.argv[3]),
|
|
username: process.argv[4] ? process.argv[4] : "echo",
|
|
password: process.argv[5]
|
|
});
|
|
|
|
client.on('connect', function() {
|
|
console.info('connected');
|
|
});
|
|
client.on('disconnect', function(packet) {
|
|
console.log('disconnected: '+ packet.reason);
|
|
});
|
|
client.on('chat', function(packet) {
|
|
var jsonMsg = JSON.parse(packet.message);
|
|
if(jsonMsg.translate == 'chat.type.announcement' || jsonMsg.translate == 'chat.type.text') {
|
|
var username = jsonMsg.with[0].text;
|
|
var msg = jsonMsg.with[1];
|
|
if(username === client.username) return;
|
|
client.write('chat', {message: msg});
|
|
}
|
|
});
|