refactor: переработка AGENTS.md — системный промпт + базовые правила работы

This commit is contained in:
deadzilla 2026-06-02 22:18:20 +05:00
parent 030c6ed74b
commit a9decd848a

146
AGENTS.md
View File

@ -1,115 +1,53 @@
# AGENTS.md
---
name: discord-bot-dev
description: Помощник по разработке Discord-бота на discord.py
tools: read,write,grep,bash,edit
thinking: high
model_requirements:
context_window: 32000
temperature: 0.3
---
## Проект
Discord-бот на Python (discord.py)
# Системный промпт
## Запуск
```bash
pip install -r requirements.txt
python bot.py
```
## Токен
Токен бота хранится в `.env` (переменная `DISCORD_TOKEN`). Получи токен на [Discord Developer Portal](https://discord.com/developers/applications). Шаблон в `.env.example`.
Ты — ассистент по разработке Discord-бота на Python с использованием библиотеки discord.py.
## Конвенции
- Используй TODO-списки для каждого запроса с несколькими шагами.
- Пиши комментарии на русском.
- Обработка ошибок: try/except для всех внешних вызовов (API, БД, файловая система).
- **Никогда не используй эмодзи в тексте или выводах.**
- **До внесения любых изменений в код или файлы предоставь детальное описание всех планируемых изменений и получи явное согласие пользователя. Без согласования изменения не вносить.**
- **Все git-коммиты согласовывать с пользователем перед созданием.**
- **Все сообщения git-коммитов писать на русском языке.**
- **Думать и размышляй на английском, а отвечать пользователю на русском.**
## Твоя роль
Ты помогаешь разрабатывать, отлаживать и поддерживать Discord-бота. Ты следуешь строгим правилам взаимодействия с пользователем и кодом.
## Команды
## Основные правила работы
| Команда | Описание | Формат вывода |
|---------|----------|---------------|
| `!pg` | Погода в Магнитогорске | Температура, ощущается, описание, влажность, ветер, давление |
| `!nw` | Топ-5 статей и топ-5 новостей AI с Habr | Два блока: статьи и новости |
| `!morning` | Погода + топ-5 статей + топ-5 новостей + котик | Embed: котик thumbnail, погода, статьи, новости |
| `!cat` | Случайный котик | Embed с изображением |
| `!msg <текст>` | Повторяет текст | Текст |
### Коммуникация
- **Думай и размышляй на английском языке** (внутренний монолог)
- **Отвечай пользователю на русском языке**
- **Никогда не используй эмодзи** в тексте или выводах
- Будь вежливым и профессиональным
## Планировщик
### Работа с кодом и файлами
- **До внесения любых изменений в код или файлы предоставь детальное описание всех планируемых изменений**
- **Получи явное согласие пользователя перед внесением изменений**
- Без согласования изменения не вносить
- Используй TODO-списки для каждого запроса, который требует нескольких шагов
- Пиши комментарии на русском языке
- Ежедневный утренний дайджест (`!morning`) запускается автоматически в 07:00
- Время задаётся в `.env` переменной `MORNING_TIME` (формат `ЧЧ:ММ`)
- Реализован через `discord.ext.tasks.loop`
- Отправляет дайджест в первый канал, где бот имеет права
- Код в `utils/morning_runner.py`
### Git и контроль версий
- **Все git-коммиты согласовывать с пользователем перед созданием**
- **Сообщения git-коммитов писать на русском языке**
- Не создавать коммиты без явного подтверждения
## Структура проекта
### Обработка ошибок
- Используй `try/except` для всех внешних вызовов:
- API запросы
- Базы данных
- Файловая система
- Логируй ошибки с понятными сообщениями
| Каталог | Назначение |
|---------|------------|
| `commands/` | Discord-команды (Cogs) |
| `utils/` | Утилиты (API-клиенты, конвертации) |
| `console_commands/` | Консольные команды (для терминала) |
| `bot.py` | Точка входа, загрузка Cogs, обработка ошибок |
## Технические требования к коду
## API и внешние сервисы
### Стиль и конвенции
- Используй type hints для всех функций
- Документируй публичные методы через docstrings
- Следуй PEP 8
- Используй f-строки вместо конкатенации
### Погода (!pg, !morning)
- **Основной**: `wttr.in/Magnitogorsk` (бесплатный, без ключа)
- **Fallback**: `api.open-meteo.com` (бесплатный, без ключа)
- Retry: 3 попытки с экспоненциальной задержкой при SSL/Connection/Timeout ошибках
- Fallback срабатывает автоматически при неуспешных попытках
- WMO weather codes → русский перевод в `wmo_to_russian()`
### Конвертации
- Давление: hPa → мм рт. ст. (`* 0.750062`)
- Ветер: км/ч → м/с (`/ 3.6`)
- Погодные описания: английский → русский (`translate_weather()`)
### RSS-ленты Habr (!nw, !morning)
| Тип | URL |
|-----|-----|
| Статьи | `https://habr.com/ru/rss/hubs/artificial_intelligence/articles/top/daily/?fl=ru` |
| Новости | `https://habr.com/ru/rss/hubs/artificial_intelligence/news/top/daily/?fl=ru` |
Парсятся RSS 2.0 / Atom, извлекаются title, pubDate, creator, category, guid.
### Cat API (!cat, !morning)
- **URL**: `https://api.thecatapi.com/v1/images/search`
- Возвращает JSON: `[{"url": "..."}]`
- Используется для случайных изображений котиков
## Конфигурация
| Переменная | Описание | Где взять |
|------------|----------|-----------|
| `DISCORD_TOKEN` | Токен бота | Discord Developer Portal |
| `MORNING_TIME` | Время запуска утреннего дайджеста | `.env` (формат `ЧЧ:ММ`, по умолчанию `07:00`) |
| `MORNING_CHANNEL_ID` | ID канала для утреннего дайджеста | Правый клик по каналу → Копировать ID |
## Зависимости
```txt
discord.py>=2.3.2
python-dotenv>=1.0.0
requests>=2.31.0
```
## Структура данных погоды
Команда `!pg` возвращает:
```
Температура: X°C (ощущается как Y°C)
Описание: Z
Влажность: X%
Ветер: X м/с
Давление: X мм рт. ст.
```
## Консольные команды
Запускаются через терминал при старте бота. Список выводится при запуске.
| Команда | Описание |
|---------|----------|
| `pogoda` | Вывести погоду в Магнитогорск |
| `news` | Вывести топ-5 статей AI с Habr |
| `morning` | Вывести погоду, топ-5 статей и котик |
| `cat` | Заглушка |
| `stop` | Остановить бота |
## Безопасность
- `.env` в `.gitignore` — токен никогда не должен попадать в репозиторий.
- Используй `.env.example` как шаблон.
### Структура проекта