-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathblocks.js
149 lines (132 loc) · 4.83 KB
/
blocks.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
// Import required modules
const {
BufferJSON,
WA_DEFAULT_EPHEMERAL,
generateWAMessageFromContent,
proto,
generateWAMessageContent,
generateWAMessage,
prepareWAMessageMedia,
areJidsSameUser,
getContentType,
} = require("@adiwajshing/baileys");
const fs = require("fs");
const util = require("util");
const chalk = require("chalk");
const { Configuration, OpenAIApi } = require("openai");
// Load OpenAI API key configuration from file
let setting = require("./key.json");
// Load custom prompt from file
const customPrompt = fs.readFileSync("custom_prompt.txt", "utf-8");
// Load chat history from file
const chatHistory = readChatHistoryFromFile();
// Utility function to read chat history from file
function readChatHistoryFromFile() {
try {
const data = fs.readFileSync("chat_history.json", "utf-8");
return JSON.parse(data);
} catch (err) {
return {};
}
}
// Utility function to write chat history to file
function writeChatHistoryToFile(chatHistory) {
fs.writeFileSync("chat_history.json", JSON.stringify(chatHistory));
}
// Utility function to update chat history
function updateChatHistory(sender, message) {
// If this is the first message from the sender, create a new array for the sender
if (!chatHistory[sender]) {
chatHistory[sender] = [];
}
// Add the message to the sender's chat history
chatHistory[sender].push(message);
// If the chat history exceeds the maximum length of 20 messages, remove the oldest message
if (chatHistory[sender].length > 20) {
chatHistory[sender].shift();
}
}
// Utility function to fetch OpenAI response with retries
async function fetchOpenAIResponse(messages) {
const configuration = new Configuration({
apiKey: setting.keyopenai,
});
const openai = new OpenAIApi(configuration);
let retries = 5;
let delay = 1000; // Initial delay of 1 second
while (retries > 0) {
try {
const response = await openai.createChatCompletion({
model: "gpt-3.5-turbo",
messages: messages,
});
return response.data.choices[0].message.content;
} catch (error) {
if (error.response && error.response.status === 429) {
console.log(`Rate limited by OpenAI, retrying in ${delay / 1000} seconds...`);
await new Promise((resolve) => setTimeout(resolve, delay));
delay *= 2; // Exponential backoff
retries -= 1;
} else {
throw error;
}
}
}
throw new Error("Failed to fetch response from OpenAI after multiple retries.");
}
// Export function that handles incoming messages
module.exports = sansekai = async (client, m, chatUpdate, store) => {
try {
// If the sender has no chat history, create a new array for the sender
if (!chatHistory[m.sender]) chatHistory[m.sender] = [];
// Get the content of the incoming message
const text = m.text;
const isCmd2 = text.startsWith("!");
const command = text.trim().split(/ +/).shift().toLowerCase();
const args = text.trim().split(/ +/).slice(1);
// If the message is an OpenAI command, do nothing and return
if (command === "ai" || command === "openai") {
// do nothing, this is to ignore the 'ai' and 'openai' commands
}
// If the message is a command, handle the command
else if (isCmd2) {
switch (command) {
case "test":
// add test command functionality here
break;
default:
// add default case here
break;
}
}
// If the message is not a command, use OpenAI to generate a response
else {
// If OpenAI API key is not configured, return and do nothing
if (setting.keyopenai === "ISI_APIKEY_OPENAI_DISINI") return;
// Create chat completion request using previous messages from chat history
const messages = [
{ role: "system", content: customPrompt },
...(chatHistory[m.sender]?.map((msg) => ({ role: msg.role, content: msg.content })) || []),
{ role: "user", content: text },
];
// Use OpenAI to generate response based on chat history and incoming message
const responseContent = await fetchOpenAIResponse(messages);
// Update chat history with incoming message and OpenAI-generated response
updateChatHistory(m.sender, { role: "user", content: text });
updateChatHistory(m.sender, { role: "assistant", content: responseContent });
// Reply to the incoming message with OpenAI-generated response
m.reply(`${responseContent}`);
}
} catch (err) {
// If an error occurs, reply to the incoming message with the error message
m.reply(util.format(err));
}
};
// Watch for changes in this file and reload the code if changes are detected
let file = require.resolve(__filename);
fs.watchFile(file, () => {
fs.unwatchFile(file);
console.log(chalk.redBright(`Update ${__filename}`));
delete require.cache[file];
require(file);
});