Use @types/node@8.0.0 to validate (and fix) small node 8 api issues
This commit is contained in:
parent
916d03f879
commit
f0a24b8f65
|
@ -85,6 +85,8 @@ class GameResolver {
|
||||||
for (const one of str.split(',')) {
|
for (const one of str.split(',')) {
|
||||||
const equals = one.indexOf('=');
|
const equals = one.indexOf('=');
|
||||||
const key = equals === -1 ? one : one.substr(0,equals);
|
const key = equals === -1 ? one : one.substr(0,equals);
|
||||||
|
|
||||||
|
/** @type {string|number|boolean} */
|
||||||
let value = equals === -1 ? '' : one.substr(equals+1);
|
let value = equals === -1 ? '' : one.substr(equals+1);
|
||||||
|
|
||||||
if(value === 'true' || value === '') value = true;
|
if(value === 'true' || value === '') value = true;
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
const GameResolver = require('./GameResolver'),
|
const GameResolver = require('./GameResolver'),
|
||||||
ProtocolResolver = require('./ProtocolResolver'),
|
ProtocolResolver = require('./ProtocolResolver'),
|
||||||
GlobalUdpSocket = require('./GlobalUdpSocket'),
|
GlobalUdpSocket = require('./GlobalUdpSocket');
|
||||||
Logger = require('./Logger');
|
|
||||||
|
|
||||||
const defaultOptions = {
|
const defaultOptions = {
|
||||||
socketTimeout: 2000,
|
socketTimeout: 2000,
|
||||||
|
|
|
@ -1,13 +1,19 @@
|
||||||
{
|
{
|
||||||
"name": "gamedig",
|
"name": "gamedig",
|
||||||
"version": "2.0.5",
|
"version": "2.0.13",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@types/cheerio": {
|
||||||
|
"version": "0.22.10",
|
||||||
|
"resolved": "https://registry.npmjs.org/@types/cheerio/-/cheerio-0.22.10.tgz",
|
||||||
|
"integrity": "sha512-fOM/Jhv51iyugY7KOBZz2ThfT1gwvsGCfWxpLpZDgkGjpEO4Le9cld07OdskikLjDUQJ43dzDaVRSFwQlpdqVg==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"@types/node": {
|
"@types/node": {
|
||||||
"version": "10.12.18",
|
"version": "8.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/@types/node/-/node-10.12.18.tgz",
|
"resolved": "https://registry.npmjs.org/@types/node/-/node-8.0.0.tgz",
|
||||||
"integrity": "sha512-fh+pAqt4xRzPfqA6eh3Z2y6fyZavRIumvjhaCL753+TVkGKGhpPeyrJG2JftD0T9q4GF00KjefsQ+PQNDdWQaQ=="
|
"integrity": "sha512-j2tekvJCO7j22cs+LO6i0kRPhmQ9MXaPZ55TzOc1lzkN5b6BWqq4AFjl04s1oRRQ1v5rSe+KEvnLUSTonuls/A=="
|
||||||
},
|
},
|
||||||
"ajv": {
|
"ajv": {
|
||||||
"version": "6.6.2",
|
"version": "6.6.2",
|
||||||
|
@ -324,9 +330,12 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"iconv-lite": {
|
"iconv-lite": {
|
||||||
"version": "0.4.18",
|
"version": "0.4.24",
|
||||||
"resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.18.tgz",
|
"resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
|
||||||
"integrity": "sha512-sr1ZQph3UwHTR0XftSbK85OvBbxe/abLGzEnPENCQwmHf7sck8Oyu4ob3LgBxWWxRoM+QszeUyl7jbqapu2TqA=="
|
"integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
|
||||||
|
"requires": {
|
||||||
|
"safer-buffer": ">= 2.1.2 < 3"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"inherits": {
|
"inherits": {
|
||||||
"version": "2.0.3",
|
"version": "2.0.3",
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
"cheerio": "^1.0.0-rc.2",
|
"cheerio": "^1.0.0-rc.2",
|
||||||
"compressjs": "^1.0.2",
|
"compressjs": "^1.0.2",
|
||||||
"gbxremote": "^0.1.4",
|
"gbxremote": "^0.1.4",
|
||||||
"iconv-lite": "^0.4.18",
|
"iconv-lite": "^0.4.24",
|
||||||
"long": "^2.4.0",
|
"long": "^2.4.0",
|
||||||
"minimist": "^1.2.0",
|
"minimist": "^1.2.0",
|
||||||
"moment": "^2.21.0",
|
"moment": "^2.21.0",
|
||||||
|
@ -46,5 +46,9 @@
|
||||||
"games.txt",
|
"games.txt",
|
||||||
"LICENSE",
|
"LICENSE",
|
||||||
"README.md"
|
"README.md"
|
||||||
]
|
],
|
||||||
|
"devDependencies": {
|
||||||
|
"@types/cheerio": "^0.22.10",
|
||||||
|
"@types/node": "^8.0.0"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@ class BuildAndShoot extends Core {
|
||||||
|
|
||||||
let m;
|
let m;
|
||||||
|
|
||||||
m = body.match(/status server for (.*?)\.?(\r|\n)/);
|
m = body.match(/status server for (.*?)\.?[\r\n]/);
|
||||||
if(m) state.name = m[1];
|
if(m) state.name = m[1];
|
||||||
|
|
||||||
m = body.match(/Current uptime: (\d+)/);
|
m = body.match(/Current uptime: (\d+)/);
|
||||||
|
|
|
@ -182,7 +182,8 @@ class Core extends EventEmitter {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @template T
|
* @template T
|
||||||
* @param {function(Socket):Promise<T>} fn
|
* @param {function(NodeJS.Socket):Promise<T>} fn
|
||||||
|
* @param {number=} port
|
||||||
* @returns {Promise<T>}
|
* @returns {Promise<T>}
|
||||||
*/
|
*/
|
||||||
async withTcp(fn, port) {
|
async withTcp(fn, port) {
|
||||||
|
@ -236,7 +237,7 @@ class Core extends EventEmitter {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @template T
|
* @template T
|
||||||
* @param {Socket} socket
|
* @param {NodeJS.Socket} socket
|
||||||
* @param {Buffer|string} buffer
|
* @param {Buffer|string} buffer
|
||||||
* @param {function(Buffer):T} ondata
|
* @param {function(Buffer):T} ondata
|
||||||
* @returns Promise<T>
|
* @returns Promise<T>
|
||||||
|
@ -250,7 +251,7 @@ class Core extends EventEmitter {
|
||||||
received = Buffer.concat([received, data]);
|
received = Buffer.concat([received, data]);
|
||||||
const result = ondata(received);
|
const result = ondata(received);
|
||||||
if (result !== undefined) {
|
if (result !== undefined) {
|
||||||
socket.off('data', onData);
|
socket.removeListener('data', onData);
|
||||||
resolve(result);
|
resolve(result);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -4,10 +4,6 @@ class Doom3 extends Core {
|
||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
this.encoding = 'latin1';
|
this.encoding = 'latin1';
|
||||||
this.isEtqw = false;
|
|
||||||
this.hasSpaceBeforeClanTag = false;
|
|
||||||
this.hasClanTag = false;
|
|
||||||
this.hasTypeFlag = false;
|
|
||||||
}
|
}
|
||||||
async run(state) {
|
async run(state) {
|
||||||
const body = await this.udpSend('\xff\xffgetInfo\x00PiNGPoNg\x00', packet => {
|
const body = await this.udpSend('\xff\xffgetInfo\x00PiNGPoNg\x00', packet => {
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
const Core = require('./core'),
|
const Core = require('./core');
|
||||||
HexUtil = require('../lib/HexUtil');
|
|
||||||
|
|
||||||
class Gamespy3 extends Core {
|
class Gamespy3 extends Core {
|
||||||
constructor() {
|
constructor() {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
const gbxremote = require('gbxremote'),
|
const gbxremote = require('gbxremote'),
|
||||||
Core = require('./core');
|
Core = require('./core'),
|
||||||
|
Promises = require('../lib/Promises');
|
||||||
|
|
||||||
class Nadeo extends Core {
|
class Nadeo extends Core {
|
||||||
async run(state) {
|
async run(state) {
|
||||||
|
@ -59,20 +60,16 @@ class Nadeo extends Core {
|
||||||
|
|
||||||
async withClient(fn) {
|
async withClient(fn) {
|
||||||
const socket = gbxremote.createClient(this.options.port, this.options.host);
|
const socket = gbxremote.createClient(this.options.port, this.options.host);
|
||||||
const cancelAsyncLeak = this.addCleanup(() => socket.terminate());
|
|
||||||
try {
|
try {
|
||||||
await this.timedPromise(
|
const connectPromise = new Promise((resolve,reject) => {
|
||||||
new Promise((resolve,reject) => {
|
socket.on('connect', resolve);
|
||||||
socket.on('connect', resolve);
|
socket.on('error', e => reject(new Error('GBX Remote Connection Error: ' + e)));
|
||||||
socket.on('error', e => reject(new Error('GBX Remote Connection Error: ' + e)));
|
socket.on('close', () => reject(new Error('GBX Remote Connection Refused')));
|
||||||
socket.on('close', () => reject(new Error('GBX Remote Connection Refused')));
|
});
|
||||||
}),
|
const timeoutPromise = Promises.createTimeout(this.options.socketTimeout, 'GBX Remote Opening');
|
||||||
this.options.socketTimeout,
|
const socket = await Promise.race([connectPromise, timeoutPromise, this.abortedPromise]);
|
||||||
'GBX Remote Opening'
|
|
||||||
);
|
|
||||||
return await fn(socket);
|
return await fn(socket);
|
||||||
} finally {
|
} finally {
|
||||||
cancelAsyncLeak();
|
|
||||||
socket.terminate();
|
socket.terminate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -80,16 +77,15 @@ class Nadeo extends Core {
|
||||||
async methodCall(client, ...cmdset) {
|
async methodCall(client, ...cmdset) {
|
||||||
const cmd = cmdset[0];
|
const cmd = cmdset[0];
|
||||||
const params = cmdset.slice(1);
|
const params = cmdset.slice(1);
|
||||||
return await this.timedPromise(
|
|
||||||
new Promise(async (resolve,reject) => {
|
const sentPromise = new Promise(async (resolve,reject) => {
|
||||||
client.methodCall(cmd, params, (err, value) => {
|
client.methodCall(cmd, params, (err, value) => {
|
||||||
if (err) reject('XMLRPC error ' + JSON.stringify(err));
|
if (err) reject('XMLRPC error ' + JSON.stringify(err));
|
||||||
resolve(value);
|
resolve(value);
|
||||||
});
|
});
|
||||||
}),
|
});
|
||||||
this.options.socketTimeout,
|
const timeoutPromise = Promises.createTimeout(this.options.socketTimeout, 'GBX Method Call');
|
||||||
'GBX Method Call'
|
return await Promise.race([sentPromise, timeoutPromise, this.abortedPromise]);
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
stripColors(str) {
|
stripColors(str) {
|
||||||
|
|
Loading…
Reference in New Issue