-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathdatabase.js
174 lines (150 loc) · 4.91 KB
/
database.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
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
const sqlite3 = require('sqlite3');
const { open } = require('sqlite');
let dbPromise = null;
async function openDb() {
if (!dbPromise) {
dbPromise = open({
filename: 'data.db',
driver: sqlite3.Database,
});
}
return dbPromise;
}
async function insert(chatid) {
try {
await getChat(chatid);
} catch (e) {
await retry(() => createTable(chatid));
}
}
async function getChat(chatid) {
const retryOptions = {
retries: 3, // Количество попыток выполнить операцию
delay: 100, // Задержка между попытками (в миллисекундах)
};
return await retry(() => fetchChat(chatid), retryOptions);
}
async function createTable(chatid) {
const db = await openDb();
await db.exec(`
CREATE TABLE IF NOT EXISTS peer${chatid}
(peer_id INT DEFAULT ${chatid},
talk INT DEFAULT 1,
gen INT DEFAULT 0,
speed INT DEFAULT 3,
textbase TEXT,
lang TEXT DEFAULT 'en'
)`
);
const result = await db.get(`SELECT * FROM peer${chatid}`);
if (!result) {
await db.run(`INSERT OR IGNORE INTO peer${chatid}
(peer_id, talk, gen, speed, lang)
VALUES (:id, :talk, :gen, :speed, :lang)`, {
':id': chatid,
':talk': 1,
':gen': 0,
':speed': 3,
':lang': 'en',
});
}
}
async function fetchChat(chatid) {
const db = await openDb();
const [chat, textbase] = await Promise.all([
db.get(`SELECT * FROM peer${chatid}`),
db.all(`SELECT textbase FROM peer${chatid} WHERE textbase IS NOT NULL AND textbase != ''`),
]);
chat.textbase = textbase.map(i => i.textbase);
return chat;
}
async function retry(operation, options) {
const { retries = 3, delay = 100 } = options || {};
let error;
for (let i = 0; i <= retries; i++) {
try {
return await operation();
} catch (e) {
error = e;
await new Promise(resolve => setTimeout(resolve, delay));
}
}
throw error; // Если все попытки не удалось выполнить операцию, выбрасываем ошибку
}
async function chatExists(chatid) {
const db = await openDb();
const chat = await db.get(
`SELECT name FROM sqlite_master WHERE type='table' AND name="peer${chatid}";`
);
return chat !== undefined;
}
async function deleteFirst(chatid) {
const retryOptions = {
retries: 3, // Количество попыток выполнить операцию
delay: 100, // Задержка между попытками (в миллисекундах)
};
return await retry(async () => {
const db = await openDb();
try {
await new Promise(resolve => setTimeout(resolve, 1000)); // Добавляем задержку в 1 секунду перед удалением первой строки
await db.run(
`DELETE FROM peer${chatid} WHERE ROWID = (SELECT ROWID FROM peer${chatid} LIMIT 1)`
);
return "Успешно удалена первая строка.";
} catch (e) {
console.log(`Ошибка при удалении первой строки: ${e}`);
throw e; // Пробрасываем ошибку, чтобы выполнить повторную попытку
}
}, retryOptions);
}
async function updateText(chatid, text) {
const db = await openDb();
await db.run(
`INSERT OR IGNORE INTO peer${chatid} (textbase) VALUES (?)`,
[text]
);
}
async function changeField(chatid, field, key) {
const db = await openDb();
await db.run(`UPDATE peer${chatid} SET ${field} = ?`, [key]);
}
async function clearText(chatid) {
const db = await openDb();
await db.run(`UPDATE peer${chatid} SET textbase = NULL`);
}
async function sender() {
const db = await openDb();
const cursor = await db.all(`SELECT name FROM sqlite_master WHERE type='table'`);
const chats = cursor.map(i => i.name.split('peer')[1]);
return chats;
}
async function deleteNulls(chatid) {
const db = await openDb();
await db.run(`DELETE FROM peer${chatid} WHERE textbase IS NULL`);
}
async function remove(chatid, args) {
const db = await openDb();
await db.run(`DELETE FROM peer${chatid} WHERE textbase LIKE ?`, [`%${args}%`]);
}
async function add_new_field(field) {
const db = await openDb();
const cursor = await db.all(`SELECT name FROM sqlite_master WHERE type='table'`);
for (let i of cursor) {
await new Promise(resolve => setTimeout(resolve, 100)); // Пауза в 100 миллисекунд перед каждой итерацией
await db.run(`ALTER TABLE ${i.name} ADD COLUMN ${field} TEXT`);
console.log(i.name);
}
console.log('finish');
}
module.exports = {
insert,
getChat,
updateText,
changeField,
clearText,
sender,
chatExists,
deleteNulls,
remove,
deleteFirst,
};