High-Performance Telegram File-to-Link Bot for Direct Links & Streaming
- About The Project
- How It Works
- Features
- Configuration
- Usage and Commands
- Advanced Feature Setup
- Deployment Guide
- Support & Community
- License
- Acknowledgments
Thunder is a powerful Telegram bot that transforms Telegram files into high-speed direct links, perfect for both streaming and rapid downloading. Share files via HTTP(S) links without needing to download them from the Telegram client first.
- 🚀 Bypassing Telegram's built-in download speed limits
- ☁️ Unlimited cloud storage with fast streaming and download links
- 🎬 Content creators sharing media files
- 👥 Communities distributing resources
- 🎓 Educational platforms sharing materials
User Uploads File → Telegram Bot → Forwards to Channel → Generates Direct Link → Direct Download / Streaming
- Upload → User sends any file to the bot.
- Store → The bot forwards the file to your private storage channel (
BIN_CHANNEL), where it is permanently saved to generate the link. - Generate → A unique, permanent link is created.
- Stream/Download → Anyone with the link can stream or download the file directly in their browser.
- Balance → Multi-client support distributes the load for high availability.
- ✅ Direct Link Generation - Convert any Telegram file into a direct HTTP(S) link.
- ✅ Permanent Links - Links remain active as long as the file exists in the storage channel.
- ✅ Browser Streaming & Downloading - Stream media directly or download files at high speed without a Telegram client.
- ✅ All File Types - Supports video, audio, documents, images, and any other file format.
- ✅ Batch Processing - Generate links for multiple files at once with a single command.
- ✅ Multi-Client Support - Distributes traffic across multiple Telegram bots to avoid limits and increase throughput.
- ✅ Async Architecture - Built with
aiohttpandasynciofor non-blocking, high-performance operations. - ✅ MongoDB Integration - Ensures persistent and reliable data storage.
- 🔐 Token Authentication - Secure user access with a time-limited token system.
- 🛡️ Admin Controls - Full suite of commands for user and bot management.
- 👤 User Authentication - Require users to join a specific channel before they can use the bot.
- ✅ Channel/Group Support - Fully functional in private chats, groups, and channels.
- 🌍 Custom Domain - Serve files from your own domain for a professional look.
- 🔗 URL Shortening - Integrate with URL shortener services for clean, shareable links.
- 🎨 Custom Templates - Personalize messages sent by the bot to match your brand.
- 📈 Media Info Display - Shows file size, duration, and format details in the response message.
Copy config_sample.env to config.env and fill in your values.
| Variable | Description | Example |
|---|---|---|
API_ID |
Telegram API ID | 12345678 |
API_HASH |
Telegram API Hash | abc123def456 |
BOT_TOKEN |
Bot token from @BotFather | 123456:ABCdefGHI |
BIN_CHANNEL |
Storage channel ID | -1001234567890 |
OWNER_ID |
Owner user ID | 12345678 |
DATABASE_URL |
MongoDB connection | mongodb+srv://... |
FQDN |
Domain/IP address | f2l.thunder.com |
HAS_SSL |
HTTPS enabled | True or False |
PORT |
Server port | 8080 |
NO_PORT |
Hide port in URLs | True or False |
Optional Configuration Details
| Variable | Description | Default |
|---|---|---|
MULTI_TOKEN1 |
Additional bot token 1 (use MULTI_TOKEN1, MULTI_TOKEN2, etc.) | (empty) |
FORCE_CHANNEL_ID |
Required channel join | (empty) |
MAX_BATCH_FILES |
Maximum files in batch processing | 50 |
CHANNEL |
Allow processing messages from channels | False |
BANNED_CHANNELS |
Blocked channel IDs | (empty) |
SLEEP_THRESHOLD |
Client switch threshold | 300 |
WORKERS |
Async workers | 8 |
NAME |
Bot name | ThunderF2L |
BIND_ADDRESS |
Bind address | 0.0.0.0 |
PING_INTERVAL |
Ping interval (seconds) | 840 |
TOKEN_ENABLED |
Enable tokens | False |
SHORTEN_ENABLED |
URL shortening for tokens | False |
SHORTEN_MEDIA_LINKS |
URL shortening for media | False |
TOKEN_TTL_HOURS |
Token validity duration in hours | 24 |
URL_SHORTENER_API_KEY |
Shortener API key | (empty) |
URL_SHORTENER_SITE |
Shortener service | (empty) |
SET_COMMANDS |
Auto-set bot commands | True |
RATE_LIMIT_ENABLED |
Enable rate limiting | False |
MAX_FILES_PER_PERIOD |
Files per window | 2 |
RATE_LIMIT_PERIOD_MINUTES |
Time window | 1 |
MAX_QUEUE_SIZE |
Queue size | 100 |
GLOBAL_RATE_LIMIT |
Global limiting | True |
MAX_GLOBAL_REQUESTS_PER_MINUTE |
Global limit | 4 |
- Start → Send
/startto the bot. - Authenticate → Join required channels (if configured).
- Upload → Send any media file.
- Receive → Get a direct streaming and download link.
- Share → Anyone can access the file via the link.
| Command | Description |
|---|---|
/start |
Start the bot and get a welcome message. Also used for token activation. |
/link |
Generates a link. For batches, reply to the first file of a group and specify the count. Example: /link 5 will process that file and the next four. |
/dc |
Get the data center (DC) of a user or file. Use /dc id, or reply to a file or user. |
/ping |
Check if the bot is online and measure response time. |
/about |
Get information about the bot. |
/help |
Show help and usage instructions. |
| Command | Description |
|---|---|
/status |
Check bot status, uptime, and resource usage. |
/broadcast |
Send a message to all users (supports text, media, buttons). |
/stats |
View usage statistics and analytics. |
/ban |
Ban a user or channel (reply to message or use user/channel ID). |
/unban |
Unban a user or channel. |
/log |
Send bot logs. |
/restart |
Restart the bot. |
/shell |
Execute a shell command. |
/speedtest |
Run network speed test and display comprehensive results. |
/users |
Show total number of users. |
/authorize |
Permanently authorize a user to use the bot (bypasses token system). |
/deauthorize |
Remove permanent authorization from a user. |
/listauth |
List all permanently authorized users. |
start - Initialize bot
link - Generate direct link
dc - Get data center info
ping - Check bot status
about - Bot information
help - Show help guide
status - [Admin] System status
stats - [Admin] Usage statistics
broadcast - [Admin] Message all users
ban - [Admin] Ban user
unban - [Admin] Unban user
users - [Admin] User count
authorize - [Admin] Grant access
deauthorize - [Admin] Revoke access
listauth - [Admin] List authorized
log - [Admin] Send bot logs
restart - [Admin] Restart the bot
shell - [Admin] Execute shell command
speedtest - [Admin] Run network speed test
Enable controlled access with tokens:
- Set
TOKEN_ENABLED=Truein yourconfig.env. - Users receive automatic tokens on first use.
- Admins can grant permanent authorization with
/authorizeto bypass tokens. - Tokens include activation links for secure access.
Configure URL shortening for cleaner links:
SHORTEN_ENABLED=True
SHORTEN_MEDIA_LINKS=True
URL_SHORTENER_API_KEY=your_api_key
URL_SHORTENER_SITE=shortener.example.comThunder implements a sophisticated multi-tier rate limiting system designed for high-performance file sharing:
- Owner Priority: Complete bypass of all rate limits.
- Authorized Users: Dedicated priority queue with faster processing.
- Regular Users: Standard queue with fair scheduling.
- Per-User Limits: Configurable files per time window.
- Global Limits: System-wide request throttling.
- Sliding Window: Time-based rate limiting with automatic cleanup.
- Automatic Re-queuing: Failed requests due to rate limits are intelligently re-queued.
- Queue Size Limits: Configurable maximum queue size.
- Flood Protection: Built-in protection against Telegram flood waits.
Monitor server performance with built-in speed testing:
/speedtestFeatures include download/upload speeds, latency measurements, and shareable result images for performance monitoring.
This section covers the complete setup process for deploying Thunder, from prerequisites to production deployment.
| Requirement | Description | Source |
|---|---|---|
| Python 3.13 | Programming language | python.org |
| MongoDB | Database | mongodb.com |
| Telegram API | API credentials | my.telegram.org |
| Bot Token | From @BotFather | @BotFather |
| Public Server | VPS/Dedicated server | Any provider |
| Storage Channel | For file storage | Create in Telegram |
# 1. Clone repository
git clone https://github.com/fyaz05/FileToLink.git
cd FileToLink
# 2. Configure
cp config_sample.env config.env
nano config.env # Edit your settings
# 3. Build and run
docker build -t thunder .
docker run -d --name thunder -p 8080:8080 thunderManual Installation
# 1. Clone repository
git clone https://github.com/fyaz05/FileToLink.git
cd FileToLink
# 2. Setup virtual environment
python3 -m venv venv
source venv/bin/activate # Windows: venv\Scripts\activate
# 3. Install dependencies
pip install -r requirements.txt
# 4. Configure
cp config_sample.env config.env
nano config.env
# 5. Run bot
python -m ThunderTip: Start with the essential configuration to get Thunder running, then add optional features as needed.
After deployment, to add any additional environment variables, use the Koyeb dashboard under Settings → Environment Variables.
- Open Render Dashboard → New → Web Service
- Choose Existing Image:
fyaz05/thunder:latest - Add your environment variables
- Click Deploy
- Open Railway → New Project → Deploy Service
- Choose Docker Image:
fyaz05/thunder:latest - Add your environment variables
- Click Deploy
Note: See the Configuration section for required environment variables.
Reverse Proxy Guide
This guide will help you set up a secure reverse proxy using NGINX for your file streaming bot with Cloudflare SSL protection.
- A VPS or server running Ubuntu/Debian with NGINX installed.
- Your file streaming bot running on a local port (e.g.,
8080). - A subdomain (e.g.,
f2l.thunder.com) set up in Cloudflare. - Cloudflare Origin Certificate files:
cert.pemandkey.key.
- DNS: Add an
Arecord for your subdomain pointing to your server's IP. Ensure Proxy Status is Proxied (orange cloud). - SSL: In the SSL/TLS tab, set the encryption mode to Full (strict).
Create a folder for your certificates and place cert.pem and key.key inside. Secure the private key.
sudo mkdir -p /etc/ssl/cloudflare/f2l.thunder.com
# Move/copy your cert.pem and key.key files into this directory
sudo chmod 600 /etc/ssl/cloudflare/f2l.thunder.com/key.key
sudo chmod 644 /etc/ssl/cloudflare/f2l.thunder.com/cert.pemCreate a new file at /etc/nginx/sites-available/f2l.thunder.conf and paste the following, replacing f2l.thunder.com and 8080 with your values.
server {
listen 443 ssl;
listen [::]:443 ssl;
server_name f2l.thunder.com;
# SSL Configuration
ssl_certificate /etc/ssl/cloudflare/f2l.thunder.com/cert.pem;
ssl_certificate_key /etc/ssl/cloudflare/f2l.thunder.com/key.key;
# Basic security
add_header X-Frame-Options DENY;
add_header X-Content-Type-Options nosniff;
location / {
# Forward requests to your bot
proxy_pass http://localhost:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
# Settings for file streaming
proxy_buffering off;
proxy_request_buffering off;
client_max_body_size 0;
}
}
# Redirect HTTP to HTTPS
server {
listen 80;
listen [::]:80;
server_name f2l.thunder.com;
return 301 https://$host$request_uri;
}Enable the configuration, test it, and reload NGINX.
sudo ln -s /etc/nginx/sites-available/f2l.thunder.conf /etc/nginx/sites-enabled/
sudo nginx -t
sudo systemctl reload nginxYour reverse proxy is now securely streaming files behind Cloudflare!
Q: Why isn't my bot responding after setup? A: This is usually a configuration issue. Please check the following:
- Verify
config.env: Make sure all essential variables (API_ID,API_HASH,BOT_TOKEN,BIN_CHANNEL,DATABASE_URL) are filled in correctly. - Use
config.envOnly: Do not editvars.pyorconfig_sample.env. The bot is designed to only read your settings fromconfig.env. - Check Logs: Review the console logs on your server or hosting platform (Koyeb, Render, Heroku) for any startup errors.
Q: What do I use for the FQDN variable?
A: It's the public URL or IP address of your bot.
- With a Domain: Use your subdomain (e.g.,
f2l.thunder.com). - On Koyeb/Render/Heroku: Use the public URL provided by the platform.
- On a VPS: Use your server's public IP address.
Q: Why are my links not working on a VPS?
A: For links to work on a VPS, the URL must include the port number (e.g., http://YOUR_VPS_IP:8080). Ensure that NO_PORT is set to False in config.env and that your server is configured to allow traffic through that port.
Q: Why are my links showing a "Resource Not Found" error or not working? A: This error means the bot can't access the file. Check these three things:
- Invalid Token: Your
BOT_TOKENor one of theMULTI_TOKENs might be wrong. Double-check them with @BotFather. - Missing Admin Rights: The bot and all your client accounts must be administrators in the
BIN_CHANNEL. - File Deleted: The link will break if the file was deleted from your
BIN_CHANNEL.
Q: Why isn't video or audio playing correctly in my browser? A: Your browser likely doesn't support the file's audio or video format (codec). This is a browser limitation, not a bot issue.
- Solution: For perfect playback, copy the link and play it in a dedicated media player. Recommended players include VLC Media Player, MX Player, PotPlayer, IINA, and MPV.
Q: Why does the bot sometimes become unresponsive? A: This is likely a Telegram Flood Wait. To prevent spam, Telegram temporarily limits accounts that make too many requests. The bot is designed to handle this automatically by pausing and will resume on its own once the limit is lifted.
Q: How can I fix slow download and streaming speeds? A: If your speeds are slow, here’s how to fix it:
- Add More Clients: This is the best solution. Add
MULTI_TOKENs to yourconfig.envto distribute the workload and increase throughput. - Use DC4 Accounts: For top performance, use Telegram accounts from Data Center 4 (DC4), as they often have the fastest connection. Use
/dcto check an account's data center. - Upgrade Your Server: A server with a slow network will bottleneck your speeds. Consider upgrading your VPS plan.
Q: How do I generate links for multiple files at once?
A: The /link command can process multiple files sent in sequence. To use it, reply to the first file of the series with the command and the total count.
- Example: For a series of 5 files, reply to the very first file with
/link 5.
Q: Can I mix tokens from different accounts and data centers? A: Yes. Mixing clients from different accounts and data centers (like DC1, DC4, and DC5) is a great way to improve bot performance and reliability.
Contributions are welcome! Please follow these steps:
- Fork the repository.
- Create a new feature branch (
git checkout -b feature/amazing-feature). - Commit your changes (
git commit -m 'Add some amazing feature'). - Push to the branch (
git push origin feature/amazing-feature). - Open a Pull Request.
Licensed under the Apache License 2.0. See the LICENSE file for details.
- Pyrofork - Telegram MTProto API Framework
- aiohttp - Asynchronous HTTP Client/Server
- PyMongo - Asynchronous MongoDB Driver
- TgCrypto - High-performance cryptography library
This project is not affiliated with Telegram. Use it responsibly and in compliance with Telegram's Terms of Service and all applicable local regulations.
⭐ Star this project if you find it useful!
Report Bug •
Request Feature
