summary refs log tree commit diff homepage
path: root/lib/rcon.js
diff options
context:
space:
mode:
authordestruc7i0n <6181960+destruc7i0n@users.noreply.github.com>2020-02-11 15:23:23 -0500
committerGitHub <noreply@github.com>2020-02-11 15:23:23 -0500
commitd2cff4ced30817c2d02bc9c133cbabcf380b6de7 (patch)
treed79b7e9f1e959d22dd9b68cec8a65e49658a16fa /lib/rcon.js
parentMerge pull request #37 from destruc7i0n/webhooks (diff)
parentPrecedence (diff)
downloadshulker-d2cff4ced30817c2d02bc9c133cbabcf380b6de7.tar.gz
shulker-d2cff4ced30817c2d02bc9c133cbabcf380b6de7.zip
Merge pull request #47 from destruc7i0n/refactor
Refactor
Diffstat (limited to 'lib/rcon.js')
-rw-r--r--lib/rcon.js96
1 files changed, 0 insertions, 96 deletions
diff --git a/lib/rcon.js b/lib/rcon.js
deleted file mode 100644
index 82b8efd..0000000
--- a/lib/rcon.js
+++ /dev/null
@@ -1,96 +0,0 @@
-// Credits to M4GNV5 for this library to reduce dependencies
-
-const net = require('net')
-const c = require('../config.json')
-const debug = c.DEBUG
-
-module.exports = Rcon
-
-function Rcon (ip, port) {
-  const self = this
-  self.rconTimeout = undefined
-  self.nextId = 0
-  self.connected = false
-  self.authed = false
-  self.packages = []
-
-  self.socket = net.connect(port, ip, function () {
-    self.connected = true
-    console.log('[INFO] Authenticated with ' + ip + ':' + port)
-  })
-
-  self.socket.on('data', function (data) {
-    const length = data.readInt32LE(0)
-    const id = data.readInt32LE(4)
-    const type = data.readInt32LE(8)
-    const response = data.toString('ascii', 12, data.length - 2)
-
-    if (self.packages[id]) {
-      self.packages[id](type, response)
-    } else {
-      console.log('unexpected rcon response', id, type, response)
-    }
-  }).on('end', function () {
-    if (debug) {
-      console.log('[DEBUG] Rcon closed!')
-    }
-  })
-}
-Rcon.timeout = 5000
-
-Rcon.prototype.close = function () {
-  this.connected = false
-  this.socket.end()
-}
-
-Rcon.prototype.auth = function (pw, cb) {
-  const self = this
-  self.pass = pw
-  self.cb = cb
-
-  if (self.authed) { throw new Error('already authed') }
-
-  if (self.connected) { doAuth() } else { self.socket.on('connect', doAuth) }
-
-  function doAuth () {
-    self.sendPackage(3, pw, cb)
-  }
-}
-
-Rcon.prototype.command = function (cmd, cb) {
-  this.sendPackage(2, cmd, cb)
-}
-
-Rcon.prototype.sendPackage = function (type, payload, cb) {
-  const self = this
-  const id = self.nextId
-  self.nextId++
-
-  if (!self.connected) { throw new Error('Cannot send package while not connected') }
-
-  const length = 14 + payload.length
-  const buff = new Buffer(length)
-  buff.writeInt32LE(length - 4, 0)
-  buff.writeInt32LE(id, 4)
-  buff.writeInt32LE(type, 8)
-
-  buff.write(payload, 12)
-  buff.writeInt8(0, length - 2)
-  buff.writeInt8(0, length - 1)
-
-  self.socket.write(buff)
-
-  const timeout = setTimeout(function () {
-    delete self.packages[id]
-    cb('Server sent no request in ' + Rcon.timeout / 1000 + ' seconds')
-  }, Rcon.timeout)
-
-  self.packages[id] = function (type, response) {
-    clearTimeout(timeout)
-    const err = type >= 0 ? false : 'Server sent package code ' + type
-    if (debug) {
-      console.log('[DEBUG] Recieved response: ' + response)
-    }
-    cb(err, response, type)
-  }
-}