Oldie Goldie — a peer-to-peer encrypted chat with tunnel and token-based access.
Project description
🕊️ Oldie-Goldie
A Being Human Cult (BHC) Initiative
A self-hostable, peer-to-peer encrypted chat system with tunnel-based connections and token-authenticated access.
🌐 What is Oldie-Goldie?
Oldie-Goldie is an on-demand, on-the-fly, self-hostable, peer-to-peer encrypted chat system. It provides ephemeral tunnel-based connections and token-authenticated access, enabling private, auditable, and serverless-style conversations between trusted peers.
💡 Why I Built It
🕵️ The Problem
Modern messaging services promise privacy — but often log metadata, store your messages, or use your data for ad targeting and behavioral profiling. Even when encryption is claimed, the closed-source nature of these apps makes it impossible to know if your messages are truly private.
“Mining for gold without opening the chest.” That’s how metadata surveillance works — who you message, when, how often — all reveal more than you think.
I wanted a fallback — a chat app that was:
- Open source and auditable
- Truly self-hostable
- Peer-to-peer encrypted, with no middleman
So I built Oldie-Goldie, and it became my trusted space for private discussions.
🧠 The Solution
Oldie-Goldie gives you:
- Direct, secure, ephemeral connections
- No cloud storage
- No accounts
- End-to-end encrypted tunnels
- Invite-token based access control
You spin up a temporary server, share a link + token with your peer, chat securely, and shut it all down when done. Nothing is logged, nothing persists — just you and your peer.
🧭 Intended Usage
Pre-requisite: Out-of-Band Sharing
- Usernames (pseudonyms) — agree beforehand with your peer.
- PSK (pre-shared key) — share a private key to authenticate tunnels.
Flow for Global Server
- Install the required Cloudflared package.
- Start the server in tunneling mode (
--host public) to get a temporary public URL. - Share that URL with your peer.
- Both register using pseudonyms (not real names).
- Use
/list_usersto find your peer. - Send a connection request via
/connect @username. - Both enter the agreed PSK to authenticate the tunnel.
- If PSK mismatches, the session is terminated, and usernames are blocked.
⚠️ Disclaimer Oldie-Goldie is not a social media or group chat platform. It’s designed for private, ephemeral one-to-one communication, where simplicity and trust are prioritized.
🧱 Guard Rails and Trust Model
| Layer | Purpose |
|---|---|
| Pre-shared pseudonyms | Protects identity |
| Pre-shared secret/password | Proof of identity |
| Token-based access | Prevents unauthorized entry |
| Temporary tunnels | Ensure no data persistence |
🔐 Example: Token-Based Secure Server
Generate tokens for two users:
og-server --host public --invite-token --bind alice bob
Then connect:
og-client --server-host public --url <server-url> --token <token>
Cloudflared Installation on Ubuntu
- Download the Debian Package via github.
wget https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64.deb
- Install the debian package
sudo dpkg -i cloudflared-linux-amd64.deb
Cloudflared Installation on Windows
Method-1
-
Download the .exe file from github (or) follow this url cloudflared_exe_download.
-
Double click and install it and add the path in which cloudflared is installed to Environment variables.
Method-2
-
Run the command prompt as Administrator.
-
execute the following command. So it will also add path to environment variables.
-
Make sure the PC is on latest version of either Windows 10/11.
winget install --id Cloudflare.cloudflared
⚙️ Installation
pip install oldie-goldie
🚀 Usage
🖥️ Run Server
Local
og-server --host local
Public (with Tunnel)
og-server --host public
Protected (Invite Tokens)
og-server --host public --invite-token --token-count 2
Strongly Protected (Bound Tokens)
og-server --host public --invite-token --bind alice bob
💬 Run Client
Connect Locally
og-client --server-host local
Connect Remotely
og-client --server-host public --url <server-url>
Connect with Token
og-client --server-host public --url <server-url> --token <token>
🧾 Changelog
See CHANGELOG.md for the full version history and upcoming features.
🧪 Future Roadmap
- Extend safe_input with foreground/background input support
- Enable server-side dynamic token generation
- Add
--reuseflag for token reuse - Tidy server and client logs
- Improve modularity and developer docs
- Add Android support
🌿 About Being Human Cult (BHC)
The Tech wing of Being Human Cult (BHC) is a community-driven initiative focused on building humane, open-source technologies that empower people to connect authentically and privately — without exploitation, surveillance, or data harvesting.
Oldie-Goldie is developed and maintained under the BHC umbrella as a free and open-source project.
Learn more: https://beinghumancult.blogspot.com
☕ Support the Project
Oldie-Goldie is free, open-source, and maintained with care by volunteers. If you’d like to support development or buy the maintainers a coffee:
- 💖 Buy Me a Coffee: (link coming soon)
- 💰 GitHub Sponsors: (link coming soon)
- 🪙 Ko-fi: (link coming soon)
- 📢 Share the project! — word of mouth helps more than you think.
Your support keeps the project independent and privacy-focused. 🙏
🤝 Contributing
Pull requests are welcome! If you’d like to contribute, please:
- Fork the repo
- Create a new branch
- Make your changes
- Submit a PR
Or open an issue to discuss ideas.
For more detailed developer setup and contributing guidelines, see CONTRIBUTING.md
📜 License
Licensed under the MIT License.
Copyright © 2025
Venu Kotamraju, under the Being Human Cult (BHC) initative.
💬 Connect
- GitHub → Oldie-Goldie
- PyPI → oldie-goldie
- LinkedIn → [Link coming soon...]
- Blog → Being Human Cult
🧡 A Note from the Author
I built Oldie-Goldie to reclaim digital privacy. It’s not about hiding — it’s about owning your data and choosing who gets to see it.
❤️ Author
Venu Kotamraju
kotamraju.venugopal@gmail.com
GitHub
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file oldie_goldie-0.5.7.tar.gz.
File metadata
- Download URL: oldie_goldie-0.5.7.tar.gz
- Upload date:
- Size: 47.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6a3c31531b8eabedf6dc702dc1109786bc44a07d3f5ccbddaab8ce542165dd56
|
|
| MD5 |
827ceb2cec1a993eda55dfecd39be88c
|
|
| BLAKE2b-256 |
2591bd7efbe19417a7fb0e6ab43c909575d008f5bb6f416c6bba12caec78a934
|
File details
Details for the file oldie_goldie-0.5.7-py3-none-any.whl.
File metadata
- Download URL: oldie_goldie-0.5.7-py3-none-any.whl
- Upload date:
- Size: 45.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b8daecbad721756ca3c578d2d8d90bbcc6211bb79ea17d084e5956488c4321f3
|
|
| MD5 |
e2a0e21bd4c33770e94d6cfa1df80067
|
|
| BLAKE2b-256 |
12231defcdaf3160afd067b4d4b3967ef800b7a4b39cbd1e4eb54ccad0db1610
|