mc-beta-server/server/server.js

114 lines
3.2 KiB
JavaScript
Raw Normal View History

2021-08-12 04:58:56 +01:00
const bufferStuff = require("./bufferStuff.js");
const ChunkManager = require("./chunkManager.js");
const User = require("./user.js");
const PacketMappingTable = require("./PacketMappingTable.js");
const NamedPackets = require("./NamedPackets.js");
2021-08-11 15:05:14 +01:00
2021-08-12 01:44:18 +01:00
const Socket = require("net").Socket;
2021-08-12 04:58:56 +01:00
const uuid = require("uuid").v4;
let idPool = 1;
global.fromIDPool = function() {
const oldVal = idPool;
idPool++;
return oldVal;
}
let netUsers = {},
netUserKeys = Object.keys(netUsers);
function addUser(socket) {
let user = new User(global.fromIDPool(), socket);
netUsers[user.id] = user;
netUserKeys = Object.keys(netUsers);
return user;
}
function removeUser() {
}
let config = {};
let entities = {};
global.chunkManager = new ChunkManager();
let tickInterval, tickCounter = BigInt(0);
let tickRate = BigInt(20);
2021-08-11 15:05:14 +01:00
2021-08-12 01:44:18 +01:00
module.exports.init = function(config) {
2021-08-12 04:58:56 +01:00
config = config;
2021-08-12 01:44:18 +01:00
console.log(`Up! Running at 0.0.0.0:${config.port}`);
2021-08-12 04:58:56 +01:00
tickInterval = setInterval(() => {
for (let key of netUserKeys) {
const user = netUsers[netUserKeys];
let itemsToRemove = [];
for (let i = 0; i < Math.min(user.chunksToSend.getLength(), 128); i++) {
const chunkKey = user.chunksToSend.itemKeys[i];
itemsToRemove.push(chunkKey);
user.socket.write(user.chunksToSend.items[chunkKey]);
}
for (let item of itemsToRemove) {
user.chunksToSend.remove(item, false);
}
user.chunksToSend.regenerateIterableArray();
}
tickCounter++;
}, 1000 / parseInt(tickRate.toString()));
2021-08-12 01:44:18 +01:00
}
module.exports.connection = function(socket = new Socket) {
2021-08-12 04:58:56 +01:00
const thisUser = addUser(socket);
2021-08-12 01:44:18 +01:00
socket.on('data', function(chunk) {
2021-08-12 04:58:56 +01:00
const reader = new bufferStuff.Reader(chunk);
switch(reader.readByte()) {
case NamedPackets.KeepAlive:
socket.write(new PacketMappingTable[NamedPackets.KeepAlive]().writePacket());
break;
case NamedPackets.LoginRequest:
socket.write(new PacketMappingTable[NamedPackets.LoginRequest](reader.readInt(), reader.readString(), reader.readLong(), reader.readByte()).writePacket(thisUser.id));
socket.write(new PacketMappingTable[NamedPackets.SpawnPosition]().writePacket());
for (let x = -3; x < 4; x++) {
for (let z = -3; z < 4; z++) {
socket.write(new PacketMappingTable[NamedPackets.PreChunk](x, z, true).writePacket());
global.chunkManager.multiBlockChunk(x, z, thisUser);
}
}
socket.write(new PacketMappingTable[NamedPackets.BlockChange](8, 64, 8, 20, 0).writePacket());
socket.write(new PacketMappingTable[NamedPackets.Player](true).writePacket());
socket.write(new PacketMappingTable[NamedPackets.ChatMessage](`\u00A7e${thisUser.username} has joined the game`).writePacket());
socket.write(new PacketMappingTable[NamedPackets.PlayerPositionAndLook](8.5, 65 + 1.6200000047683716, 65, 8.5, 0, 0, false).writePacket());
thisUser.loginFinished = true;
break;
case NamedPackets.Handshake:
thisUser.username = reader.readString();
socket.write(new PacketMappingTable[NamedPackets.Handshake](thisUser.username).writePacket());
break;
}
2021-08-12 01:44:18 +01:00
});
socket.on('end', function() {
console.log("Connection closed");
});
socket.on('error', function(err) {
console.log("Connection error!");
});
2021-08-11 15:05:14 +01:00
}