feat(arabot): add database commands

This commit is contained in:
smyalygames 2023-02-20 18:02:42 +00:00
parent f8e99ef4f2
commit e0c609cf69
2 changed files with 85 additions and 0 deletions

View File

@ -0,0 +1,38 @@
// SPDX-License-Identifier: GPL-3.0-or-later
/*
Animal Rights Advocates Discord Bot
Copyright (C) 2023 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/>.
I used the Sapphire documentation and parts of the code from the Sapphire CLI to
create this file.
*/
import { Listener } from '@sapphire/framework';
import { setupTypes } from '#utils/database/outreach';
export class EventTypesReadyListener extends Listener {
public constructor(context: Listener.Context, options: Listener.Options) {
super(context, {
...options,
once: true,
event: 'ready',
});
}
public async run() {
await setupTypes();
}
}

View File

@ -0,0 +1,47 @@
import { container } from '@sapphire/framework';
import type { Snowflake } from 'discord.js';
export async function createEvent(
modId: Snowflake,
) {
// Add the user to the database
await container.database.event.create({
data: {
leader: {
connect: {
id: modId,
},
},
type: {
connect: {
type: 'Discord Outreach',
},
},
},
});
}
export async function countTypes() {
const count = await container.database.eventType.count();
return count;
}
export async function createTypes() {
await container.database.eventType.create({
data: {
type: 'Discord Outreach',
},
});
}
export async function setupTypes() {
const types = [
'Discord Outreach',
];
if (types.length === await countTypes()) {
return;
}
await createTypes();
}