Skip to main content

Upload (and download) files to Telegram up to 4 GiB using your account.

Project description

https://raw.githubusercontent.com/ankit-chaubey/uploady/main/logo.png

pip-rating badge Latest Tests CI build status Latest PyPI version Python versions Code Climate Test coverage Github stars

Uploady

Why uploady? While telegram-upload is great, Uploady offers additional features (currently in development):

  • Support for multiple bots/accounts with floodwait handling

  • Scheduled uploads for hands-off management

  • Gallery synchronization for up-to-date media

  • Posting with inline button and much more

  • Something even more unexpected 😄 is coming soon!

Uploady enhances flexibility, automation, and control, making it the ultimate solution for Telegram file management.


Telegram-upload uses your personal Telegram account to upload and download files up to 4 GiB (2 GiB for free users). Turn Telegram into your personal ☁ cloud!

To install 🔧 uploady, run this command in your terminal:

$ sudo pip3 install -U uploady

This is the preferred method to install uploady, as it will always install the most recent stable release. 🐍 Python 3.7-3.12 are tested and supported. There are other installation ways available like Docker. More info in the 📕 documentation but make sure to use uploady instead of telegram-upload in all respective methods.

https://raw.githubusercontent.com/ankit-chaubey/uploady/main/uploady-demo.gif

❓ Usage

To use this program you need a Telegram account and your App api_id & api_hash (get it in my.telegram.org). The first time you use uploady it requests your 📱 telephone, api_id and api_hash. Bot tokens can not be used with this program (bot uploads are limited to 50MB).

To send ⬆️ files (by default it is uploaded to saved messages):

$ uploady file1.mp4 file2.mkv

You can download ⤵️ the files again from your saved messages (by default) or from a channel. All files will be downloaded until the last text message.

$ telegram-download

Read the documentation for more info about the options availables.

Interactive mode

The interactive option (--interactive) allows you to choose the dialog and the files to download or upload with a terminal 🪄 wizard. It even supports mouse!

$ uploady --interactive    # Interactive upload
$ telegram-download --interactive  # Interactive download

More info in the documentation

Set group or chat

By default when using uploady without specifying the recipient or sender, uploady will use your personal chat. However you can define the 👨 destination. For file upload the argument is --to <entity>. For example:

$ uploady --to telegram.me/joinchat/AAAAAEkk2WdoDrB4-Q8-gg video.mkv

You can download files from a specific chat using the –from <entity> parameter. For example:

$ telegram-download --from username

You can see all the possible values for the entity in the documentation.

Split & join files

If you try to upload a file that exceeds the maximum supported by Telegram by default, an error will occur. But you can enable ✂ split mode to upload multiple files:

$ uploady --large-files split large-video.mkv

Files split using split can be rejoined on download using:

$ telegram-download --split-files join

Find more help in the uploady documentation.

Delete on success

The --delete-on-success option allows you to ❌ delete the Telegram message after downloading the file. This is useful to send files to download to your saved messages and avoid downloading them again. You can use this option to download files on your computer away from home.

Configuration

Credentials are saved in ~/.config/uploady.json and ~/.config/uploady.session. You must make sure that these files are secured. You can copy these 📁 files to authenticate uploady on more machines, but it is advisable to create a session file for each machine.

More options

Telegram-upload has more options available, like customizing the files thumbnail, set a caption message (including variables) or configuring a proxy. Read the documentation for more info.

💡 Features

  • Upload and download multiples files (up to 4 GiB per file for premium users).

  • Interactive mode.

  • Add video thumbs.

  • Split and join large files.

  • Delete local or remote file on success.

  • Use variables in the caption message.

  • … And more.

🐋 Docker

Run uploady without installing it on your system using Docker. Instead of uploady and telegram-download you should use upload and download. Usage:

$ docker run -v <files_dir>:/files/
             -v <config_dir>:/config
             -it ankit-chaubey/uploady:main
             <command> <args>
  • <files_dir>: upload or download directory.

  • <config_dir>: Directory that will be created to store the uploady configuration. It is created automatically.

  • <command>: upload and download.

  • <args>: uploady and telegram-download arguments.

For example:

$ docker run -v /media/data/:/files/
             -v $PWD/config:/config
             -it ankit-chaubey/uploady:main
             upload file_to_upload.txt

❤️ Thanks

This project developed by Nekmo & collaborators would not be possible without Telethon, the library used as a Telegram client.

This project is maintained by Ankit Chaubey & The enhancements and customizations for Uploady are coming soon.

Telegram-upload is licensed under the MIT license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

uploady-0.0.3.tar.gz (282.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

uploady-0.0.3-py2.py3-none-any.whl (48.2 kB view details)

Uploaded Python 2Python 3

File details

Details for the file uploady-0.0.3.tar.gz.

File metadata

  • Download URL: uploady-0.0.3.tar.gz
  • Upload date:
  • Size: 282.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.21

File hashes

Hashes for uploady-0.0.3.tar.gz
Algorithm Hash digest
SHA256 217c6136eb0bd87522b4d25593c7c882e226a54ba3ab40f19e01082dd6be6c05
MD5 6fbd95494d051c42084e3ed06eb9a2c8
BLAKE2b-256 d66857a6cd7e9c4857871ac87e9c0030a4f50085425d005ef5caf0a1fd93cedc

See more details on using hashes here.

File details

Details for the file uploady-0.0.3-py2.py3-none-any.whl.

File metadata

  • Download URL: uploady-0.0.3-py2.py3-none-any.whl
  • Upload date:
  • Size: 48.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.21

File hashes

Hashes for uploady-0.0.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 49a4c0a77fdb69941c536e73755824d0a6767bef70a9adccf07fd11be167e88c
MD5 5966306e3789cf2cd52d2db88dd9a2e7
BLAKE2b-256 27e415e82346e1841f3b8e5e1d8b2dc48c0515bf13451c037da0d2134ff556c0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page