Compare commits

..

No commits in common. "f8b98de8b0ad64c673d0941af18e53b4760a6db5" and "18611835cb3a242713b3678c0cbc2882b380c0fb" have entirely different histories.

2 changed files with 65 additions and 158 deletions

154
bot.js
View File

@ -5,9 +5,8 @@ const { OpenRouterClient } = require('openrouter-kit');
const { getPrompt } = require('./prompts.js');
const logger = require('./logger.js');
const callAI = require("./requestAI");
const {searchInPrompts, saveInPrompts} = require("./promptResponser");
const {searchInCache, searchInPrompts, saveInPrompts} = require("./promptResponser");
const INSTRUCTIONS = require("./promptGen");
const {sendHelp} = require("./infoSender");
require('dotenv').config();
const char = {name:'marina'}
class TelegramHistoryBot {
@ -30,16 +29,14 @@ class TelegramHistoryBot {
this.init();
}
async isAdmin(ctx, userId = ctx.from.id) {
isAdmin (ctx, userId = ctx.from.id) {
try {
const member = await ctx.getChatMember(userId)
const member = ctx.getChatMember(userId)
return ['creator', 'administrator'].includes(member.status)
} catch (error) {
logger.error('Ошибка проверки статуса пользователя:', error)
} catch {
return false
}
}
async init() {
try {
await this.loadHistory();
@ -72,33 +69,13 @@ 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 {
@ -107,7 +84,7 @@ class TelegramHistoryBot {
request = {persona: "Карл Маркс", messages: 22, hours: 0};
}
}
console.log('ищем персону')
let prompt = await searchInPrompts(request["persona"])
if (!prompt) {
logger.info('⚠️ Не найден подходящий prompt для запроса, генерируем...')
@ -116,54 +93,54 @@ class TelegramHistoryBot {
} 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]
this.bot.command('summary_day', async (ctx) => {
// if (!this.isAdmin(ctx)) {
// await ctx.deleteMessage
// return
// }
// 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);
// });
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));
@ -172,9 +149,6 @@ class TelegramHistoryBot {
// Общий обработчик сообщений (исключая команды)
this.bot.on('message', async (ctx) => {
// Пропускаем все команды
if (!isGroupChat(ctx)) {
return;
}
if (ctx.message.text && ctx.message.text.startsWith('/')) {
return;
}
@ -532,26 +506,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' });
}
}
// Запуск бота

View File

@ -1,67 +0,0 @@
/**
* Модуль для отправки справочной информации
*/
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
};