mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-16 03:23:29 +01:00
Add shard eval, broadcastEval, and fix fetchGuildCount response
This commit is contained in:
File diff suppressed because one or more lines are too long
@@ -141,7 +141,16 @@ class Client extends EventEmitter {
|
|||||||
|
|
||||||
if (process.send) {
|
if (process.send) {
|
||||||
process.on('message', message => {
|
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.');
|
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;
|
module.exports = Shard;
|
||||||
|
|||||||
@@ -114,6 +114,17 @@ class ShardingManager extends EventEmitter {
|
|||||||
return Promise.all(promises);
|
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.
|
* Obtains the total guild count across all shards.
|
||||||
* @param {number} [timeout=3000] Time to automatically fail after (in milliseconds)
|
* @param {number} [timeout=3000] Time to automatically fail after (in milliseconds)
|
||||||
|
|||||||
Reference in New Issue
Block a user