A Telegram bot to stream files to web
Demo Bot (Not Available)»
Report a Bug
|
Request Feature
Table of Contents
This bot will give you stream links for Telegram files without the need of waiting till the download completes
The main working part was taken from Megatron and thanks to eyaadh for his awesome project.
git clone https://github.com/DeekshithSH/FileStreamBot
cd FileStreamBot
python3 -m venv ./venv
. ./venv/bin/activate
pip3 install -r requirements.txt
python3 -m WebStreamer
and to stop the whole bot, do CTRL+C
- If you wanna run this bot 24/7 on the VPS, follow these steps.
sudo apt install tmux -y
tmux
python3 -m WebStreamer
now you can close the VPS and the bot will run on it.
If you're on Heroku, just add these in the Environmental Variables
or if you're Locally hosting, create a file named .env
in the root directory and add all the variables there.
An example of .env
file:
API_ID=452525
API_HASH=esx576f8738x883f3sfzx83
BOT_TOKEN=55838383:yourtbottokenhere
BIN_CHANNEL=-100
DATABASE_URL=mongodb://admin:pAswaRd@192.168.27.1
FQDN=192.168.27.1
HAS_SSL=False
MULTI_TOKEN1=55838383:yourfirstmulticlientbottokenhere
MULTI_TOKEN2=55838383:yoursecondmulticlientbottokenhere
MULTI_TOKEN3=55838383:yourthirdmulticlientbottokenhere
OWNER_ID=777000
PORT=8080
API_ID
: Goto my.telegram.org to obtain this.
API_HASH
: Goto my.telegram.org to obtain this.
BOT_TOKEN
: Get the bot token from @BotFather
BIN_CHANNEL
: Create a new channel (private/public), post something in your channel. Forward that post to @missrose_bot and reply /id
. Now copy paste the forwarded channel ID in this field.
OWNER_ID
: Your Telegram User ID, Send /id
to @missrose_bot to get Your Telegram User ID
DATABASE_URL
: MongoDB URI for saving User IDs when they first Start the Bot. We will use that for Broadcasting to them. I will try to add more features related with Database. If you need help to get the URI you can ask in Me Telegram.
MULTI_TOKEN1
: Add your first bot token or session strings here.
MULTI_TOKEN2
: Add your second bot token or session strings here.
you may also add as many as bots you want. (max limit is not tested yet)
MULTI_TOKEN3
, MULTI_TOKEN4
, etc.
SLEEP_THRESHOLD
: Set a sleep threshold for flood wait exceptions happening globally in this telegram bot instance, below which any request that raises a flood wait will be automatically invoked again after sleeping for the required amount of time. Flood wait exceptions requiring higher waiting times will be raised. Defaults to 60 seconds.
WORKERS
: Number of maximum concurrent workers for handling incoming updates. Defaults to 3
PORT
: The port that you want your webapp to be listened to. Defaults to 8080
WEB_SERVER_BIND_ADDRESS
: Your server bind address. Defauls to 0.0.0.0
NO_PORT
: (can be either True
or False
) If you don't want your port to be displayed. You should point your PORT
to 80
(http) or 443
(https) for the links to work. Ignore this if you're on Heroku.
FQDN
: A Fully Qualified Domain Name if present. Defaults to WEB_SERVER_BIND_ADDRESS
HAS_SSL
: (can be either True
or False
) If you want the generated links in https format.
PING_INTERVAL
: The time in ms you want the servers to be pinged each time to avoid sleeping (Only for Heroku). Defaults to 1200
or 20 minutes.
UPDATES_CHANNEL
: Your Telegram Channel
FORCE_UPDATES_CHANNEL
: Set to True, so every user have to Join update channel to use the bot.
SESSION_NAME
: Name for the Database created on your MongoDB. Defaults to F2LxBot
BANNED_CHANNELS
: Put IDs of Banned Channels where bot will not work. You can add multiple IDs & separate with Space.
KEEP_ALIVE
: If you want to make the server ping itself every PING_INTERVAL
seconds to avoid sleeping. Helpful in PaaS Free tiers. Defaults to False
BIN_CHANNEL
as an admin
/start
: To check if the bot is alive or not.
To get an instant stream link, just forward any media to the bot and boom, its fast af.
- How long the links will remain valid or is there any expiration time for the links generated by the bot?
The links will will be valid as longs as your bot is alive and you haven't deleted the log channel.
Feel free to contribute to this project if you have any further ideas
You can contact either via my Telegram Group or you can PM me on @DeekshithSH
- Me
- EverythingSuckz for his FileStreamBot
- Avishkar Patil for his FileStreamBot
- eyaadh for his awesome Megatron Bot.
- BlackStone for adding multi-client support.
- Dan Tès for his Pyrogram Library
- TheHamkerCat for helping me with my common doubts.