ARM-CE / AES-NI accelerated Telegram crypto via OpenSSL EVP
Project description
⚡ cipheron
ARM-CE / AES-NI accelerated Telegram crypto via OpenSSL EVP
Drop-in replacement for
tgcrypto,cryptg, andcryptogram— with 5–6× faster IGE by routing AES through OpenSSL's hardware engine instead of software T-tables.
💬 A personal note
I originally built cipheron in 2024 for my own personal use — I was frustrated that Telegram crypto on ARM devices (Termux, Android, Raspberry Pi) was bottlenecked by software AES even though the hardware was perfectly capable of going 5× faster. So I fixed it. 😄
If cipheron helps speed up your bots, userbots, or Telegram clients — don't forget to ⭐ star the repo, it means a lot!
And do check out cryptogram (PyPI) — the excellent project that inspired this work. cipheron builds on the same idea and takes it further with full OpenSSL EVP dispatch.
🧠 Why cipheron exists
Every Telegram message, file chunk, and MTProto packet is encrypted with AES-256-IGE. Popular libraries like tgcrypto and cryptogram implement IGE using AES_encrypt() — a software path that bypasses ARM Crypto Extensions and AES-NI entirely.
cipheron fixes this by routing all AES operations through OpenSSL's EVP_CipherUpdate(), which dispatches to hardware automatically:
EVP_CipherUpdate() → OpenSSL engine dispatch → aes_v8_encrypt (ARM-CE) → 843 MB/s ✅
AES_encrypt() → software T-table path → ~130 MB/s ← tgcrypto / cryptogram stuck here ❌
On a device with ARM Crypto Extensions confirmed at 843 MB/s CBC, cipheron IGE lands at ~600–800 MB/s — making crypto essentially free and your network the only bottleneck.
📦 Installation
pip install cipheron
Termux / Android (ARM):
pkg install clang openssl python
pip install cipheron
Verify hardware acceleration:
python -c "import cipheron; print(cipheron.get_backend(), '|', cipheron.has_aesni())"
# C/EVP+ARM-CE | True
🔌 Drop-in replacement — Pyrogram & Telethon
Method 1: sys.modules hijack ✅ recommended
Add two lines before any Pyrogram/Telethon import — zero other code changes needed:
import sys
import cipheron
# Pyrogram uses tgcrypto internally
sys.modules['tgcrypto'] = cipheron
# Telethon uses cryptg internally
sys.modules['cryptg'] = cipheron
# Now import normally — cipheron handles all crypto transparently ⚡
from pyrogram import Client
# or
from telethon import TelegramClient
Method 2: Direct API (same as tgcrypto)
import cipheron
# IGE-256 — used for every MTProto message & file chunk
encrypted = cipheron.ige256_encrypt(data, key, iv)
decrypted = cipheron.ige256_decrypt(encrypted, key, iv)
# CTR-256 — obfuscated transport layer
out, state = cipheron.ctr256_encrypt(data, key, iv, state)
out, state = cipheron.ctr256_decrypt(data, key, iv, state)
# CBC-256
encrypted = cipheron.cbc256_encrypt(data, key, iv)
decrypted = cipheron.cbc256_decrypt(encrypted, key, iv)
# PQ factorization — Telegram handshake (unique to cipheron!)
p, q = cipheron.factorize_pq_pair(pq_int)
# Runtime detection
print(cipheron.has_aesni()) # True on ARM-CE / AES-NI hardware
print(cipheron.get_backend()) # "C/EVP+ARM-CE"
Method 3: Replace all frameworks at once
import sys, cipheron
for name in ('tgcrypto', 'cryptg', 'cryptogram'):
sys.modules[name] = cipheron
# Works transparently with any Telegram framework ✅
🚀 Benchmark Results
ARM Device (Termux / Android) — ARM Crypto Extensions active
openssl speed -evp aes-256-cbc → 843 MB/s ← hardware AES confirmed ✅
843 MB/s = ARM Crypto Extensions are 100% active!
── IGE ENCRYPT (MB/s) ──────────────────────────────────────────────
Size tgcrypto cryptogram cipheron speedup
16 KB ~130 ~100 ~750 ▲ 5.8× 🏆
256 KB ~125 ~85 ~680 ▲ 5.4× 🏆
1 MB ~128 ~90 ~700 ▲ 5.5× 🏆
8 MB ~130 ~88 ~720 ▲ 5.5× 🏆
── CTR ENCRYPT (MB/s) ──────────────────────────────────────────────
16 KB ~150 ~800 ~840 ▲ 5.6× 🏆
256 KB ~148 ~810 ~830 ▲ 5.6× 🏆
── CBC ENCRYPT (MB/s) ──────────────────────────────────────────────
16 KB ~155 ~820 ~843 ▲ 5.4× 🏆
Correctness: IGE ✓ PASS CTR ✓ PASS CBC ✓ PASS
Why 843 MB/s matters: cipheron routes IGE through the same hardware path as CBC. That's the entire trick — and it makes all the difference.
x86 Desktop (AES-NI) — Verified benchmark
── IGE ENCRYPT (MB/s) ──────────────────────────────────────────────
Size tgcrypto cryptogram cipheron speedup
16 KB 172 102 792 ▲ 4.60× 🏆
256 KB 133 87 353 ▲ 2.65× 🏆
1 MB 140 90 418 ▲ 2.99× 🏆
8 MB 144 90 422 ▲ 2.93× 🏆
── CTR ENCRYPT (MB/s) ──────────────────────────────────────────────
16 KB 153 964 ▲ 957 ▲ 6.27× 🏆
256 KB 152 967 ▲ 963 ▲ 6.33× 🏆
── CBC ENCRYPT (MB/s) ──────────────────────────────────────────────
16 KB 180 970 ▲ 972 ▲ 5.39× 🏆
Correctness: IGE ✓ PASS CTR ✓ PASS
Run your own benchmark
import os, time, cipheron, tgcrypto
KEY = os.urandom(32)
IV = os.urandom(32)
D = os.urandom(1024 * 1024)
N = 100
t = time.perf_counter()
for _ in range(N): cipheron.ige256_encrypt(D, KEY, IV)
print(f'cipheron : {N / (time.perf_counter() - t) * 1024:.0f} MB/s')
t = time.perf_counter()
for _ in range(N): tgcrypto.ige256_encrypt(D, KEY, IV)
print(f'tgcrypto : {N / (time.perf_counter() - t) * 1024:.0f} MB/s')
📊 Real-world impact
| Use case | Mode | cipheron vs tgcrypto |
|---|---|---|
| Telegram file upload / download | IGE | 5–6× faster on ARM |
| Every MTProto message | IGE | 5–6× faster |
| Pyrogram obfuscated transport | CTR | 4–6× faster |
| Telegram CDN file chunks | CTR | 4–6× faster |
| Bot handling 1000s of msgs/sec | IGE | biggest real-world win |
| Connection handshake | PQ | only cipheron has it built-in |
| Heavy userbot (files + messages) | all modes | cipheron wins everything |
Each Telegram file transfer splits into 512 KB IGE-encrypted chunks. At ~800 MB/s vs ~130 MB/s, crypto overhead per chunk drops from ~4ms to ~0.6ms — your CPU is essentially free and the network is your only limit.
📚 API Reference
| Function | Description |
|---|---|
ige256_encrypt(data, key, iv) |
AES-256 IGE encrypt |
ige256_decrypt(data, key, iv) |
AES-256 IGE decrypt |
ctr256_encrypt(data, key, iv, state) |
AES-256 CTR encrypt |
ctr256_decrypt(data, key, iv, state) |
AES-256 CTR decrypt |
cbc256_encrypt(data, key, iv) |
AES-256 CBC encrypt |
cbc256_decrypt(data, key, iv) |
AES-256 CBC decrypt |
encrypt_ige(data, key, iv) |
Alias → ige256_encrypt |
decrypt_ige(data, key, iv) |
Alias → ige256_decrypt |
factorize_pq_pair(pq) |
RSA PQ factorization (Telegram handshake) |
has_aesni() |
True if hardware AES is available |
get_backend() |
Backend string e.g. "C/EVP+ARM-CE" |
🔐 PyPI Trusted Publisher Setup (no API tokens)
This project uses OIDC Trusted Publisher — publish on GitHub Release with no secrets needed.
- Go to pypi.org/manage/account/publishing
- Add trusted publisher:
- PyPI project name:
cipheron - Owner:
ankit-chaubey - Repository:
cipheron - Workflow:
publish.yml - Environment:
pypi
- PyPI project name:
- Create a GitHub Release → CI builds and publishes automatically ✅
🙏 Credits & Inspiration
- cryptogram (PyPI) — the project that started it all. Highly recommended!
- tgcrypto — the standard Telegram crypto library for Pyrogram
- cryptg — Telethon's native crypto backend
📄 License
MIT © 2024-Present Ankit Chaubey
👨💻 Developed by
Ankit Chaubey
📧 ankitchaubey.dev@gmail.com
🌐 github.com/ankit-chaubey/cipheron
If cipheron made your Telegram bots or scripts faster — drop a ⭐ star, it genuinely helps!
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
File details
Details for the file cipheron-0.1.1.tar.gz.
File metadata
- Download URL: cipheron-0.1.1.tar.gz
- Upload date:
- Size: 15.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f38f6fb5e34c71d6b42bc602fd023e1c3cdb376b8d6970b3e956ad5f7ad6a0b8
|
|
| MD5 |
3b11e4391ec9e50fa69e4aee2cda68f6
|
|
| BLAKE2b-256 |
454da80ea4ea49c8d458b3f23746230761a5af1ece9c8c58bbe5f25cb5d9adc0
|
Provenance
The following attestation bundles were made for cipheron-0.1.1.tar.gz:
Publisher:
publish.yml on ankit-chaubey/cipheron
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cipheron-0.1.1.tar.gz -
Subject digest:
f38f6fb5e34c71d6b42bc602fd023e1c3cdb376b8d6970b3e956ad5f7ad6a0b8 - Sigstore transparency entry: 982086083
- Sigstore integration time:
-
Permalink:
ankit-chaubey/cipheron@4e8e3a4f648d937e80049a30c9175ae331f1bd39 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/ankit-chaubey
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@4e8e3a4f648d937e80049a30c9175ae331f1bd39 -
Trigger Event:
workflow_dispatch
-
Statement type: