Files
cockinator/index.js

169 lines
6.8 KiB
JavaScript

const config = require('./config.json');
// the basic discord setup stuff yoinked from their guide
const { Client, Events, GatewayIntentBits, Partials, ActivityType, MessageFlags, Collection } = require('discord.js');
const client = new Client({
intents: [
GatewayIntentBits.Guilds,
GatewayIntentBits.GuildMessages,
GatewayIntentBits.DirectMessages,
GatewayIntentBits.MessageContent,
GatewayIntentBits.GuildMessageReactions
],
partials: [
Partials.Channel,
Partials.Message,
Partials.Reaction,
Partials.User
]
});
// build the button below the message that swaps the URL
const { ActionRowBuilder, ButtonBuilder, ButtonStyle } = require('discord.js');
const swapRow = new ActionRowBuilder()
.addComponents(
new ButtonBuilder()
.setCustomId('swap_twitter')
.setLabel('Swap URL')
.setStyle(ButtonStyle.Secondary),
);
// the main function that swaps the URL, takes
function convertURL(url, regex, domain) {
const match = url.match(regex);
if (match) {
console.log(`Converting ${url} to ${domain}`)
return `https://${domain}/${match[1]}/status/${match[2]}`;
}
}
// called by the swap button, swaps girlcock links to fxtwitter, and back again if needed
function swapify(url) {
const girlcockRegex = /https?:\/\/girlcockx\.com\/(.*?)\/status\/(\d+)/;
const fxtwitterRegex = /https?:\/\/fxtwitter\.com\/(.*?)\/status\/(\d+)/;
if (url.match(girlcockRegex)) return convertURL(url, girlcockRegex, "fxtwitter.com");
if (url.match(fxtwitterRegex)) return convertURL(url, fxtwitterRegex, "girlcockx.com");
// if we got this far, somethings not right but we'll try twitter before giving up
const twitterRegex = /https?:\/\/x\.com\/(.*?)\/status\/(\d+)/;
if (url.match(twitterRegex)) return convertURL(url, twitterRegex, "girlcockx.com");
return url; // give up, we'll just return the original URL
}
// what actually listens for the button press and calls swapify
client.on(Events.InteractionCreate, async interaction => {
if (interaction.isButton()) {
if (interaction.customId === 'swap_twitter') {
try {
await interaction.update(swapify(interaction.message.content));
} catch (error) { // honestly the swapify function has its own error handling and it should be fine but whatever
console.error(error);
await interaction.reply({ content: "Something went wrong trying to swap the URL", ephemeral: true });
}
}
return;
}
});
client.once(Events.ClientReady, readyClient => {
console.log(`Discord: Connected as ${readyClient.user.tag}`);
client.user.setActivity(config.status, { type: ActivityType.Custom });
});
client.login(config.token);
client.on(Events.MessageCreate, message => {
// if we smell a twitter link, girlcock it!
const twitterRegex = /https?:\/\/x\.com\/(.*?)\/status\/(\d+)/;
const regexProfile = message.content.match(twitterRegex);
if (regexProfile) {
const cocklink = convertURL(regexProfile[0], twitterRegex, "girlcockx.com")
message.channel.send({ content: cocklink, flags: MessageFlags.SuppressNotifications, components: [swapRow] })
message.suppressEmbeds().catch(err =>
// this next bit just cuts down the error to the important part, which will usually end up being "no permissions"
console.error("Removing original embed failed: " + err.stack?.split('\n')[0] || err.message || String(err).split('\n')[0])
)
}
if (message.content.startsWith('!status') && config.parentsAndOrGuardians.includes(message.author.id)) {
let status = message.content.substring('!status'.length).trim();
client.user.setActivity(status, { type: ActivityType.Custom });
config.status = status;
}
// wouldnt it be funny to react to 1 in like 1000 messages with emoji from a list
if (Math.random() < 0.001 && !message.author.bot) {
const customEmojis = [
'Shitten:1430413059574206555',
'BLOWSUP:1430413011918651503',
'grin_cat:1445254917991436449'
];
const randomEmoji = customEmojis[Math.floor(Math.random() * customEmojis.length)];
message.react(randomEmoji);
}
});
// funny auto mpreg react
const mpregs = [
'mpreg01:1434029622206398556',
'mpreg02:1434029708038639807',
'mpreg03:1434029731321352192',
'mpreg04:1434029755619086517',
'mpreg05:1434029779514032228',
'mpreg06:1434029803358523482',
'mpreg07:1434029827681161266',
'mpreg08:1434029848866717798',
'mpreg09:1434029865593606215',
'mpreg10:1434029885009166467',
'mpreg11:1434029910158217327',
'mpreg12:1434029928768077865',
'mpreg13:1434029953346830417',
'mpreg14:1434029984808304730',
'mpreg15:1434030008124309585',
'mpreg16:1434030025144795207',
'mpreg17:1434030048586760303',
'mpreg18:1434030067419451402',
'mpreg19:1434030085794435092'
];
client.on(Events.MessageReactionAdd, (reaction, user) => {
if (reaction.emoji.name === '🫃' && !user.bot) {
reaction.message.react('🫃');
for (const mpreg of mpregs) {
reaction.message.react(mpreg).catch(err => console.error(err.stack?.split('\n')[0] || err.message || String(err).split('\n')[0]));
}
}
});
// command handling for ./commands
const fs = require('fs');
const path = require('node:path');
client.commands = new Collection();
const commandsPath = path.join(__dirname, 'commands');
const commandFiles = fs.readdirSync(commandsPath).filter(file => file.endsWith('.js'));
for (const file of commandFiles) {
const filePath = path.join(commandsPath, file);
const command = require(filePath);
if ('data' in command && 'execute' in command) {
client.commands.set(command.data.name, command);
console.debug(`Commands: Registered "${command.data.name}"`);
} else {
console.log(`[WARNING] The command at ${filePath} is missing a required "data" or "execute" property.`);
}
}
client.on(Events.InteractionCreate, async interaction => {
if (!interaction.isChatInputCommand()) return;
const command = interaction.client.commands.get(interaction.commandName);
if (!command) {
console.error(`No command matching ${interaction.commandName} was found.`);
return;
} try {
console.debug(`Command: Executing ${interaction.commandName}`);
await command.execute(interaction);
} catch (error) {
console.error(error);
if (interaction.replied || interaction.deferred) {
await interaction.followUp({ content: 'There was an error while executing this command!', flags: MessageFlags.Ephemeral });
} else {
await interaction.reply({ content: 'There was an error while executing this command!', flags: MessageFlags.Ephemeral });
}
}
});