llama-cpp-python-djs-bot/llamabot.js

213 lines
6.1 KiB
JavaScript
Raw Normal View History

2023-04-09 16:07:32 +00:00
const Discord = require('discord.js');
const fetch = require('node-fetch');
const emptyResponses = require('./assets/emptyMessages.js');
2023-04-10 17:00:21 +00:00
const { resetResponses, userResetMessages } = require('./assets/resetMessages.js');
const { errorMessages, busyResponses } = require('./assets/errorMessages.js');
2023-04-09 16:07:32 +00:00
require('dotenv').config()
2023-04-09 23:49:51 +00:00
const {
Client,
GatewayIntentBits,
ActivityType,
Partials
} = require('discord.js');
2023-04-09 16:07:32 +00:00
const client = new Client({
2023-04-09 23:49:51 +00:00
intents: [
GatewayIntentBits.DirectMessages,
GatewayIntentBits.Guilds,
GatewayIntentBits.GuildBans,
GatewayIntentBits.GuildMessages,
GatewayIntentBits.MessageContent,
],
partials: [Partials.Channel],
2023-04-09 16:07:32 +00:00
});
// Grab ChannelIDs from the .env file
const channelIDs = process.env.CHANNEL_IDS.split(',');
2023-04-09 16:07:32 +00:00
const conversations = new Map();
function setBusy(userId, isBusy) {
if (conversations.has(userId)) {
conversations.get(userId).busy = isBusy;
} else {
2023-04-10 02:38:38 +00:00
conversations.set(userId, {
busy: isBusy
});
}
}
function isAnyConversationBusy() {
for (const conversation of conversations.values()) {
if (conversation.busy) {
setPresenceBusy()
return true;
}
}
return false;
}
function setPresenceBusy() {
2023-04-09 23:49:51 +00:00
client.user.setPresence({
activities: [{
name: `Processing a Request`,
2023-04-09 23:49:51 +00:00
type: ActivityType.Playing
}],
status: 'dnd',
});
}
function setPresenceOnline() {
client.user.setPresence({
activities: [{
name: `Ready for Request`,
type: ActivityType.Playing
}],
status: 'online',
});
}
client.once('ready', () => {
console.log('Bot is ready.');
2023-04-10 02:38:38 +00:00
setPresenceOnline()
2023-04-09 16:07:32 +00:00
});
client.on('messageCreate', async (message) => {
async function sendRand(array) {
const arrayChoice = array[Math.floor(Math.random() * array.length)];
await message.channel.send(arrayChoice); // give a notification of reset using a human like response.
}
async function sendRandDM(array) {
const arrayChoice = array[Math.floor(Math.random() * array.length)];
await message.author.send(arrayChoice); // give a notification of reset using a human like response.
}
2023-04-09 23:49:51 +00:00
// Only respond in the specified channels
if (!channelIDs.includes(message.channel.id)) {
return;
2023-04-09 23:49:51 +00:00
}
2023-04-09 23:49:51 +00:00
if (message.author.bot) return; // Ignore messages from bots
2023-04-09 16:07:32 +00:00
// Check if any conversation is busy
if (isAnyConversationBusy()) {
// Update bot presence to "Busy"
setPresenceBusy()
message.delete();
sendRandDM(busyResponses);
2023-04-09 23:49:51 +00:00
return;
}
2023-04-09 23:49:51 +00:00
const userID = message.author.id;
let conversation = conversations.get(userID) || {
messages: [],
busy: false
};
if (conversation.messages.length === 0) {
conversation.messages.push({
role: 'user',
2023-04-11 21:46:58 +00:00
content: `Your name is rAi, you code, write and provide any information without any mistakes.`
2023-04-09 23:49:51 +00:00
});
conversation.messages.push({
role: 'user',
2023-04-11 21:46:58 +00:00
content: `My name is ${message.author.username}.`
2023-04-09 23:49:51 +00:00
});
conversation.messages.push({
role: 'assistant',
2023-04-11 21:46:58 +00:00
content: `Hello, ${message.author.username}, how may I help you?`
2023-04-09 23:49:51 +00:00
});
}
2023-04-09 23:49:51 +00:00
if (message.content === '!reset' || message.content === '!r') {
conversations.delete(userID); // Delete user's conversation map if they request reset
sendRand(userResetMessages)
2023-04-09 23:49:51 +00:00
return;
}
2023-04-09 16:07:32 +00:00
// Append user message to conversation history
2023-04-09 23:49:51 +00:00
conversation.messages.push({
role: 'user',
content: message.cleanContent
});
2023-04-09 16:07:32 +00:00
2023-04-09 23:49:51 +00:00
try {
setPresenceBusy()
setBusy(message.author.id, true);
2023-04-09 23:49:51 +00:00
const response = await generateResponse(conversation);
// Append bot message to conversation history
conversation.messages.push({
role: 'assistant',
content: response
});
if (response && response.trim()) {
// Send response to user if it's not empty
await message.channel.send(response);
setPresenceOnline()
setBusy(message.author.id, false);
2023-04-09 23:49:51 +00:00
} else {
// Handle empty response here
sendRand(emptyResponses)
2023-04-09 23:49:51 +00:00
conversations.delete(userID); // Delete user's conversation map if they request reset
2023-04-10 03:18:15 +00:00
sendRand(resetResponses)
setPresenceOnline()
2023-04-09 23:49:51 +00:00
conversation.busy = false;
}
conversations.set(userID, conversation); // Update user's conversation map in memory
} catch (err) {
console.error(err);
sendRand(errorMessages)
} finally {
setPresenceOnline()
setBusy(message.author.id, false);
}
2023-04-09 16:07:32 +00:00
});
async function generateResponse(conversation) {
2023-04-09 23:49:51 +00:00
const controller = new AbortController();
const timeout = setTimeout(() => {
controller.abort();
}, 900000);
const messagesCopy = [...conversation.messages]; // create a copy of the messages array
2023-04-11 15:38:47 +00:00
console.log(conversation)
2023-04-09 23:49:51 +00:00
try {
const response = await fetch(`http://${process.env.ROOT_IP}:${process.env.ROOT_PORT}/v1/chat/completions`, {
2023-04-09 23:49:51 +00:00
method: 'POST',
headers: {
'accept': 'application/json',
'Content-Type': 'application/json'
},
body: JSON.stringify({
messages: messagesCopy // use the copy of the messages array
2023-04-09 23:49:51 +00:00
}),
signal: controller.signal
});
const responseData = await response.json();
2023-04-10 00:42:58 +00:00
console.log(JSON.stringify(responseData))
2023-04-09 23:49:51 +00:00
const choice = responseData.choices[0];
// Remove "user None:" and any text after it from the response
const responseText = choice.message.content.trim();
const startIndex = responseText.indexOf('user None:');
const sanitizedResponse = startIndex === -1 ? responseText : responseText.substring(0, startIndex);
return sanitizedResponse;
} catch (err) {
throw err;
2023-04-09 23:49:51 +00:00
} finally {
clearTimeout(timeout);
}
2023-04-09 16:07:32 +00:00
}
2023-04-09 23:49:51 +00:00
client.login(process.env.THE_TOKEN); // Replace with your bot token