Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nonprojects/tgbox
Encrypted cloud storage Protocol based on Telegram
https://github.com/nonprojects/tgbox
api async cloud-storage encrypted-files python3 telegram
Last synced: 4 days ago
JSON representation
Encrypted cloud storage Protocol based on Telegram
- Host: GitHub
- URL: https://github.com/nonprojects/tgbox
- Owner: NonProjects
- License: lgpl-2.1
- Created: 2021-05-07T10:32:19.000Z (over 3 years ago)
- Default Branch: indev
- Last Pushed: 2024-04-14T09:37:15.000Z (7 months ago)
- Last Synced: 2024-04-14T09:59:30.274Z (7 months ago)
- Topics: api, async, cloud-storage, encrypted-files, python3, telegram
- Language: Python
- Homepage: https://tgbox.readthedocs.io/
- Size: 1.84 MB
- Stars: 30
- Watchers: 2
- Forks: 4
- Open Issues: 4
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
TGBOX: encrypted cloud storage based on Telegram
================================================
.. epigraph::| ❕ This repository contains a set of classes and functions used to manage TGBOX.
| Try the `tgbox-cli `__ if you're interested in working implementation!.. code-block:: python
import tgbox, tgbox.api.sync
# This two will not work. Get your own at https://my.telegram.org
API_ID, API_HASH = 1234567, '00000000000000000000000000000000'tc = tgbox.api.TelegramClient(api_id=API_ID, api_hash=API_HASH)
tc.start() # This method will prompt you for Phone, Code & Passwordprint(phrase := tgbox.keys.Phrase.generate()) # Your secret Box Phrase
basekey = tgbox.keys.make_basekey(phrase) # Will Require 1GB of RAM
box = tgbox.api.make_box(tc, basekey) # Will make Encrypted File Storage# Will upload selected file to the RemoteBox, cache information
# in LocalBox and return the tgbox.api.abstract.BoxFile object
abbf = box.push(input('File to upload (path): '))# Retrieving some info from the BoxFile
print('File size:', abbf.size, 'bytes')
print('File name:', abbf.file_name)downloaded = abbf.download() # Downloading your file from Remote.
print(downloaded) # Will print path to downloaded file objectbox.done() # Work is done. Close all connections!
.. epigraph::
| ❔ This code block heavily utilize the magic ``tgbox.api.sync`` module and high-level functions
| from the ``tgbox.api.abstract`` module for showcase. For actual *Async* code, see `Examples `__.Motivation
----------The Telegram is beautiful app. Not only by mean of features and Client API, but it's also used to be good in cryptography and secure messaging. In the last years, core and client devs of Telegram mostly work for "social-network features", i.e video chats and message reactions which is OK (until stories, wtf?), but there also can be plenty of "crypto-related" things implemented.
Target
------This *[unofficial]* library targets to be a PoC of **encrypted file storage** inside the Telegram, and should be used as standalone *Python library*.
Abstract
--------We name *"encrypted cloud storage"* as **Box** and the API to it as ``tgbox``. The *Box* splits into the **RemoteBox** and the **LocalBox**. They define a basic primitives. You can **share** your *Box* and separate *Files* with other people absolutely **secure** - only You and someone you want will have decryption key, even through insecure communication canals (`e2e `__). You can make **unlimited** amount of Boxes, Upload & Download **speed is faster** than in official Telegram clients and maximum filesize is around **2GB** and around **4GB** for Premium users.
Documentation
-------------See `ReadTheDocs `__ for main information and help.
You can also build docs from the source
.. code-block:: console
git clone https://github.com/NonProject/tgbox --branch=indev
cd tgbox && python3 -m pip install .[doc] # Install with doc
cd docs && make html && firefox _build/html/index.htmlThird party & thanks to
-----------------------
- `⭐️ `__ **Stargazers!**
- `Sphinx_book_theme `__ (`BSD 3-Clause `__)
- `Aiosqlite `__ (`MIT `__)
- `Telethon `__ (`MIT `__)
- `Ecdsa `__ (`LICENSE `__)
- `Filetype `__ (`MIT `__)
- `Cryptg `__ (`LICENSE `__)
- `Cryptography `__ (`LICENSE `__)Resources
---------
- Official **developer channel**: `@nontgbox `__
- **Example** TGBOX **container**: `@nontgbox_non `__