Skip to main content

A lightweight DNS-based message broker

Project description

TXTpresso

TXTpresso is an unconventional and experimental project aimed at exploring the possibilities of using the DNS protocol and TXT records with zero-second TTL for lightweight API-like data communication. Welcome to the geeky side of internet protocols!

Usage

pip install txtpresso
txtpresso-hello
dig @localhost +short txt hello.txtpresso
"Hello, world!"
dig @82.182.17.65 +short txt hello.txtpresso
"Hello, world!"
nslookup -type=TXT hello.txtpresso localhost
Server:         localhost
Address:        127.0.0.1#53

hello.txtpresso text = "Hello, world!"

Goal

The goal of TXTpresso is to use the DNS protocol's unique features to create a lightweight, fast, and potentially harder-to-detect communication system compared to traditional HTTP APIs. The widespread compatibility of DNS across all internet clients is a key advantage, facilitating a nimble and efficient method of data communication.

Concept

Using DNS TXT records and UDP, TXTpresso offers simple and swift communication methods compared to the overhead of HTTP requests, headers, and JSON payloads. By using unique lookups, such as test${UTIME}.domain, TXTpresso bypasses some caching issues, though users should be cautious of the potential impact on DNS traffic and server load.

Use Cases

  1. Bypassing firewalls or restrictions: By using DNS instead of HTTP APIs, this "under-the-radar" method might allow for communication in scenarios where traditional internet access is limited or blocked.
  2. Lightweight communication: If the emphasis is on simplicity and speed rather than robustness, using DNS lookups and UDP might keep things fast and lightweight compared to a full-blown HTTP API.
  3. Novel applications or hacks: As a fun, experimental project, you could come up with neat applications that take advantage of the DNS protocol's unique characteristics.

Example Script

You can look at this example that implements a time function using TXTpresso.

Methods

GET

TXTpresso's GET method is is using the concept of utilizing subdomains to represent queries or endpoints. By sending a DNS query for a TXT record on a specific subdomain (like time.domain), you essentially request data associated with that subdomain. The server, in turn, processes the query and sends back the corresponding data in the TXT record.

Example: To query the current time, use the dig command to search for a TXT record on time.domain:

dig @txtpresso.server.com +short txt time.txtpresso

POST - to be implemented

TXTpresso's POST method relies on BASE64-encoding the data you want to send and embedding it as part of a subdomain in a DNS query. This approach essentially transforms the subdomain into a carrier of your data payload. Upon receiving the query, the server decodes the information from the subdomain and processes it accordingly.

Example: Encode your data (limited to 512 bytes) in a DNS-friendly format, such as Base64, and send it as a subdomain for a DNS query.

dig @txtpresso.server.com +short a c3VwZXJ0cm91cGVyCg.post.txtpresso

Caveats

Be mindful of some limitations when using TXTpresso:

  1. Increased DNS traffic and potential server load.
  2. Caching complications, depending on unique lookups.
  3. Limitations in data size - a maximum of 512 bytes.
  4. Potential latency and packet loss with UDP.

Reminder

This experimental project is intended for educational purposes and to demonstrate the unconventional application of the DNS protocol. Always consider the broader impact on internet infrastructure and use TXTpresso responsibly.

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

TXTpresso-0.1.8.tar.gz (4.3 kB view details)

Uploaded Source

Built Distribution

TXTpresso-0.1.8-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

Details for the file TXTpresso-0.1.8.tar.gz.

File metadata

  • Download URL: TXTpresso-0.1.8.tar.gz
  • Upload date:
  • Size: 4.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for TXTpresso-0.1.8.tar.gz
Algorithm Hash digest
SHA256 44452a0d6cc5867a5ae9f31832fe64892f1cfe8f167b4fde102c1e5e26623718
MD5 e451dc9c5885a5d5aa4dfc6a12f962d4
BLAKE2b-256 3ef149b5df30312fb26556e810bae8a7786a2d9a8823a1777a12492d27d6b6ba

See more details on using hashes here.

File details

Details for the file TXTpresso-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: TXTpresso-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 5.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for TXTpresso-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 4d93b01e3adc6f4faf0acff27677529824b5715123fc788fec5bf251283e84c5
MD5 8aaf29076132330bdab255203b090d15
BLAKE2b-256 68908e74fa0bce1a293a5f3a4fd732be58466f31290e9ef79dd5946df20cf34b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page