fsdfdsf
This commit is contained in:
parent
c50328818f
commit
1c775cfd60
21 changed files with 690 additions and 17 deletions
41
package-lock.json
generated
Normal file
41
package-lock.json
generated
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
{
|
||||||
|
"name": "mc-beta-server",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"lockfileVersion": 2,
|
||||||
|
"requires": true,
|
||||||
|
"packages": {
|
||||||
|
"": {
|
||||||
|
"version": "1.0.0",
|
||||||
|
"license": "MIT",
|
||||||
|
"dependencies": {
|
||||||
|
"net": "^1.0.2",
|
||||||
|
"uuid": "^8.3.2"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/net": {
|
||||||
|
"version": "1.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/net/-/net-1.0.2.tgz",
|
||||||
|
"integrity": "sha1-0XV+yaf7I3HYPPR1XOPifhCCk4g="
|
||||||
|
},
|
||||||
|
"node_modules/uuid": {
|
||||||
|
"version": "8.3.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
|
||||||
|
"integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==",
|
||||||
|
"bin": {
|
||||||
|
"uuid": "dist/bin/uuid"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"net": {
|
||||||
|
"version": "1.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/net/-/net-1.0.2.tgz",
|
||||||
|
"integrity": "sha1-0XV+yaf7I3HYPPR1XOPifhCCk4g="
|
||||||
|
},
|
||||||
|
"uuid": {
|
||||||
|
"version": "8.3.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
|
||||||
|
"integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg=="
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
22
package.json
Normal file
22
package.json
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
{
|
||||||
|
"name": "mc-beta-server",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "",
|
||||||
|
"main": "index.js",
|
||||||
|
"scripts": {},
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/tgpethan/mc-beta-server.git"
|
||||||
|
},
|
||||||
|
"keywords": [],
|
||||||
|
"author": "",
|
||||||
|
"license": "MIT",
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/tgpethan/mc-beta-server/issues"
|
||||||
|
},
|
||||||
|
"homepage": "https://github.com/tgpethan/mc-beta-server#readme",
|
||||||
|
"dependencies": {
|
||||||
|
"net": "^1.0.2",
|
||||||
|
"uuid": "^8.3.2"
|
||||||
|
}
|
||||||
|
}
|
61
server/NamedPackets.js
Normal file
61
server/NamedPackets.js
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
const namedPackets = {
|
||||||
|
"KeepAlive": 0x00,
|
||||||
|
"LoginRequest": 0x01,
|
||||||
|
"Handshake": 0x02,
|
||||||
|
"ChatMessage": 0x03,
|
||||||
|
"TimeUpdate": 0x04,
|
||||||
|
"EntityEquipment": 0x05,
|
||||||
|
"SpawnPosition": 0x06,
|
||||||
|
"UseEntity": 0x07,
|
||||||
|
"UpdateHealth": 0x08,
|
||||||
|
"Respawn": 0x09,
|
||||||
|
"Player": 0x0A,
|
||||||
|
"PlayerPosition": 0x0B,
|
||||||
|
"PlayerLook": 0x0C,
|
||||||
|
"PlayerPositionAndLook": 0x0D,
|
||||||
|
"PlayerDigging": 0x0E,
|
||||||
|
"PlayerBlockPlacement": 0x0F,
|
||||||
|
"HoldingChange": 0x10,
|
||||||
|
"UseBed": 0x11,
|
||||||
|
"Animation": 0x12,
|
||||||
|
"EntityAction": 0x13,
|
||||||
|
"NamedEntitySpawn": 0x14,
|
||||||
|
"PickupSpawn": 0x15,
|
||||||
|
"CollectItem": 0x16,
|
||||||
|
"AddObjectOrVehicle": 0x17,
|
||||||
|
"MobSpawn": 0x18,
|
||||||
|
"EntityPainting": 0x19,
|
||||||
|
"StanceUpdate": 0x1B,
|
||||||
|
"EntityVelocity": 0x1C,
|
||||||
|
"DestroyEntity": 0x1D,
|
||||||
|
"Entity": 0x1E,
|
||||||
|
"EntityRelativeMove": 0x1F,
|
||||||
|
"EntityLook": 0x20,
|
||||||
|
"EntityLookAndRelativeMove": 0x21,
|
||||||
|
"EntityTeleport": 0x22,
|
||||||
|
"EntityStatus": 0x26,
|
||||||
|
"AttachEntity": 0x27,
|
||||||
|
"EntityMetadata": 0x28,
|
||||||
|
"PreChunk": 0x32,
|
||||||
|
"MapChunk": 0x33,
|
||||||
|
"MultiBlockChange": 0x34,
|
||||||
|
"BlockChange": 0x35,
|
||||||
|
"BlockAction": 0x36,
|
||||||
|
"Explosion": 0x3C,
|
||||||
|
"SoundEffect": 0x3D,
|
||||||
|
"NewOrInvalidState": 0x46,
|
||||||
|
"Thunderbolt": 0x47,
|
||||||
|
"OpenWindow": 0x64,
|
||||||
|
"CloseWindow": 0x65,
|
||||||
|
"WindowClick": 0x66,
|
||||||
|
"SetSlot": 0x67,
|
||||||
|
"WindowItems": 0x68,
|
||||||
|
"UpdateProgressBar": 0x69,
|
||||||
|
"Transaction": 0x6A,
|
||||||
|
"UpdateSign": 0x82,
|
||||||
|
"ItemData": 0x83,
|
||||||
|
"IncrementStatistic": 0xC8,
|
||||||
|
"DisconnectOrKick": 0xFF
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = namedPackets;
|
23
server/PacketMappingTable.js
Normal file
23
server/PacketMappingTable.js
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
const Packet0KeepAlive = require("./Packets/Packet0KeepAlive.js"),
|
||||||
|
Packet1LoginRequest = require("./Packets/Packet1LoginRequest.js"),
|
||||||
|
Packet2Handshake = require("./Packets/Packet2Handshake.js"),
|
||||||
|
Packet3Chat = require("./Packets/Packet3Chat.js"),
|
||||||
|
Packet6SpawnPosition = require("./Packets/Packet6SpawnPosition.js"),
|
||||||
|
Packet10Player = require("./Packets/Packet10Player.js"),
|
||||||
|
Packet13PlayerPositionAndLook = require("./Packets/Packet13PlayerPositionAndLook.js"),
|
||||||
|
Packet50PreChunk = require("./Packets/Packet50PreChunk.js"),
|
||||||
|
Packet53BlockChange = require("./Packets/Packet53BlockChange.js");
|
||||||
|
|
||||||
|
const mappingTable = {
|
||||||
|
0x00: Packet0KeepAlive,
|
||||||
|
0x01: Packet1LoginRequest,
|
||||||
|
0x02: Packet2Handshake,
|
||||||
|
0x03: Packet3Chat,
|
||||||
|
0x06: Packet6SpawnPosition,
|
||||||
|
0x0A: Packet10Player,
|
||||||
|
0x0D: Packet13PlayerPositionAndLook,
|
||||||
|
0x32: Packet50PreChunk,
|
||||||
|
0x35: Packet53BlockChange,
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = mappingTable;
|
|
@ -1,13 +1,21 @@
|
||||||
|
const bufferStuff = require("../bufferStuff.js");
|
||||||
|
|
||||||
module.exports = class {
|
module.exports = class {
|
||||||
constructor() {
|
constructor(packetID = 0x00) {
|
||||||
this.id = 0;
|
this.id = packetID;
|
||||||
}
|
|
||||||
|
|
||||||
readPacket() {
|
|
||||||
|
|
||||||
|
this.writer = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
writePacket() {
|
writePacket() {
|
||||||
|
this.writer = new bufferStuff.Writer();
|
||||||
|
|
||||||
|
this.writer.writeByte(this.id);
|
||||||
|
|
||||||
|
return this.writer;
|
||||||
|
}
|
||||||
|
|
||||||
|
toBuffer() {
|
||||||
|
return this.writer == null ? Buffer.alloc(0) : this.writer.buffer;
|
||||||
}
|
}
|
||||||
}
|
}
|
11
server/Packets/Packet0KeepAlive.js
Normal file
11
server/Packets/Packet0KeepAlive.js
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet0KeepAlive extends Packet {
|
||||||
|
writePacket() {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet0KeepAlive;
|
19
server/Packets/Packet10Player.js
Normal file
19
server/Packets/Packet10Player.js
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet10Player extends Packet {
|
||||||
|
constructor(onGround = true) {
|
||||||
|
super(0x0A);
|
||||||
|
|
||||||
|
this.onGround = onGround;
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket() {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeBool(this.onGround);
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet10Player;
|
31
server/Packets/Packet13PlayerPositionAndLook.js
Normal file
31
server/Packets/Packet13PlayerPositionAndLook.js
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet13PlayerPositionAndLook extends Packet {
|
||||||
|
constructor(x = 0, y = 65, stance = 67, z = 0, yaw = 0.0, pitch = 0.0, onGround = true) {
|
||||||
|
super(0x0D);
|
||||||
|
|
||||||
|
this.x = x;
|
||||||
|
this.y = y;
|
||||||
|
this.stance = stance;
|
||||||
|
this.z = z;
|
||||||
|
this.yaw = yaw;
|
||||||
|
this.pitch = pitch;
|
||||||
|
this.onGround = onGround;
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket() {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeDouble(this.x);
|
||||||
|
this.writer.writeDouble(this.y);
|
||||||
|
this.writer.writeDouble(this.stance);
|
||||||
|
this.writer.writeDouble(this.z);
|
||||||
|
this.writer.writeFloat(this.yaw);
|
||||||
|
this.writer.writeFloat(this.pitch);
|
||||||
|
this.writer.writeBool(this.onGround);
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet13PlayerPositionAndLook;
|
29
server/Packets/Packet1LoginRequest.js
Normal file
29
server/Packets/Packet1LoginRequest.js
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet1LoginRequest extends Packet {
|
||||||
|
constructor(protocol_version = 0, username = "", map_seed = BigInt(0), dimension = 0) {
|
||||||
|
super(0x01);
|
||||||
|
|
||||||
|
this.protocol_version = protocol_version;
|
||||||
|
this.username = username;
|
||||||
|
this.map_seed = map_seed;
|
||||||
|
this.dimension = dimension;
|
||||||
|
}
|
||||||
|
|
||||||
|
readPacket() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket(EID = 0) {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeInt(EID);
|
||||||
|
this.writer.writeString("");
|
||||||
|
this.writer.writeLong(971768181197178410);
|
||||||
|
this.writer.writeByte(0);
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet1LoginRequest;
|
19
server/Packets/Packet2Handshake.js
Normal file
19
server/Packets/Packet2Handshake.js
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet2Handshake extends Packet {
|
||||||
|
constructor(username = "") {
|
||||||
|
super(0x02);
|
||||||
|
|
||||||
|
this.username = username;
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket(EID = 0) {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeString("-"); // "-" == Offline mode
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet2Handshake;
|
19
server/Packets/Packet3Chat.js
Normal file
19
server/Packets/Packet3Chat.js
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet3Chat extends Packet {
|
||||||
|
constructor(message = "") {
|
||||||
|
super(0x03);
|
||||||
|
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket() {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeString(this.message);
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet3Chat;
|
23
server/Packets/Packet50PreChunk.js
Normal file
23
server/Packets/Packet50PreChunk.js
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet50PreChunk extends Packet {
|
||||||
|
constructor(x = 0, z = 0, mode = true) {
|
||||||
|
super(0x32);
|
||||||
|
|
||||||
|
this.x = x;
|
||||||
|
this.z = z;
|
||||||
|
this.mode = mode;
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket() {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeInt(this.x);
|
||||||
|
this.writer.writeInt(this.z);
|
||||||
|
this.writer.writeBool(this.mode);
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet50PreChunk;
|
27
server/Packets/Packet53BlockChange.js
Normal file
27
server/Packets/Packet53BlockChange.js
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet53BlockChange extends Packet {
|
||||||
|
constructor(x = 0, y = 0, z = 0, block_type = 0, block_metadata = 0) {
|
||||||
|
super(0x35);
|
||||||
|
|
||||||
|
this.x = x;
|
||||||
|
this.y = y;
|
||||||
|
this.z = z;
|
||||||
|
this.block_type = block_type;
|
||||||
|
this.block_metadata = block_metadata;
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket() {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeInt(this.x);
|
||||||
|
this.writer.writeByte(this.y);
|
||||||
|
this.writer.writeInt(this.z);
|
||||||
|
this.writer.writeByte(this.block_type);
|
||||||
|
this.writer.writeByte(this.block_metadata);
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet53BlockChange;
|
23
server/Packets/Packet6SpawnPosition.js
Normal file
23
server/Packets/Packet6SpawnPosition.js
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
const Packet = require("./Packet.js");
|
||||||
|
|
||||||
|
class Packet6SpawnPosition extends Packet {
|
||||||
|
constructor(x = 8.5, y = 65.5, z = 8.5) {
|
||||||
|
super(0x06);
|
||||||
|
|
||||||
|
this.x = x;
|
||||||
|
this.y = y;
|
||||||
|
this.z = z;
|
||||||
|
}
|
||||||
|
|
||||||
|
writePacket() {
|
||||||
|
super.writePacket();
|
||||||
|
|
||||||
|
this.writer.writeInt(this.x);
|
||||||
|
this.writer.writeInt(this.y);
|
||||||
|
this.writer.writeInt(this.z);
|
||||||
|
|
||||||
|
return this.toBuffer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Packet6SpawnPosition;
|
80
server/Util/funkyArray.js
Normal file
80
server/Util/funkyArray.js
Normal file
|
@ -0,0 +1,80 @@
|
||||||
|
const pRandom = require("./prettyRandom.js");
|
||||||
|
|
||||||
|
module.exports = class {
|
||||||
|
constructor(indexingMode = false) {
|
||||||
|
this.items = {};
|
||||||
|
this.itemKeys = Object.keys(this.items);
|
||||||
|
|
||||||
|
this.indexingMode = indexingMode;
|
||||||
|
this.index = 0;
|
||||||
|
|
||||||
|
this.iterableArray = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
add(item, regenerate = true) {
|
||||||
|
let id;
|
||||||
|
if (this.indexingMode) {
|
||||||
|
this.items[id = this.index] = item;
|
||||||
|
} else {
|
||||||
|
this.items[id = pRandom()] = item;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (regenerate) this.regenerateIterableArray();
|
||||||
|
this.itemKeys = Object.keys(this.items);
|
||||||
|
|
||||||
|
this.index++;
|
||||||
|
|
||||||
|
return this.items[id];
|
||||||
|
}
|
||||||
|
|
||||||
|
remove(id, regenerate = true) {
|
||||||
|
delete this.items[id];
|
||||||
|
if (regenerate) this.regenerateIterableArray();
|
||||||
|
this.itemKeys = Object.keys(this.items);
|
||||||
|
}
|
||||||
|
|
||||||
|
removeFirstItem(regenerate = true) {
|
||||||
|
delete this.items[this.itemKeys[0]];
|
||||||
|
if (regenerate) this.regenerateIterableArray();
|
||||||
|
this.itemKeys = Object.keys(this.items);
|
||||||
|
}
|
||||||
|
|
||||||
|
regenerateIterableArray() {
|
||||||
|
this.iterableArray = new Array();
|
||||||
|
for (let itemKey of this.itemKeys) {
|
||||||
|
this.iterableArray.push(this.items[itemKey]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
getFirstItem() {
|
||||||
|
return this.items[this.itemKeys[0]];
|
||||||
|
}
|
||||||
|
|
||||||
|
getLength() {
|
||||||
|
return this.itemKeys.length;
|
||||||
|
}
|
||||||
|
|
||||||
|
getKeyById(id) {
|
||||||
|
return this.itemKeys[id];
|
||||||
|
}
|
||||||
|
|
||||||
|
getById(id) {
|
||||||
|
return this.items[this.itemKeys[id]];
|
||||||
|
}
|
||||||
|
|
||||||
|
getByKey(key) {
|
||||||
|
return this.items[key];
|
||||||
|
}
|
||||||
|
|
||||||
|
getKeys() {
|
||||||
|
return this.itemKeys;
|
||||||
|
}
|
||||||
|
|
||||||
|
getItems() {
|
||||||
|
return this.items;
|
||||||
|
}
|
||||||
|
|
||||||
|
getIterableItems() {
|
||||||
|
return this.iterableArray;
|
||||||
|
}
|
||||||
|
}
|
21
server/Util/prettyRandom.js
Normal file
21
server/Util/prettyRandom.js
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
let lastRandom = -1;
|
||||||
|
|
||||||
|
function pRandom(from = 0, to = 2147483647) {
|
||||||
|
let thisRandom = Math.floor(map(Math.random(), 0, 1, from, to));
|
||||||
|
if (thisRandom == lastRandom) thisRandom = pRandom(from, to);
|
||||||
|
|
||||||
|
return thisRandom;
|
||||||
|
}
|
||||||
|
|
||||||
|
function map(input, inputMin, inputMax, outputMin, outputMax) {
|
||||||
|
const newv = (input - inputMin) / (inputMax - inputMin) * (outputMax - outputMin) + outputMin;
|
||||||
|
|
||||||
|
if (outputMin < outputMax) return constrain(newv, outputMin, outputMax);
|
||||||
|
else return constrain(newv, outputMax, outputMin);
|
||||||
|
}
|
||||||
|
|
||||||
|
function constrain(input, low, high) {
|
||||||
|
return Math.max(Math.min(input, high), low);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = pRandom;
|
|
@ -22,6 +22,16 @@ module.exports.Writer = class {
|
||||||
this.writeBuffer(buff);
|
this.writeBuffer(buff);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
writeByteArray(data = [0]) {
|
||||||
|
const buff = Buffer.alloc(data.length);
|
||||||
|
|
||||||
|
for (let byte of data) {
|
||||||
|
buff.writeInt8(byte);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.writeBuffer(buff);
|
||||||
|
}
|
||||||
|
|
||||||
writeShort(data = 0) {
|
writeShort(data = 0) {
|
||||||
const buff = Buffer.alloc(2);
|
const buff = Buffer.alloc(2);
|
||||||
buff.writeIntBE(data, 0, 2);
|
buff.writeIntBE(data, 0, 2);
|
||||||
|
@ -29,6 +39,18 @@ module.exports.Writer = class {
|
||||||
this.writeBuffer(buff);
|
this.writeBuffer(buff);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
writeShortArray(data = [0]) {
|
||||||
|
const buff = Buffer.alloc(data.length * 2);
|
||||||
|
let offset = 0;
|
||||||
|
|
||||||
|
for (let short of data) {
|
||||||
|
buff.writeIntBE(short, offset, 2);
|
||||||
|
offset += 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.writeBuffer(buff);
|
||||||
|
}
|
||||||
|
|
||||||
writeInt(data = 0) {
|
writeInt(data = 0) {
|
||||||
const buff = Buffer.alloc(4);
|
const buff = Buffer.alloc(4);
|
||||||
buff.writeIntBE(data, 0, 4);
|
buff.writeIntBE(data, 0, 4);
|
||||||
|
|
|
@ -1,25 +1,110 @@
|
||||||
|
const FunkyArray = require("./Util/funkyArray.js");
|
||||||
|
const bufferStuff = require("./bufferStuff.js");
|
||||||
|
|
||||||
module.exports = class {
|
module.exports = class {
|
||||||
constructor() {
|
constructor() {
|
||||||
this.chunks = {};
|
this.chunks = {};
|
||||||
|
|
||||||
this.createChunk(0, 0);
|
this.queuedBlockUpdates = new FunkyArray();
|
||||||
|
|
||||||
|
for (let x = -3; x < 4; x++) {
|
||||||
|
for (let z = -3; z < 4; z++) {
|
||||||
|
this.createChunk(x, z);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
createChunk(x = 0, z = 0) {
|
// TODO: Store metadata!
|
||||||
this.chunks[x] = {};
|
createChunk(cx = 0, cz = 0) {
|
||||||
this.chunks[x][z] = {};
|
if (this.chunks[cx] == null) this.chunks[cx] = {};
|
||||||
|
this.chunks[cx][cz] = {};
|
||||||
|
|
||||||
|
let chunkQueuedBlocks = [];
|
||||||
|
|
||||||
const chunk = this.chunks[x][z];
|
|
||||||
for (let y = 0; y < 128; y++) {
|
for (let y = 0; y < 128; y++) {
|
||||||
chunk[y] = {};
|
this.chunks[cx][cz][y] = {};
|
||||||
for (let x = 0; x < 16; x++) {
|
for (let x = 0; x < 16; x++) {
|
||||||
chunk[y][x] = {};
|
this.chunks[cx][cz][y][x] = [];
|
||||||
for (let z = 0; z < 16; z++) {
|
for (let z = 0; z < 16; z++) {
|
||||||
chunk[y][x][z] = 0;
|
if (y == 64) {
|
||||||
|
this.chunks[cx][cz][y][x].push(2);
|
||||||
|
// Make a tree :)
|
||||||
|
if (Math.random() <= 0.01) {
|
||||||
|
const newX = x + (16 * cx), newZ = z + (16 * cz);
|
||||||
|
// trunk
|
||||||
|
this.setBlock(17, newX, y + 1, newZ);
|
||||||
|
this.setBlock(17, newX, y + 2, newZ);
|
||||||
|
this.setBlock(17, newX, y + 3, newZ);
|
||||||
|
this.setBlock(17, newX, y + 4, newZ);
|
||||||
|
// leaves
|
||||||
|
this.setBlock(18, newX + 2, y + 3, newZ + 2);
|
||||||
|
this.setBlock(18, newX + 1, y + 3, newZ + 2);
|
||||||
|
this.setBlock(18, newX, y + 3, newZ + 2);
|
||||||
|
this.setBlock(18, newX - 1, y + 3, newZ + 2);
|
||||||
|
this.setBlock(18, newX - 2, y + 3, newZ + 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (y == 63 || y == 62) this.chunks[cx][cz][y][x].push(3);
|
||||||
|
else if (y == 0) this.chunks[cx][cz][y][x].push(7);
|
||||||
|
else if (y < 62) this.chunks[cx][cz][y][x].push(1);
|
||||||
|
else this.chunks[cx][cz][y][x].push(0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log(chunk);
|
multiBlockChunk(chunkX = 0, chunkZ = 0, user) {
|
||||||
|
const writer = new bufferStuff.Writer();
|
||||||
|
|
||||||
|
// I couldn't figure out how to construct a chunk lmao
|
||||||
|
// __ima just send each block individually__
|
||||||
|
// Using multi block chunks now!
|
||||||
|
// TODO: yknow, figure out how to chunk.
|
||||||
|
let blocksToSend = [];
|
||||||
|
for (let y = 0; y < 128; y++) {
|
||||||
|
blocksToSend = [];
|
||||||
|
for (let x = 0; x < 16; x++) {
|
||||||
|
for (let z = 0; z < 16; z++) {
|
||||||
|
if (this.chunks[chunkX][chunkZ][y][x][z] == 0) continue; // don't send air lol
|
||||||
|
blocksToSend.push([this.chunks[chunkX][chunkZ][y][x][z], x & 0xf, z & 0xf]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (blocksToSend.length > 0) {
|
||||||
|
writer.reset();
|
||||||
|
writer.writeByte(0x34);
|
||||||
|
writer.writeInt(chunkX);
|
||||||
|
writer.writeInt(chunkZ);
|
||||||
|
writer.writeShort(blocksToSend.length);
|
||||||
|
// Block coords
|
||||||
|
for (let blocks of blocksToSend) {
|
||||||
|
writer.writeShort((blocks[1] << 12 | blocks[2] << 8 | y) - 32768);
|
||||||
|
}
|
||||||
|
// Block types
|
||||||
|
for (let blocks of blocksToSend) {
|
||||||
|
writer.writeByte(blocks[0]);
|
||||||
|
}
|
||||||
|
// Block metadata
|
||||||
|
for (let blocks of blocksToSend) {
|
||||||
|
writer.writeByte(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
user.chunksToSend.add(writer.buffer) // so we don't flood the client queue these
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
setBlock(id = 0, x = 0, y = 0, z = 0) {
|
||||||
|
if (y < 0 || y > 127) throw "Tried to set a block outside of the world!";
|
||||||
|
|
||||||
|
const chunkX = Math.floor(x / 16);
|
||||||
|
const chunkZ = Math.floor(z / 16);
|
||||||
|
const blockX = x - (16 * chunkX);
|
||||||
|
const blockZ = z - (16 * chunkZ);
|
||||||
|
|
||||||
|
// Don't queue a block update if that block is already this block
|
||||||
|
//if (this.chunks[chunkX][chunkZ][y][blockX][blockZ] == id) return;
|
||||||
|
|
||||||
|
this.queuedBlockUpdates.add([id, chunkX, chunkZ, y, blockX, blockZ]);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,14 +1,107 @@
|
||||||
const bufferStuff = require("./bufferStuff.js")
|
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");
|
||||||
|
|
||||||
const Socket = require("net").Socket;
|
const Socket = require("net").Socket;
|
||||||
|
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);
|
||||||
|
|
||||||
module.exports.init = function(config) {
|
module.exports.init = function(config) {
|
||||||
|
config = config;
|
||||||
console.log(`Up! Running at 0.0.0.0:${config.port}`);
|
console.log(`Up! Running at 0.0.0.0:${config.port}`);
|
||||||
|
|
||||||
|
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()));
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports.connection = function(socket = new Socket) {
|
module.exports.connection = function(socket = new Socket) {
|
||||||
|
const thisUser = addUser(socket);
|
||||||
|
|
||||||
socket.on('data', function(chunk) {
|
socket.on('data', function(chunk) {
|
||||||
console.log(chunk);
|
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;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.on('end', function() {
|
socket.on('end', function() {
|
||||||
|
|
16
server/user.js
Normal file
16
server/user.js
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
const funkyArray = require("./Util/funkyArray.js");
|
||||||
|
|
||||||
|
const Socket = require("net").Socket;
|
||||||
|
|
||||||
|
module.exports = class {
|
||||||
|
constructor(id = 1, socket = new Socket) {
|
||||||
|
this.id = id;
|
||||||
|
this.socket = socket;
|
||||||
|
|
||||||
|
this.username = "UNNAMED";
|
||||||
|
|
||||||
|
this.loginFinished = false;
|
||||||
|
|
||||||
|
this.chunksToSend = new funkyArray();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue