This commit is contained in:
parent
1fd5f6cc6a
commit
bb81ff2e16
4 changed files with 138 additions and 0 deletions
42
commands/admin/whitelist.js
Normal file
42
commands/admin/whitelist.js
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
const sqlite3 = require('sqlite3').verbose();
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
name: 'whitelist',
|
||||||
|
description: 'Whitelist different commands that need whitelisting.',
|
||||||
|
admin: true,
|
||||||
|
async execute({message, args, prefix}) {
|
||||||
|
if(args < 2){
|
||||||
|
message.channel.send(`You need to supply the command and channel that you want to whitelist\n\`${prefix}whitelist <command> <server_id>\``);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let command = args[0];
|
||||||
|
let guild = args[1];
|
||||||
|
// TODO: First check if the bot has access to that guild before whitelisting.
|
||||||
|
const databasePath = 'data/database.db'
|
||||||
|
const db = new sqlite3.Database(databasePath)
|
||||||
|
let err = false;
|
||||||
|
await new Promise((resolve, reject)=>{
|
||||||
|
db.run(`INSERT INTO whitelist (
|
||||||
|
serverId,
|
||||||
|
command,
|
||||||
|
dateAdded
|
||||||
|
) VALUES (?, ?, ?)`,
|
||||||
|
[
|
||||||
|
guild,
|
||||||
|
command,
|
||||||
|
new Date().getTime()
|
||||||
|
], function (error) {
|
||||||
|
if (error) {
|
||||||
|
console.error(error);
|
||||||
|
err = true;
|
||||||
|
resolve();
|
||||||
|
}else{
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})
|
||||||
|
if(!err)
|
||||||
|
message.channel.send("Command has been whitelisted in this server.")
|
||||||
|
else message.channel.send("Could not whitelist the server with that command. Check the logs.")
|
||||||
|
}
|
||||||
|
};
|
72
commands/misc/chat.js
Normal file
72
commands/misc/chat.js
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
require("dotenv").config();
|
||||||
|
const sqlite3 = require('sqlite3').verbose();
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
name: 'chat',
|
||||||
|
description: 'A chat command that uses an LLM to answer your prompts (server must be whitelisted)',
|
||||||
|
async execute({ message, args }) {
|
||||||
|
// TODO: Externalize the whitelist checking into a the message function with a variable export. And cache it.
|
||||||
|
// Have a global collection that gets created on launch from the database, the collection uses the guild ID as a key and has an array of commands that are whitelisted.
|
||||||
|
// Just write to both the database and this collection when a new command gets whitelisted.
|
||||||
|
const db = new sqlite3.Database('data/database.db');
|
||||||
|
let isWhitelisted = false;
|
||||||
|
await new Promise((resolve, reject) => {
|
||||||
|
db.get(`SELECT * FROM whitelist WHERE serverId = ? AND command = ?`, [message.guild.id, this.name],
|
||||||
|
function (error, row){
|
||||||
|
if(error){
|
||||||
|
console.error(error);
|
||||||
|
resolve("");
|
||||||
|
}else{
|
||||||
|
if(row === undefined){
|
||||||
|
resolve();
|
||||||
|
}else {
|
||||||
|
isWhitelisted = true;
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
if(!isWhitelisted){
|
||||||
|
message.channel.send("This server is not whitelisted. The bot admin needs to whitelist the server for this command to work.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(args.length === 0){
|
||||||
|
message.channel.send("You have to set your prompt in the arguments");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const prompt = args.join(" ");
|
||||||
|
let answer = "";
|
||||||
|
const initialMessage = await message.channel.send("Generating response... This may take a moment.")
|
||||||
|
message.channel.sendTyping();
|
||||||
|
await fetch(`https://openrouter.ai/api/v1/chat/completions`, {
|
||||||
|
method: `POST`,
|
||||||
|
headers: {
|
||||||
|
"Authorization": `Bearer ${process.env.OPENROUTER_API_KEY}`,
|
||||||
|
"Content-Type": `application/json`
|
||||||
|
},
|
||||||
|
body: JSON.stringify({
|
||||||
|
"model": `deepseek/deepseek-chat-v3-0324:free`,
|
||||||
|
"messages": [
|
||||||
|
{
|
||||||
|
"role": `user`,
|
||||||
|
"content": prompt
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"max_tokens": 100
|
||||||
|
})
|
||||||
|
}).then(response => response.json()).then(data => {
|
||||||
|
answer = data.choices[0].message.content;
|
||||||
|
}).catch(error => {
|
||||||
|
console.error(error);
|
||||||
|
});
|
||||||
|
if(answer.length > 0){
|
||||||
|
if(answer.length > 1999){
|
||||||
|
initialMessage.edit("Unfortunately the length of the message was longer than what discord allows.")
|
||||||
|
}
|
||||||
|
initialMessage.edit(answer)
|
||||||
|
}else {
|
||||||
|
initialMessage.edit("Something went wrong. The owner should check the console.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
|
@ -18,6 +18,8 @@ async function checkAndConvertJSONToSQL(){
|
||||||
}
|
}
|
||||||
const createDatabaseTables = require('./server/createDatabaseTables');
|
const createDatabaseTables = require('./server/createDatabaseTables');
|
||||||
const createLastfmTable = require('./server/createLastfmTable');
|
const createLastfmTable = require('./server/createLastfmTable');
|
||||||
|
const createWhitelistTable = require('./server/createWhitelistTable.js')
|
||||||
|
createWhitelistTable();
|
||||||
createLastfmTable();
|
createLastfmTable();
|
||||||
checkAndConvertJSONToSQL();
|
checkAndConvertJSONToSQL();
|
||||||
const { Collection, Client, GatewayIntentBits, Partials } = require('discord.js');
|
const { Collection, Client, GatewayIntentBits, Partials } = require('discord.js');
|
||||||
|
|
22
server/createWhitelistTable.js
Normal file
22
server/createWhitelistTable.js
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
const sqlite3 = require('sqlite3').verbose();
|
||||||
|
module.exports = async function () {
|
||||||
|
const db = new sqlite3.Database('data/database.db');
|
||||||
|
return new Promise ((resolve, reject)=>{
|
||||||
|
db.run(
|
||||||
|
`CREATE TABLE IF NOT EXISTS whitelist (
|
||||||
|
serverId TEXT PRIMARY KEY,
|
||||||
|
command TEXT,
|
||||||
|
dateAdded INTEGER)`,
|
||||||
|
(err) => {
|
||||||
|
if (err) {
|
||||||
|
console.error(`Error while creating table 'whitelist': ${err}`);
|
||||||
|
reject(err);
|
||||||
|
} else {
|
||||||
|
console.log("Table 'whitelist' created successfully.");
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
db.close();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
})
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue