.. image:: https://raw.githubusercontent.com/Nekmo/telegram-upload/master/logo.png :width: 100%
|
.. image:: https://raw.githubusercontent.com/Nekmo/telegram-upload/pip-rating-badge/pip-rating-badge.svg :target: https://github.com/Nekmo/telegram-upload/actions/workflows/pip-rating.yml :alt: pip-rating badge
.. image:: https://img.shields.io/github/actions/workflow/status/Nekmo/telegram-upload/test.yml?style=flat-square&maxAge=2592000&branch=master :target: https://github.com/Nekmo/telegram-upload/actions?query=workflow%3ATests :alt: Latest Tests CI build status
.. image:: https://img.shields.io/pypi/v/telegram-upload.svg?style=flat-square :target: https://pypi.org/project/telegram-upload/ :alt: Latest PyPI version
.. image:: https://img.shields.io/pypi/pyversions/telegram-upload.svg?style=flat-square :target: https://pypi.org/project/telegram-upload/ :alt: Python versions
.. image:: https://img.shields.io/codeclimate/maintainability/Nekmo/telegram-upload.svg?style=flat-square :target: https://codeclimate.com/github/Nekmo/telegram-upload :alt: Code Climate
.. image:: https://img.shields.io/codecov/c/github/Nekmo/telegram-upload/master.svg?style=flat-square :target: https://codecov.io/github/Nekmo/telegram-upload :alt: Test coverage
.. image:: https://img.shields.io/github/stars/Nekmo/telegram-upload?style=flat-square :target: https://github.com/Nekmo/telegram-upload :alt: Github stars
############### telegram-upload ############### 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 ๐ง telegram-upload, run this command in your terminal:
.. code-block:: console
$ sudo pip3 install -U telegram-upload
This is the preferred method to install telegram-upload, as it will always install the most recent stable release.
๐ Python 3.7-3.11 are tested and supported. There are other installation ways available like Docker <#-docker>
.
More info in the ๐ documentation <https://docs.nekmo.org/telegram-upload/installation.html>
.. image:: https://raw.githubusercontent.com/Nekmo/telegram-upload/master/telegram-upload-demo.gif :target: https://asciinema.org/a/592098 :width: 100%
To use this program you need an Telegram account and your App api_id & api_hash (get it in
my.telegram.org <https://my.telegram.org/>
_). The first time you use telegram-upload 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):
.. code-block:: console
$ telegram-upload 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.
.. code-block:: console
$ telegram-download
Read the documentation <https://docs.nekmo.org/telegram-upload/usage.html#telegram-download>
_ for more info about the
options availables.
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!
.. code-block:: console
$ telegram-upload --interactive # Interactive upload
$ telegram-download --interactive # Interactive download
More info in the documentation <https://docs.nekmo.org/telegram-upload/usage.html#interactive-mode>
_
By default when using telegram-upload without specifying the recipient or sender, telegram-upload will use your personal
chat. However you can define the ๐จ destination. For file upload the argument is --to <entity>
. For example:
.. code-block::
$ telegram-upload --to telegram.me/joinchat/AAAAAEkk2WdoDrB4-Q8-gg video.mkv
You can download files from a specific chat using the --from
.. code-block::
$ telegram-download --from username
You can see all the possible values for the entity in the documentation <https://docs.nekmo.org/telegram-upload/usage.html#set-recipient-or-sender>
_.
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:
.. code-block:: console
$ telegram-upload --large-files split large-video.mkv
Files split using split can be rejoined on download using:
.. code-block:: console
$ telegram-download --split-files join
Find more help in the telegram-upload documentation <https://docs.nekmo.org/telegram-upload/usage.html#split-files>
_.
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.
Credentials are saved in ~/.config/telegram-upload.json
and ~/.config/telegram-upload.session
. You must make
sure that these files are secured. You can copy these ๐ files to authenticate telegram-upload
on more machines, but
it is advisable to create a session file for each machine.
Telegram-upload has more options available, like customizing the files thumbnail, set a caption message (including
variables) or configuring a proxy.
Read the documentation <https://docs.nekmo.org/telegram-upload/usage.html#telegram-download>
_ for more info.
Run telegram-upload without installing it on your system using Docker. Instead of telegram-upload
and telegram-download
you should use upload
and download
. Usage::
$ docker run -v <files_dir>:/files/
-v <config_dir>:/config
-it nekmo/telegram-upload:master
<command> <args>
<files_dir>
: upload or download directory.<config_dir>
: Directory that will be created to store the telegram-upload configuration.
It is created automatically.<command>
: upload
and download
.<args>
: telegram-upload
and telegram-download
arguments.For example::
$ docker run -v /media/data/:/files/
-v $PWD/config:/config
-it nekmo/telegram-upload:master
upload file_to_upload.txt
This project developed by Nekmo <https://github.com/Nekmo>
& collaborators <https://github.com/Nekmo/telegram-upload/graphs/contributors>
would not be possible without
Telethon <https://github.com/LonamiWebs/Telethon>
_, the library used as a Telegram client.
Telegram-upload is licensed under the MIT license <https://github.com/Nekmo/telegram-upload/blob/master/LICENSE>
_.