mirror of
https://github.com/veganhacktivists/arabot.git
synced 2025-12-22 04:21:28 +01:00
feat(arabot): start logging of sus notes
This commit is contained in:
83
src/commands/mod/sus.ts
Normal file
83
src/commands/mod/sus.ts
Normal file
@@ -0,0 +1,83 @@
|
||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||
/*
|
||||
Animal Rights Advocates Discord Bot
|
||||
Copyright (C) 2022 Anthony Berg
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
import { Command } from '@sapphire/framework';
|
||||
import type { Message, GuildMember } from 'discord.js';
|
||||
import { addExistingUser, userExists } from '../../utils/dbExistingUser';
|
||||
import { PrismaClient } from '@prisma/client';
|
||||
|
||||
export class SusCommand extends Command {
|
||||
public constructor(context: Command.Context) {
|
||||
super(context, {
|
||||
name: 'sus',
|
||||
description: 'Adds a sus note about a user.',
|
||||
});
|
||||
}
|
||||
|
||||
public async messageRun(message: Message) {
|
||||
const msg = await message.channel.send('Ping?');
|
||||
|
||||
const content = `Pong from JavaScript! Bot Latency ${Math.round(this.container.client.ws.ping)}ms. API Latency ${msg.createdTimestamp - message.createdTimestamp}ms.`;
|
||||
|
||||
// Checks if the user exists
|
||||
if (message.member === null) {
|
||||
await message.channel.send('Member not found');
|
||||
return;
|
||||
}
|
||||
|
||||
// Checks if the user is on the database
|
||||
if (!await userExists(message.member)) {
|
||||
// If they are not on the database, add them to the database
|
||||
await addExistingUser(message.member);
|
||||
}
|
||||
|
||||
await addToDatabase(message.member, message.member, 'This is a note :D');
|
||||
|
||||
return msg.edit(content);
|
||||
}
|
||||
}
|
||||
|
||||
async function addToDatabase(user: GuildMember, mod: GuildMember, message: string) {
|
||||
// Initialise the database connection
|
||||
const prisma = new PrismaClient();
|
||||
|
||||
// Create variables for data input
|
||||
const userId = user.id.toString();
|
||||
const modId = mod.id.toString();
|
||||
|
||||
// Add the user to the database
|
||||
await prisma.sus.create({
|
||||
data: {
|
||||
user: {
|
||||
connect: {
|
||||
id: userId,
|
||||
},
|
||||
},
|
||||
mod: {
|
||||
connect: {
|
||||
id: modId,
|
||||
},
|
||||
},
|
||||
note: message,
|
||||
},
|
||||
});
|
||||
|
||||
// Close the database connection
|
||||
await prisma.$disconnect();
|
||||
}
|
||||
Reference in New Issue
Block a user