Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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: 2 months ago
JSON representation

Encrypted cloud storage Protocol based on Telegram

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 & Password

print(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 object

box.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.html

Third 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 `__