Download videos from Youtube and other platforms through a Telegram Bot
Go to file
2021-12-30 19:03:21 +08:00
.github/workflows push to ghcr 2021-12-26 19:17:07 +08:00
assets reorder import, change code style, avoid /music and other commands in groups 2021-05-05 12:10:22 +08:00
conf use celery 2021-12-29 23:57:36 +08:00
tools working after switch to mysql 2021-12-29 15:54:25 +08:00
ytdlbot dynamic worker name 2021-12-30 19:03:21 +08:00
.dockerignore use celery 2021-12-29 23:57:36 +08:00
.gitignore add flower, use mysql5.7 2021-12-30 16:37:27 +08:00
.gitmodules remove submodule for better support of heroku 2021-05-24 09:27:49 +08:00
app.json add heroku buildpack 2021-08-30 22:29:46 +08:00
docker-compose.yml add flower, use mysql5.7 2021-12-30 16:37:27 +08:00
Dockerfile use celery 2021-12-29 23:57:36 +08:00
flower.yml add flower, use mysql5.7 2021-12-30 16:37:27 +08:00
LICENSE Initial commit 2021-05-03 18:24:44 +08:00
Procfile use celery 2021-12-29 23:57:36 +08:00
README.md support video resolution and sendfile #22 #5 2021-12-07 21:32:06 +08:00
requirements.txt add flower, use mysql5.7 2021-12-30 16:37:27 +08:00
worker.yml worker.yml 2021-12-30 14:45:36 +08:00

ytdlbot

YouTube Download Bot🚀

Download videos from YouTube and other platforms through a Telegram Bot

Deploy

Usage

https://t.me/benny_ytdlbot

Send link directly to the bot. Any platform supported by youtube-dl will also work.

Limitation of my bot

Because I have limited resources, hundreds of Gigabytes doesn't sound like a sustainable solution.

In that case, I added one limitation: 5 GiB per 24 hours for each user. Might change in future

You can choose to become 'VIP' if you really need large traffic. And also, you could always deploy your own bot.

Features

  1. fast download and upload.
  2. ads free
  3. support progress bar
  4. audio conversion
  5. playlist support
  6. VIP support
  7. support different video resolutions
  8. support sending as file or streaming as video

How to deploy?

You can deploy this bot on any platform that supports Python.

Heroku

Use the button above! It should work like a magic.

Normal

  1. clone code
  2. install ffmpeg
  3. install Python 3.6+
  4. pip3 install -r requirements.txt
  5. set environment variables TOKEN, APP_ID and APP_HASH, and more if you like.
  6. python3 ytdl.py

Simple one line docker

Some functions, such as VIP, ping will be disabled.

docker run -e APP_ID=111 -e APP_HASH=111 -e TOKEN=370FXI bennythink/ytdlbot

docker-compose

Compatible with amd64, arm64 and armv7l

1. get docker-compose.yml

Download this file to a directory, for example ~/ytdl/docker-compose.yml

2. create VIP database

mkdir ~/ytdl/data/
touch ~/ytdl/data/vip.sqlite

3. create env file

mkdir ~/ytdl/env/
vim ~/ytdl/env/ytdl.env

you can configure all the following environment variables:

  • WORKERS: default 500

  • APP_ID: REQUIRED

  • APP_HASH: REQUIRED

  • TOKEN: REQUIRED

  • REDIS: REQUIRED

  • OWNER: owner username

  • QUOTA: quota in bytes

  • EX: quota expire time

  • MULTIPLY: vip quota comparing to normal quota

  • USD2CNY: exchange rate

  • VIP: enable VIP or not, default: disable

  • AFD_LINK

  • COFFEE_LINK

  • COFFEE_TOKEN

  • AFD_TOKEN

  • AFD_USER_ID

  • AUTHORIZED_USER: users that could use this bot, user_id, separated with ,

  • REQUIRED_MEMBERSHIP: group or channel username, user must join this group to use the bot. Could be use with above AUTHORIZED_USER

4. run

docker-compose up -d

Command

start - Let's start
about - Want to contribute?
ping - Bot running status
help - Anything troubles you?
ytdl - Download video in group
vip - Join VIP
terms - View Terms of Service
settings - Set your preference

Test video

https://www.youtube.com/watch?v=BaW_jenozKc

Test Playlist

https://www.youtube.com/playlist?list=PL1Hdq7xjQCJxQnGc05gS4wzHWccvEJy0w

License

Apache License 2.0