mirror of
https://github.com/NovaGM/Modules.git
synced 2024-08-14 22:47:01 +00:00
Added SnowflakeInfo module.
This commit is contained in:
parent
4676a8d90e
commit
e1667e6865
2 changed files with 98 additions and 0 deletions
11
SnowflakeInfo/goosemodModule.json
Normal file
11
SnowflakeInfo/goosemodModule.json
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
{
|
||||||
|
"main": "index.js",
|
||||||
|
|
||||||
|
"name": "SnowflakeInfo",
|
||||||
|
"description": "Returns info about a given snowflake.",
|
||||||
|
"tags": ["commands"],
|
||||||
|
|
||||||
|
"authors": ["717352467280691331"],
|
||||||
|
|
||||||
|
"version": "1.0.0"
|
||||||
|
}
|
87
SnowflakeInfo/index.js
Normal file
87
SnowflakeInfo/index.js
Normal file
|
@ -0,0 +1,87 @@
|
||||||
|
import { commands, internalMessage } from '@goosemod/patcher';
|
||||||
|
|
||||||
|
const discordEpoch = Number(1420070400000);
|
||||||
|
|
||||||
|
const idToBinary = (num) => {
|
||||||
|
let bin = '';
|
||||||
|
let high = parseInt(num.slice(0, -10)) || 0;
|
||||||
|
let low = parseInt(num.slice(-10));
|
||||||
|
try {
|
||||||
|
while (low > 0 || high > 0) {
|
||||||
|
bin = String(low & 1) + bin;
|
||||||
|
low = Math.floor(low / 2);
|
||||||
|
if (high > 0) {
|
||||||
|
low += 5000000000 * (high % 2);
|
||||||
|
high = Math.floor(high / 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
console.error(e);
|
||||||
|
}
|
||||||
|
return bin;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default {
|
||||||
|
goosemodHandlers: {
|
||||||
|
onImport: () => {
|
||||||
|
commands.add(
|
||||||
|
'echo',
|
||||||
|
"Prints out all of the message's text in an internal message.",
|
||||||
|
(args) => {
|
||||||
|
internalMessage(args.text[0].text);
|
||||||
|
console.log(args);
|
||||||
|
},
|
||||||
|
[
|
||||||
|
{
|
||||||
|
type: 3,
|
||||||
|
name: 'text',
|
||||||
|
description: 'Text to be printed in an internal message.',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
);
|
||||||
|
|
||||||
|
commands.add(
|
||||||
|
'snowflake',
|
||||||
|
'Returns info about a given snowflake.',
|
||||||
|
(args) => {
|
||||||
|
// Check if the supplied argument is actually a snowflake or not
|
||||||
|
if (!/\d{1,20}/.test(args.snowflake[0].text)) {
|
||||||
|
internalMessage('The provided argument is not a snowflake.');
|
||||||
|
} else {
|
||||||
|
const binary = idToBinary(args.snowflake[0].text).toString(2).padStart(64, '0');
|
||||||
|
|
||||||
|
const res = {
|
||||||
|
timestamp: parseInt(binary.substring(0, 42), 2) + discordEpoch,
|
||||||
|
workerID: parseInt(binary.substring(42, 47), 2),
|
||||||
|
processID: parseInt(binary.substring(47, 52), 2),
|
||||||
|
increment: parseInt(binary.substring(52, 64), 2),
|
||||||
|
binary: binary,
|
||||||
|
};
|
||||||
|
|
||||||
|
internalMessage(
|
||||||
|
`Snowflake info for \`${args.snowflake[0].text}\`\n\n` +
|
||||||
|
`**Timestamp**: ${new Date(res.timestamp).toUTCString()} (${res.timestamp})\n` +
|
||||||
|
`**Worker ID**: ${res.workerID}\n` +
|
||||||
|
`**Process ID**: ${res.processID}\n` +
|
||||||
|
`**Increment**: ${res.increment}\n` +
|
||||||
|
`**Binary**: ${res.binary}\n`,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
[
|
||||||
|
{
|
||||||
|
type: 3,
|
||||||
|
name: 'snowflake',
|
||||||
|
description: 'Snowflake to decrypt.',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onRemove: () => {
|
||||||
|
commands.remove('echo');
|
||||||
|
commands.remove('snowflake');
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
Loading…
Reference in a new issue