Compare commits
5 Commits
18611835cb
...
f8b98de8b0
| Author | SHA1 | Date | |
|---|---|---|---|
| f8b98de8b0 | |||
| 9f32e97eca | |||
| c0cda72db5 | |||
| 523c533aea | |||
| f22e89a461 |
156
bot.js
156
bot.js
@ -5,8 +5,9 @@ const { OpenRouterClient } = require('openrouter-kit');
|
||||
const { getPrompt } = require('./prompts.js');
|
||||
const logger = require('./logger.js');
|
||||
const callAI = require("./requestAI");
|
||||
const {searchInCache, searchInPrompts, saveInPrompts} = require("./promptResponser");
|
||||
const {searchInPrompts, saveInPrompts} = require("./promptResponser");
|
||||
const INSTRUCTIONS = require("./promptGen");
|
||||
const {sendHelp} = require("./infoSender");
|
||||
require('dotenv').config();
|
||||
const char = {name:'marina'}
|
||||
class TelegramHistoryBot {
|
||||
@ -29,14 +30,16 @@ class TelegramHistoryBot {
|
||||
|
||||
this.init();
|
||||
}
|
||||
isAdmin (ctx, userId = ctx.from.id) {
|
||||
async isAdmin(ctx, userId = ctx.from.id) {
|
||||
try {
|
||||
const member = ctx.getChatMember(userId)
|
||||
const member = await ctx.getChatMember(userId)
|
||||
return ['creator', 'administrator'].includes(member.status)
|
||||
} catch {
|
||||
} catch (error) {
|
||||
logger.error('Ошибка проверки статуса пользователя:', error)
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
async init() {
|
||||
try {
|
||||
await this.loadHistory();
|
||||
@ -69,13 +72,33 @@ class TelegramHistoryBot {
|
||||
}
|
||||
|
||||
setupHandlers() {
|
||||
const isGroupChat = (ctx) => {
|
||||
return ctx.chat.type === 'group' || ctx.chat.type === 'supergroup';
|
||||
};
|
||||
this.bot.start(async (ctx) => {
|
||||
if (isGroupChat(ctx)) {
|
||||
return; // Игнорируем в группах
|
||||
}
|
||||
await sendHelp(ctx);
|
||||
});
|
||||
|
||||
this.bot.command('summy', async (ctx) => {
|
||||
if (!(await this.isAdmin(ctx))) {
|
||||
await ctx.deleteMessage()
|
||||
return
|
||||
}
|
||||
if (!isGroupChat(ctx)) {
|
||||
await ctx.reply('❗ Эта команда работает только в группах');
|
||||
return;
|
||||
}
|
||||
|
||||
const message = ctx.message.text || '';
|
||||
await ctx.deleteMessage();
|
||||
const args = message.replace(/^\/summy(@\w+)?\s*/, ''); // удаляет /summy и возможный @botname
|
||||
const trimmed = args.trim(); // удаляет лишние пробелы по краям, если нужно
|
||||
logger.info('📊 Получена команда /summy с запросом: ' + trimmed);
|
||||
let request = await callAI('', trimmed, 'request');
|
||||
console.log('получили отвкт: ', typeof request, request)
|
||||
|
||||
if (typeof request === 'string') {
|
||||
try {
|
||||
|
||||
@ -84,7 +107,7 @@ console.log('получили отвкт: ', typeof request, request)
|
||||
request = {persona: "Карл Маркс", messages: 22, hours: 0};
|
||||
}
|
||||
}
|
||||
console.log('ищем персону')
|
||||
|
||||
let prompt = await searchInPrompts(request["persona"])
|
||||
if (!prompt) {
|
||||
logger.info('⚠️ Не найден подходящий prompt для запроса, генерируем...')
|
||||
@ -93,54 +116,54 @@ console.log('ищем персону')
|
||||
} else {
|
||||
logger.info('✅ Найден подходящий prompt для запроса')
|
||||
}
|
||||
//handleSummaryCommand
|
||||
|
||||
const options = {persona:request["persona"], promptToUse:prompt}
|
||||
if (request["messages"]>0) {
|
||||
await this.handleSummaryCommand(ctx, 'last', request["messages"], options);
|
||||
} else {
|
||||
await this.handleSummaryCommand(ctx, 'hours', request["hours"], options);
|
||||
}
|
||||
//await ctx.reply(prompt)
|
||||
|
||||
|
||||
});
|
||||
// Команды суммаризации - должны быть ДО обработки обычных сообщений
|
||||
this.bot.command('summary_day', async (ctx) => {
|
||||
// if (!this.isAdmin(ctx)) {
|
||||
// await ctx.deleteMessage
|
||||
// return
|
||||
// }
|
||||
logger.info('📊 Получена команда summary_day');
|
||||
const args = ctx.message.text.split(' ');
|
||||
if (args.length > 1) {
|
||||
char.name=args[1]
|
||||
}
|
||||
await ctx.deleteMessage()
|
||||
await this.handleSummaryCommand(ctx, 'day');
|
||||
});
|
||||
|
||||
this.bot.command('summary_hours', async (ctx) => {
|
||||
logger.info('📊 Получена команда summary_hours');
|
||||
const args = ctx.message.text.split(' ');
|
||||
if (args.length < 2 || isNaN(parseInt(args[1]))) {
|
||||
await ctx.reply('❗ Укажите количество часов: /summary_hours 6');
|
||||
return;
|
||||
}
|
||||
const hours = parseInt(args[1]);
|
||||
await ctx.deleteMessage()
|
||||
await this.handleSummaryCommand(ctx, 'hours', hours);
|
||||
});
|
||||
|
||||
this.bot.command('summary_last', async (ctx) => {
|
||||
logger.info('📊 Получена команда summary_last');
|
||||
const args = ctx.message.text.split(' ');
|
||||
if (args.length < 2 || isNaN(parseInt(args[1]))) {
|
||||
await ctx.reply('❗ Укажите количество сообщений: /summary_last 50');
|
||||
return;
|
||||
}
|
||||
const count = parseInt(args[1]);
|
||||
await ctx.deleteMessage()
|
||||
await this.handleSummaryCommand(ctx, 'last', count);
|
||||
});
|
||||
// this.bot.command('summary_day', async (ctx) => {
|
||||
// // if (!this.isAdmin(ctx)) {
|
||||
// // await ctx.deleteMessage
|
||||
// // return
|
||||
// // }
|
||||
// logger.info('📊 Получена команда summary_day');
|
||||
// const args = ctx.message.text.split(' ');
|
||||
// if (args.length > 1) {
|
||||
// char.name=args[1]
|
||||
// }
|
||||
// await ctx.deleteMessage()
|
||||
// await this.handleSummaryCommand(ctx, 'day');
|
||||
// });
|
||||
//
|
||||
// this.bot.command('summary_hours', async (ctx) => {
|
||||
// logger.info('📊 Получена команда summary_hours');
|
||||
// const args = ctx.message.text.split(' ');
|
||||
// if (args.length < 2 || isNaN(parseInt(args[1]))) {
|
||||
// await ctx.reply('❗ Укажите количество часов: /summary_hours 6');
|
||||
// return;
|
||||
// }
|
||||
// const hours = parseInt(args[1]);
|
||||
// await ctx.deleteMessage()
|
||||
// await this.handleSummaryCommand(ctx, 'hours', hours);
|
||||
// });
|
||||
//
|
||||
// this.bot.command('summary_last', async (ctx) => {
|
||||
// logger.info('📊 Получена команда summary_last');
|
||||
// const args = ctx.message.text.split(' ');
|
||||
// if (args.length < 2 || isNaN(parseInt(args[1]))) {
|
||||
// await ctx.reply('❗ Укажите количество сообщений: /summary_last 50');
|
||||
// return;
|
||||
// }
|
||||
// const count = parseInt(args[1]);
|
||||
// await ctx.deleteMessage()
|
||||
// await this.handleSummaryCommand(ctx, 'last', count);
|
||||
// });
|
||||
|
||||
// Команды помощи
|
||||
//this.bot.command('summary_help', async (ctx) => await this.sendHelp(ctx));
|
||||
@ -149,6 +172,9 @@ console.log('ищем персону')
|
||||
// Общий обработчик сообщений (исключая команды)
|
||||
this.bot.on('message', async (ctx) => {
|
||||
// Пропускаем все команды
|
||||
if (!isGroupChat(ctx)) {
|
||||
return;
|
||||
}
|
||||
if (ctx.message.text && ctx.message.text.startsWith('/')) {
|
||||
return;
|
||||
}
|
||||
@ -506,26 +532,26 @@ ${conversationFlow}`;
|
||||
return summary;
|
||||
}
|
||||
|
||||
async sendHelp(ctx) {
|
||||
const helpText = `
|
||||
🤖 <b>Бот сохраняет всю историю чата</b>
|
||||
|
||||
📊 <b>Команды суммаризации:</b>
|
||||
/summary_day - суммаризация за сутки
|
||||
/summary_hours N - за последние N часов
|
||||
/summary_last N - последние N сообщений
|
||||
|
||||
💡 <b>Примеры:</b>
|
||||
/summary_hours 6 - за последние 6 часов
|
||||
/summary_last 50 - последние 50 сообщений
|
||||
|
||||
ℹ️ Бот сохраняет все сообщения и создает живые истории на основе переписки.
|
||||
|
||||
🔧 Поддерживаются все типы сообщений: текст, фото, видео, аудио, документы, стикеры и др.
|
||||
`.trim();
|
||||
|
||||
await ctx.reply(helpText, { parse_mode: 'HTML' });
|
||||
}
|
||||
// async sendHelp(ctx) {
|
||||
// const helpText = `
|
||||
// 🤖 <b>Бот сохраняет всю историю чата</b>
|
||||
//
|
||||
// 📊 <b>Команды суммаризации:</b>
|
||||
// /summary_day - суммаризация за сутки
|
||||
// /summary_hours N - за последние N часов
|
||||
// /summary_last N - последние N сообщений
|
||||
//
|
||||
// 💡 <b>Примеры:</b>
|
||||
// /summary_hours 6 - за последние 6 часов
|
||||
// /summary_last 50 - последние 50 сообщений
|
||||
//
|
||||
// ℹ️ Бот сохраняет все сообщения и создает живые истории на основе переписки.
|
||||
//
|
||||
// 🔧 Поддерживаются все типы сообщений: текст, фото, видео, аудио, документы, стикеры и др.
|
||||
// `.trim();
|
||||
//
|
||||
// await ctx.reply(helpText, { parse_mode: 'HTML' });
|
||||
// }
|
||||
}
|
||||
|
||||
// Запуск бота
|
||||
|
||||
67
infoSender.js
Normal file
67
infoSender.js
Normal file
@ -0,0 +1,67 @@
|
||||
/**
|
||||
* Модуль для отправки справочной информации
|
||||
*/
|
||||
|
||||
const helpText = `
|
||||
🚀 **САММАРИ БОТ** - *Ваш умный помощник для переписок!*
|
||||
|
||||
✨ *Полностью бесплатный сервис от [Rockzo.ru](https://rockzo.ru)*
|
||||
|
||||
🎭 **Магия персонажей в действии!**
|
||||
Превратите скучную переписку в увлекательный анализ через призму любимых персонажей!
|
||||
|
||||
🔥 **Главная команда:**
|
||||
• \`/summy [ваш запрос]\` - создайте уникальную суммаризацию!
|
||||
|
||||
💡 **Примеры использования:**
|
||||
• \`/summy Проанализируй последние 50 сообщений как Шерлок Холмс\`
|
||||
• \`/summy Виталий Бианки, за последние сутки\`
|
||||
• \`/summy Расскажи как Стив Джобс о наших идеях за 3 часа\`
|
||||
• \`/summy Оцени дискуссию глазами психолога, 100 сообщений\`
|
||||
|
||||
🎨 **Не бойтесь экспериментировать!**
|
||||
• Пробуйте разных персонажей: от классиков до современных героев
|
||||
• Задавайте необычные ракурсы анализа
|
||||
• Выбирайте ЛИБО количество сообщений, ЛИБО временной период
|
||||
• Придумывайте креативные подходы к анализу!
|
||||
|
||||
⚡ **Важная информация:**
|
||||
• 🏢 Работает только в группах и каналах
|
||||
• 👑 Требуются права администратора для использования
|
||||
• 💬 В личке доступна только эта справка
|
||||
• 🆓 **Абсолютно бесплатно навсегда!**
|
||||
• 📊 Указывайте либо количество сообщений, либо временной период (не комбинируйте!)
|
||||
|
||||
🌟 *Превратите каждую переписку в произведение искусства!*
|
||||
|
||||
---
|
||||
💻 Разработано с ❤️ командой **[Rockzo.ru](https://rockzo.ru)**
|
||||
`;
|
||||
|
||||
/**
|
||||
* Отправляет справочное сообщение пользователю
|
||||
* @param {Object} ctx - Контекст Telegraf
|
||||
* @returns {Promise<void>}
|
||||
*/
|
||||
async function sendHelp(ctx) {
|
||||
try {
|
||||
await ctx.reply(helpText, { parse_mode: 'Markdown' });
|
||||
} catch (error) {
|
||||
// Если Markdown не работает, отправляем обычный текст
|
||||
const plainText = helpText.replace(/[`*_]/g, '');
|
||||
await ctx.reply(plainText);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Получить текст справки (без отправки)
|
||||
* @returns {string} Текст справки
|
||||
*/
|
||||
function getHelpText() {
|
||||
return helpText;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
sendHelp,
|
||||
getHelpText
|
||||
};
|
||||
Loading…
Reference in New Issue
Block a user