Skip to content

A self-hosted Telegram file downloader for continuous, stable, and unattended downloads.

License

Notifications You must be signed in to change notification settings

jarvis2f/telegram-files

Repository files navigation

Telegram Files

A self-hosted Telegram file downloader for continuous, stable, and unattended downloads.

license last-commit release


🔗 Table of Contents


📍 Overview

  • 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.

🧩 Screenshots

More Screenshots

🚀 Getting Started

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.

Using docker  

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.


⌨️ Development

☑️ Prerequisites

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

⚙️ Installation

Install telegram-files using one of the following methods:

Build from source:

  1. Clone the telegram-files repository:
git clone https://github.com/jarvis2f/telegram-files
  1. Navigate to the project directory:
cd telegram-files
  1. Install the project dependencies:

Using npm  

cd web
npm install

Using gradle  

cd api
gradle build

Using docker  

docker build -t jarvis2f/telegram-files .

📌 Project Roadmap

  • 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.

🔰 Contributing

Contributing Guidelines
  1. Fork the Repository: Start by forking the project repository to your github account.
  2. Clone Locally: Clone the forked repository to your local machine using a git client.
    git clone https://github.com/jarvis2f/telegram-files
  3. Create a New Branch: Always work on a new branch, giving it a descriptive name.
    git checkout -b new-feature-x
  4. Make Your Changes: Develop and test your changes locally.
  5. Commit Your Changes: Commit with a clear message describing your updates.
    git commit -m 'Implemented new feature x.'
  6. Push to github: Push the changes to your forked repository.
    git push origin new-feature-x
  7. Submit a Pull Request: Create a PR against the original project repository. Clearly describe the changes and their motivations.
  8. Review: Once your PR is reviewed and approved, it will be merged into the main branch. Congratulations on your contribution!

🎗 License

This project is protected under the MIT License. For more details, refer to the LICENSE file.


🆗 FAQs

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.