A self-hosted Telegram file downloader for continuous, stable, and unattended downloads.
- 📍 Overview
- 🧩 Screenshots
- 🚀 Getting Started
- ⌨️ Development
- 📌 Project Roadmap
- 🔰 Contributing
- 🎗 License
- 🆗 FAQs
- Support for downloading files from telegram channels and groups.
- Support multiple telegram accounts for downloading files.
- Support suspending and resuming downloads.
- Multiple accounts with same files will be downloaded only once.
- Responsive design supports mobile access.
Before getting started with telegram-files, you should apply a telegram api id and hash. You can apply for it on the Telegram API page.
docker run -d \
--name telegram-files \
--restart always \
-e APP_ENV=${APP_ENV:-prod} \
-e APP_ROOT=${APP_ROOT:-/app/data} \
-e TELEGRAM_API_ID=${TELEGRAM_API_ID} \
-e TELEGRAM_API_HASH=${TELEGRAM_API_HASH} \
-p 6543:80 \
-v ./data:/app/data \
ghcr.io/jarvis2f/telegram-files:latest
Using docker-compose
Copy docker-compose.yaml to your project directory and run the following command:
docker-compose up -d
Install on unRaid
On unRaid, install from the Community Repositories by searching for telegram-files
.
Important Note: You should NOT expose the service to the public internet. Because the service is not secure.
Before getting started with telegram-files, ensure your runtime environment meets the following requirements:
- Programming Language: JDK21,TypeScript
- Package Manager: Gradle,Npm
- Container Runtime: Docker
Install telegram-files using one of the following methods:
Build from source:
- Clone the telegram-files repository:
git clone https://github.com/jarvis2f/telegram-files
- Navigate to the project directory:
cd telegram-files
- Install the project dependencies:
cd web
npm install
cd api
gradle build
docker build -t jarvis2f/telegram-files .
- ✅
Task 1
: Automatically download files based on set rules. - ✅
Task 2
: Download statistics and reports. - ☑️
Task 3
: Improve Telegram’s login functionality. - ☑️
Task 4
: Support auto transfer files to other destinations. - ☑️
Task 5
: File table is optimized using virtual lists, and API service using GraalVM. - ☑️
Task 6
: File downloads in comments under channel messages.
- 💬 Join the Discussions: Share your insights, provide feedback, or ask questions.
- 🐛 Report Issues: Submit bugs found or log feature requests
for the
telegram-files
project. - 💡 Submit Pull Requests: Review open PRs, and submit your own PRs.
Contributing Guidelines
- Fork the Repository: Start by forking the project repository to your github account.
- Clone Locally: Clone the forked repository to your local machine using a git client.
git clone https://github.com/jarvis2f/telegram-files
- Create a New Branch: Always work on a new branch, giving it a descriptive name.
git checkout -b new-feature-x
- Make Your Changes: Develop and test your changes locally.
- Commit Your Changes: Commit with a clear message describing your updates.
git commit -m 'Implemented new feature x.'
- Push to github: Push the changes to your forked repository.
git push origin new-feature-x
- Submit a Pull Request: Create a PR against the original project repository. Clearly describe the changes and their motivations.
- Review: Once your PR is reviewed and approved, it will be merged into the main branch. Congratulations on your contribution!
This project is protected under the MIT License. For more details, refer to the LICENSE file.
Q. Can't start the api server, error:java.lang.UnsatisfiedLinkError: no tdjni in java.library.path
A. Maybe download tdlib failed, you can see the entrypoint.sh file, then download tdlib
manually.
Q. Web's spoiler is static, how to solve it?
A. 1. Because CSS Houdini Paint API
is not supported by all browsers. 2. It is only supported on https.
Use in http environment, you can use the following method to solve it
Open the chrome://flags
page, search for Insecure origins treated as secure
, and add the address of the web page to
the list.