2025-12-10 14:46:09 +03:00
# Telegram Video Download Bot
2025-12-12 12:39:11 +03:00
Telegram бот для скачивания видео с YouTube, Instagram, TikTok, VK и Yapfiles. Микросервисная архитектура с раздельными сервисами для каждого источника.
2025-12-11 01:07:04 +03:00
## Архитектура
Проект разделен на микросервисы:
- **Основной бот** (в корне проекта) - Telegram бот, обрабатывает сообщения и оркестрирует запросы к сервисам
- **youtube-downloader** - сервис для скачивания с YouTube (порт 5557)
- **instagram-downloader** - сервис для скачивания с Instagram (порт 5556)
- **vk-downloader** - сервис для скачивания с VK (порт 5555)
2025-12-12 12:39:11 +03:00
- **yapfiles-downloader** - сервис для скачивания с Yapfiles (порт 5558)
- **tiktok-downloader** - сервис для скачивания с TikTok (порт 5559)
2025-12-11 01:07:04 +03:00
Каждый сервис работает в отдельном Docker контейнере и может быть развернут независимо.
2025-12-10 14:46:09 +03:00
2025-12-10 16:22:18 +03:00
## Возможности
- 📹 Скачивание видео с YouTube
- 📸 Скачивание видео с Instagram (требуются cookies)
2025-12-12 12:39:11 +03:00
- 🎵 Скачивание видео с TikTok
2025-12-11 01:07:04 +03:00
- 🎬 Скачивание видео с VK
2025-12-12 12:39:11 +03:00
- 📁 Скачивание видео с Yapfiles
- 🌍 Локализация интерфейса (русский/английский) на основе языка пользователя
2025-12-10 16:22:18 +03:00
- 📊 Статистика скачанных видео и пользователей
- 🔄 Автоматическое сохранение статистики в базу данных
2025-12-11 01:07:04 +03:00
- 👥 Работа в группах с автоматическим обнаружением ссылок
2025-12-12 12:39:11 +03:00
- 📢 Рассылка сообщений всем пользователям (`broadcast.py` )
## Команды бота
- `/start` — начало работы с ботом
- `/stat` — статистика: количество пользователей и скачанных видео
- `/support` — информация о боте и контакт автора
2025-12-10 16:22:18 +03:00
## Требования
- Docker и Docker Compose
- Telegram Bot Token (получить у [@BotFather ](https://t.me/BotFather ))
- Для Instagram: файл с cookies (см. раздел Instagram ниже)
## Быстрый старт
### 1. Клонирование репозитория
2025-12-10 14:46:09 +03:00
```bash
2025-12-10 16:22:18 +03:00
git clone < repository_url >
cd videoDownloadBot
2025-12-10 14:46:09 +03:00
```
2025-12-10 16:22:18 +03:00
### 2. Настройка переменных окружения
2025-12-11 01:07:04 +03:00
Скопируйте `.env.example` в `.env` в корне проекта и заполните:
2025-12-10 16:22:18 +03:00
```bash
cp .env.example .env
nano .env # или используйте любой редактор
```
**Необходимые переменные:**
```env
TELEGRAM_BOT_TOKEN=your_telegram_bot_token_here
TELEGRAM_BOT_USERNAME=your_bot_username
2025-12-11 01:07:04 +03:00
# Downloader Services URLs
2025-12-12 12:39:11 +03:00
YOUTUBE_DOWNLOADER_URL=http://localhost:5557
INSTAGRAM_DOWNLOADER_URL=http://localhost:5556
VK_DOWNLOADER_URL=http://localhost:5555
YAPFILES_DOWNLOADER_URL=http://localhost:5558
TIKTOK_DOWNLOADER_URL=http://localhost:5559
2025-12-10 16:22:18 +03:00
```
### 3. Настройка Instagram (опционально)
Если планируете скачивать видео с Instagram:
2025-12-11 01:07:04 +03:00
1. Экспортируйте cookies из браузера (см. `instagram-downloader/INSTAGRAM_COOKIES_INSTRUCTIONS.md` )
2. Сохраните файл как `instagram_cookies.txt` в папке `instagram-downloader/`
2025-12-10 17:02:01 +03:00
2025-12-11 01:07:04 +03:00
```bash
cd instagram-downloader
./get_instagram_cookies.sh
```
2025-12-10 14:46:09 +03:00
2025-12-11 01:07:04 +03:00
### 4. Запуск сервисов
2025-12-12 12:39:11 +03:00
**Каждый сервис запускается отдельно:**
2025-12-10 16:22:18 +03:00
```bash
2025-12-12 12:39:11 +03:00
# Запуск сервисов загрузчиков
cd youtube-downloader & & docker compose up -d & & cd ..
cd instagram-downloader & & docker compose up -d & & cd ..
cd vk-downloader & & docker compose up -d & & cd ..
cd yapfiles-downloader & & docker compose up -d & & cd ..
cd tiktok-downloader & & docker compose up -d & & cd ..
# Запуск основного бота (из корня проекта)
2025-12-11 01:07:04 +03:00
docker compose up -d
2025-12-10 16:22:18 +03:00
```
2025-12-12 12:39:11 +03:00
### 5. Проверка статуса
2025-12-10 16:22:18 +03:00
```bash
2025-12-12 12:39:11 +03:00
# Проверка всех сервисов
docker ps | grep -E "(video_download_bot|youtube|instagram|vk|yapfiles|tiktok)"
2025-12-11 01:07:04 +03:00
```
2025-12-12 12:39:11 +03:00
## Порты сервисов
2025-12-11 01:07:04 +03:00
2025-12-12 12:39:11 +03:00
| Сервис | Порт |
|--------|------|
| VK Downloader | 5555 |
| Instagram Downloader | 5556 |
| YouTube Downloader | 5557 |
| Yapfiles Downloader | 5558 |
| TikTok Downloader | 5559 |
2025-12-11 01:07:04 +03:00
2025-12-12 12:39:11 +03:00
## Рассылка сообщений
2025-12-11 01:07:04 +03:00
2025-12-12 12:39:11 +03:00
Скрипт `broadcast.py` позволяет отправить сообщение всем пользователям бота:
2025-12-11 01:07:04 +03:00
```bash
2025-12-12 12:39:11 +03:00
# Простое сообщение
./broadcast.py -y "Текст сообщения"
2025-12-11 01:07:04 +03:00
2025-12-12 12:39:11 +03:00
# С HTML-разметкой
./broadcast.py -y --html '< b > Важно!< / b > Новая функция добавлена.'
2025-12-11 01:07:04 +03:00
2025-12-12 12:39:11 +03:00
# Из файла
./broadcast.py -y --file announcement.txt --html
2025-12-11 01:07:04 +03:00
2025-12-12 12:39:11 +03:00
# Посмотреть список пользователей
./broadcast.py --list
2025-12-11 01:07:04 +03:00
```
2025-12-10 14:46:09 +03:00
## Структура проекта
2025-12-10 16:22:18 +03:00
```
videoDownloadBot/
2025-12-11 01:07:04 +03:00
├── bot.py # Код основного Telegram бота
2025-12-12 12:39:11 +03:00
├── broadcast.py # Скрипт для рассылки сообщений
2025-12-11 01:07:04 +03:00
├── requirements.txt # Python зависимости бота
├── Dockerfile # Образ для бота
2025-12-12 12:39:11 +03:00
├── docker-compose.yml # Конфигурация бота
├── .env.example # Пример конфигурации
├── data/ # База данных (bot.db)
├── video/ # Скачанные видео
2025-12-11 01:07:04 +03:00
├── youtube-downloader/ # Сервис для YouTube
├── instagram-downloader/ # Сервис для Instagram
2025-12-12 12:39:11 +03:00
├── vk-downloader/ # Сервис для VK
├── yapfiles-downloader/ # Сервис для Yapfiles
├── tiktok-downloader/ # Сервис для TikTok
├── README.md # Этот файл
└── ARCHITECTURE.md # Описание архитектуры
2025-12-10 16:22:18 +03:00
```
2025-12-11 01:07:04 +03:00
## API Endpoints
2025-12-10 16:22:18 +03:00
2025-12-11 01:07:04 +03:00
В с е сервисы загрузчиков предоставляют одинаковый API:
- `GET /health` - проверка здоровья сервиса
- `POST /download/stream` - скачивание видео (возвращает бинарные данные)
```json
POST /download/stream
Content-Type: application/json
{
"url": "https://youtube.com/watch?v=..."
}
2025-12-10 16:22:18 +03:00
```
2025-12-11 01:07:04 +03:00
## Обновление
2025-12-10 16:22:18 +03:00
```bash
2025-12-11 01:07:04 +03:00
git pull
2025-12-12 12:39:11 +03:00
# Пересобрать и перезапустить основной бот
docker compose down & & docker compose up -d --build
2025-12-11 01:07:04 +03:00
2025-12-12 12:39:11 +03:00
# Пересобрать сервисы загрузчиков
cd youtube-downloader & & docker compose up -d --build & & cd ..
cd instagram-downloader & & docker compose up -d --build & & cd ..
cd vk-downloader & & docker compose up -d --build & & cd ..
cd yapfiles-downloader & & docker compose up -d --build & & cd ..
cd tiktok-downloader & & docker compose up -d --build & & cd ..
2025-12-10 16:22:18 +03:00
```
2025-12-12 12:39:11 +03:00
## Локализация
2025-12-10 16:22:18 +03:00
2025-12-12 12:39:11 +03:00
Бот автоматически определяет язык пользователя из настроек Telegram:
- Если язык начинается с `ru` — интерфейс на русском
- Иначе — интерфейс на английском
2025-12-10 16:22:18 +03:00
2025-12-12 12:39:11 +03:00
Язык сохраняется в базе данных для каждого пользователя.
2025-12-10 16:22:18 +03:00
## Troubleshooting
### Бот не отвечает
- Проверьте логи: `docker compose logs bot`
- Убедитесь, что токен правильный в `.env`
2025-12-11 01:07:04 +03:00
- Проверьте, что все сервисы запущены и доступны
2025-12-10 16:22:18 +03:00
2025-12-12 12:39:11 +03:00
### Сервис не работает
- Проверьте логи сервиса: `cd <service>-downloader && docker compose logs -f`
- Проверьте URL в `.env`
- Для Instagram: проверьте валидность cookies
2025-12-10 16:22:18 +03:00
### База данных не сохраняется
2025-12-12 12:39:11 +03:00
- Проверьте права на папку `data/`
2025-12-10 16:22:18 +03:00
- Убедитесь, что volume смонтирован в `docker-compose.yml`
## Лицензия
MIT
## Поддержка
2025-12-10 14:46:09 +03:00
2025-12-12 12:39:11 +03:00
При возникновении проблем создайте issue в репозитории или свяжитесь с автором: @rvrubel