mirror of
https://github.com/danbulant/discord.js
synced 2026-05-24 20:42:27 +00:00
Add shard eval, broadcastEval, and fix fetchGuildCount response
This commit is contained in:
parent
65b93532ce
commit
e4f416ae6c
4 changed files with 52 additions and 2 deletions
File diff suppressed because one or more lines are too long
|
|
@ -141,7 +141,16 @@ class Client extends EventEmitter {
|
|||
|
||||
if (process.send) {
|
||||
process.on('message', message => {
|
||||
if (message === '_guildCount') process.send(this.guilds.size);
|
||||
if (!message) return;
|
||||
if (message === '_guildCount') {
|
||||
process.send({ _guildCount: this.guilds.size });
|
||||
} else if (message._eval) {
|
||||
try {
|
||||
process.send({ _evalResult: eval(message._eval) });
|
||||
} catch (err) {
|
||||
process.send({ _evalError: err });
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -54,6 +54,36 @@ class Shard {
|
|||
if (!sent) throw new Error('Failed to send message to shard\'s process.');
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Evaluates a script on the shard, in the context of the Client.
|
||||
* @param {string} script JavaScript to run on the shard
|
||||
* @returns {Promise<*>} Result of the script
|
||||
*/
|
||||
eval(script) {
|
||||
return new Promise((resolve, reject) => {
|
||||
const listener = message => {
|
||||
if (!message) return;
|
||||
if (message._evalResult) {
|
||||
this.process.removeListener('message', listener);
|
||||
resolve(message._evalResult);
|
||||
} else if (message._evalError) {
|
||||
this.process.removeListener('message', listener);
|
||||
const err = new Error(message._evalError.message, message._evalError.fileName, message._evalError.lineNumber);
|
||||
err.name = message._evalError.name;
|
||||
err.columnNumber = message._evalError.columnNumber;
|
||||
err.stack = message._evalError.stack;
|
||||
reject(err);
|
||||
}
|
||||
};
|
||||
this.process.on('message', listener);
|
||||
|
||||
this.send({ _eval: script }).catch(err => {
|
||||
this.process.removeListener('message', listener);
|
||||
reject(err);
|
||||
});
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = Shard;
|
||||
|
|
|
|||
|
|
@ -114,6 +114,17 @@ class ShardingManager extends EventEmitter {
|
|||
return Promise.all(promises);
|
||||
}
|
||||
|
||||
/**
|
||||
* Evaluates a script on all shards, in the context of the Clients.
|
||||
* @param {string} script JavaScript to run on each shard
|
||||
* @returns {Promise<Array>} Results of the script
|
||||
*/
|
||||
broadcastEval(script) {
|
||||
const promises = [];
|
||||
for (const shard of this.shards.values()) promises.push(shard.eval(script));
|
||||
return Promise.all(promises);
|
||||
}
|
||||
|
||||
/**
|
||||
* Obtains the total guild count across all shards.
|
||||
* @param {number} [timeout=3000] Time to automatically fail after (in milliseconds)
|
||||
|
|
|
|||
Loading…
Reference in a new issue