2025-12-10 14:46:09 +03:00
# Telegram Video Download Bot
2025-12-11 01:07:04 +03:00
Telegram бот для скачивания видео с YouTube, Instagram и VK. Микросервисная архитектура с раздельными сервисами для каждого источника.
## Архитектура
Проект разделен на микросервисы:
- **Основной бот** (в корне проекта) - Telegram бот, обрабатывает сообщения и оркестрирует запросы к сервисам
- **youtube-downloader** - сервис для скачивания с YouTube (порт 5557)
- **instagram-downloader** - сервис для скачивания с Instagram (порт 5556)
- **vk-downloader** - сервис для скачивания с VK (порт 5555)
Каждый сервис работает в отдельном Docker контейнере и может быть развернут независимо.
2025-12-10 14:46:09 +03:00
2025-12-10 16:22:18 +03:00
## Возможности
- 📹 Скачивание видео с YouTube
- 📸 Скачивание видео с Instagram (требуются cookies)
2025-12-11 01:07:04 +03:00
- 🎬 Скачивание видео с VK
2025-12-10 16:22:18 +03:00
- 📊 Статистика скачанных видео и пользователей
- 🔄 Автоматическое сохранение статистики в базу данных
2025-12-11 01:07:04 +03:00
- 👥 Работа в группах с автоматическим обнаружением ссылок
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
# Для локальной разработки через docker-compose используются внутренние имена сервисов
YOUTUBE_DOWNLOADER_URL=http://youtube-downloader:5000
INSTAGRAM_DOWNLOADER_URL=http://instagram-downloader:5000
VK_DOWNLOADER_URL=http://vk-downloader:5000
2025-12-10 16:22:18 +03:00
```
- **TELEGRAM_BOT_TOKEN** — токен бота от @BotFather
- **TELEGRAM_BOT_USERNAME** — username бота (без @), используется в подписи видео
2025-12-11 01:07:04 +03:00
- **YOUTUBE_DOWNLOADER_URL** — URL YouTube сервиса (для docker-compose: `http://youtube-downloader:5000` , для продакшена: `http://<ip>:5557` )
- **INSTAGRAM_DOWNLOADER_URL** — URL Instagram сервиса (для docker-compose: `http://instagram-downloader:5000` , для продакшена: `http://<ip>:5556` )
- **VK_DOWNLOADER_URL** — URL VK сервиса (для docker-compose: `http://vk-downloader:5000` , для продакшена: `http://<ip>:5555` )
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 16:22:18 +03:00
3. Формат: Netscape cookies file
2025-12-11 01:07:04 +03:00
**Быстрое получение cookies через скрипт:**
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
Или обновление существующих cookies:
2025-12-10 16:22:18 +03:00
```bash
2025-12-11 01:07:04 +03:00
cd instagram-downloader
./update_instagram_cookies.sh
2025-12-10 16:22:18 +03:00
```
2025-12-11 01:07:04 +03:00
**Примечание:** Без cookies Instagram может блокировать запросы. При первом запуске обновите cookies вручную.
### 4. Запуск сервисов
**Важно:** Каждый сервис запускается отдельно на своем хосте (или на одном хосте, но отдельными командами).
#### Запуск основного бота
2025-12-10 16:22:18 +03:00
```bash
2025-12-11 01:07:04 +03:00
# Из корня проекта
docker compose up -d
2025-12-10 16:22:18 +03:00
```
2025-12-11 01:07:04 +03:00
Это запустит только основной Telegram бот.
#### Запуск сервисов загрузчиков
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
# Запуск YouTube сервиса (порт 5557)
cd youtube-downloader
2025-12-10 16:22:18 +03:00
docker compose up -d
2025-12-11 01:07:04 +03:00
# Запуск Instagram сервиса (порт 5556)
cd ../instagram-downloader
docker compose up -d
# Запуск VK сервиса (порт 5555)
cd ../vk-downloader
docker compose up -d
```
**Порядок запуска:** Сначала запустите сервисы загрузчиков, затем основной бот.
#### Раздельное развертывание на разных хостах (рекомендуется для продакшена)
**Хост 1 (с VPN для YouTube/Instagram):**
- YouTube сервис (порт 5557)
- Instagram сервис (порт 5556)
- Основной бот
**Хост 2 (без VPN для VK):**
- VK сервис (порт 5555)
В `.env` файле в корне проекта на хосте 1 укажите IP адреса сервисов:
```env
YOUTUBE_DOWNLOADER_URL=http://localhost:5557
INSTAGRAM_DOWNLOADER_URL=http://localhost:5556
VK_DOWNLOADER_URL=http://< ip_х о с та _2 > :5555
2025-12-10 16:22:18 +03:00
```
2025-12-11 01:07:04 +03:00
### 5. Проверка статуса
Проверить статус сервисов:
```bash
# Основной бот (из корня проекта)
docker compose ps
# Сервисы загрузчиков (из соответствующих папок)
cd youtube-downloader & & docker compose ps
cd ../instagram-downloader & & docker compose ps
cd ../vk-downloader & & docker compose ps
```
Просмотр логов:
```bash
# Основной бот (из корня проекта)
docker compose logs -f bot
# Сервисы загрузчиков (из соответствующих папок)
cd youtube-downloader & & docker compose logs -f
cd ../instagram-downloader & & docker compose logs -f
cd ../vk-downloader & & docker compose logs -f
```
2025-12-10 14:46:09 +03:00
## Использование
2025-12-10 16:22:18 +03:00
1. Найдите вашего бота в Telegram по username
2025-12-10 14:46:09 +03:00
2. Отправьте команду `/start`
2025-12-10 16:22:18 +03:00
3. Отправьте ссылку на видео (YouTube, Instagram или VK)
4. Дождитесь скачивания и получите файл
2025-12-11 01:07:04 +03:00
### Работа в группах
Добавьте бота в группу и дайте ему права администратора (нужно право на удаление сообщений). После этого бот будет автоматически находить ссылки на видео в сообщениях участников, скачивать их и отправлять прямо в группу, заменяя исходное сообщение с о ссылкой.
2025-12-10 16:22:18 +03:00
### Команды
- `/start` — начало работы с ботом
- `/stat` — статистика: количество пользователей и скачанных видео
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 бота
├── requirements.txt # Python зависимости бота
├── Dockerfile # Образ для бота
├── docker-compose.yml # Оркестратор всех сервисов
├── .env.example # Пример конфигурации
├── youtube-downloader/ # Сервис для YouTube
│ ├── app.py # Flask API сервис
│ ├── requirements.txt # Python зависимости
│ ├── Dockerfile # Образ для YouTube сервиса
│ └── docker-compose.yml # Конфигурация YouTube сервиса
├── instagram-downloader/ # Сервис для Instagram
│ ├── app.py # Flask API сервис
│ ├── requirements.txt # Python зависимости
│ ├── Dockerfile # Образ для Instagram сервиса
│ ├── docker-compose.yml # Конфигурация Instagram сервиса
│ ├── instagram_cookies.txt # Cookies для Instagram (создать вручную)
│ ├── get_instagram_cookies.sh # Скрипт для получения cookies
│ ├── update_instagram_cookies.sh # Скрипт для обновления cookies
│ ├── INSTAGRAM_COOKIES_INSTRUCTIONS.md # Инструкции по cookies
│ └── README.md # Документация сервиса
├── vk-downloader/ # Сервис для VK
│ ├── app.py # Flask API сервис
│ ├── requirements.txt # Python зависимости
│ ├── Dockerfile # Образ для VK сервиса
│ └── docker-compose.yml # Конфигурация VK сервиса
└── README.md # Этот файл
2025-12-10 16:22:18 +03:00
```
2025-12-11 01:07:04 +03:00
## Порты сервисов
2025-12-10 16:22:18 +03:00
2025-12-11 01:07:04 +03:00
- **Основной бот**: не требует внешних портов (работает через Telegram API)
- **YouTube Downloader**: порт 5557
- **Instagram Downloader**: порт 5556
- **VK Downloader**: порт 5555
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
# Пересобрать и перезапустить основной бот (из корня проекта)
docker compose build & & docker compose up -d
# Пересобрать и перезапустить каждый сервис загрузчика отдельно
cd youtube-downloader & & docker compose build & & docker compose up -d
cd ../instagram-downloader & & docker compose build & & docker compose up -d
cd ../vk-downloader & & docker compose build & & docker compose up -d
2025-12-10 16:22:18 +03:00
```
## Остановка
```bash
2025-12-11 01:07:04 +03:00
# Остановить основной бот (из корня проекта)
2025-12-10 16:22:18 +03:00
docker compose down
2025-12-11 01:07:04 +03:00
# Остановить каждый сервис загрузчика отдельно
cd youtube-downloader & & docker compose down
cd ../instagram-downloader & & docker compose down
cd ../vk-downloader & & docker compose down
2025-12-10 16:22:18 +03:00
```
## Развертывание на продакшене
### Вариант 1: В с е на одном хосте (с VPN)
1. Настройте VPN для доступа к YouTube и Instagram
2025-12-11 01:07:04 +03:00
2. Запустите каждый сервис отдельно в своей папке
3. В `.env` в корне проекта укажите: `http://localhost:5557` , `http://localhost:5556` , `http://localhost:5555`
2025-12-10 16:22:18 +03:00
### Вариант 2: Раздельное развертывание (рекомендуется)
**Хост 1 (с VPN):**
2025-12-11 01:07:04 +03:00
- Основной бот
- YouTube сервис
- Instagram сервис
- В `.env` в корне: `YOUTUBE_DOWNLOADER_URL=http://localhost:5557` , `INSTAGRAM_DOWNLOADER_URL=http://localhost:5556` , `VK_DOWNLOADER_URL=http://<ip_х о с та _2>:5555`
2025-12-10 16:22:18 +03:00
**Хост 2 (без VPN):**
2025-12-11 01:07:04 +03:00
- VK сервис
- В `.env` corebot на хосте 1: IP этого хоста
2025-12-10 16:22:18 +03:00
**Преимущества:**
- VK работает быстрее без VPN
- Меньше нагрузка на VPN канал
2025-12-11 01:07:04 +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-11 01:07:04 +03:00
### YouTube/Instagram/VK не работает
- Проверьте, что соответствующий сервис запущен: `docker compose ps`
- Проверьте URL в `.env` corebot
- Проверьте логи сервиса: `docker compose logs -f`
- Для Instagram: проверьте наличие и валидность `instagram-downloader/instagram_cookies.txt`
2025-12-10 16:22:18 +03:00
### База данных не сохраняется
2025-12-11 01:07:04 +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-10 16:22:18 +03:00
При возникновении проблем создайте issue в репозитории.