Skip to content

Commit

Permalink
feat(node): node compatability
Browse files Browse the repository at this point in the history
  • Loading branch information
c43721 committed Oct 29, 2024
1 parent ba54acc commit f8a4728
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 9 deletions.
5 changes: 4 additions & 1 deletion deno.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,8 @@
"@std/io": "jsr:@std/io@^0.225.0"
},
"version": "0.0.2",
"exports": "./mod.ts"
"exports": "./mod.ts",
"publish": {
"include": ["README.md", "mod.ts", "src/"]
}
}
18 changes: 10 additions & 8 deletions src/rcon.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import protocol from "./protocol.ts";
import { iterateReader } from "@std/io";
import { concat } from "@std/bytes";
import { createConnection, type Socket } from "node:net";
import { encode, decode } from "./packet.ts";
Expand Down Expand Up @@ -75,7 +74,7 @@ export default class Rcon {
*/
public async authenticate(password: string): Promise<boolean> {
if (!this.#connected) {
await this.#connect();
this.#connect();
}

const response = await this.#send(
Expand Down Expand Up @@ -127,6 +126,7 @@ export default class Rcon {
this.#connection = createConnection({
host: this.#host,
port: this.#port,
timeout: 1000,
});

this.#connected = true;
Expand All @@ -145,12 +145,16 @@ export default class Rcon {
throw new PacketSizeTooBigException();
}

await this.#connection!.write(encodedPacket);
this.#connection!.write(encodedPacket);

let potentialMultiPacketResponse = new Uint8Array();

for await (const response of iterateReader(this.#connection!)) {
const decodedPacket = decode(response);
const socketIterator = this.#connection![Symbol.asyncIterator]();

while (true) {
const { value } = await socketIterator.next();

const decodedPacket = decode(value);

if (decodedPacket.size < 10) {
throw new UnableToParseResponseException();
Expand Down Expand Up @@ -191,14 +195,12 @@ export default class Rcon {
""
);

await this.#connection!.write(encodedTerminationPacket);
this.#connection!.write(encodedTerminationPacket);
} else if (decodedPacket.size <= 3700) {
// no need to check for ID_TERM here, since this packet will always be < 3700
return new TextDecoder().decode(potentialMultiPacketResponse);
}
}
}

throw new Error("Unreachable");
}
}

0 comments on commit f8a4728

Please sign in to comment.