Skip to content

pubky/pkarr

Repository files navigation

Pkarr

Own your identity. No registrars. No platforms. Just your keys.

Crates.io Documentation License

Pkarr turns Ed25519 public keys into domain names that you truly own. Publish DNS records to the Bittorrent peer-to-peer network with 10+ million nodes. No registrar can seize your domain. No platform can deplatform your identity.

Where we are going, this https://o4dksfbqk85ogzdb5osziw6befigbuxmuxkuxq8434q89uj56uyy resolves everywhere!

Quick Start

cargo add pkarr
use pkarr::{Client, Keypair, SignedPacket};

#[tokio::main]
async fn main() -> anyhow::Result<()> {
    // Generate your identity
    let keypair = Keypair::random();
    println!("Your public key: {}", keypair.public_key());

    // Create and sign DNS records
    let packet = SignedPacket::builder()
        .txt("_hello".try_into()?, "world".try_into()?, 3600)
        .sign(&keypair)?;

    // Publish to the network
    let client = Client::builder().build()?;
    client.publish(&packet, None).await?;

    println!("Published! Resolve at: https://pkdns.net/?id={}", keypair.public_key());
    Ok(())
}

Documentation

Guide Description
Introduction Philosophy, concepts, and why Pkarr exists
Quickstart Get started in 5 minutes
Integration Guide Embedding Pkarr in your application
Feature Reference Cargo feature flags and configurations
API Reference Full Rust API documentation
Examples Code samples
Specifications Protocol design documents

Demo

Try the web app to resolve records in your browser.

How It Works

  1. Generate a keypair — Your public key becomes your domain name
  2. Sign DNS records — Standard A, AAAA, TXT, CNAME records, self-signed
  3. Publish to the DHT — Records stored on the Mainline DHT (10M+ nodes)
  4. Resolve anywhere — Anyone can query and verify your records
sequenceDiagram
    participant Client
    participant Relay
    participant DHT

    Client->>Relay: Publish signed packet
    Relay->>DHT: Store (BEP44)

    Client->>Relay: Resolve public key
    Relay->>DHT: Query
    DHT->>Relay: Signed packet
    Relay->>Client: Verified response
Loading

The Network

Pkarr uses the Mainline DHT, the same peer-to-peer network that powers BitTorrent. Records are stored using BEP44 (mutable items). With 15 years of proven reliability and 10+ million active nodes, there's no need to bootstrap a new network.

Key Points

  • Records are ephemeral — The DHT drops records after hours; republish periodically
  • 1000-byte limit — Pkarr is for discovery, not storage
  • Caching everywhere — Clients and relays cache aggressively for performance
  • Relays for browsers — Web apps use HTTP relays since browsers cannot open UDP sockets

Pkarr is the I/O library that reads and writes DNS records to the DHT.

FAQ

Why not blockchain domains (ENS, Handshake)?

Blockchain domains introduce artificial scarcity, transaction fees, and chain dependencies. Pkarr uses public keys directly—infinite supply, zero fees, no chain lock-in.

Why not GNU Name System?

GNS is sophisticated but requires the full GNU net stack. Pkarr takes a minimalist approach: leverage existing infrastructure (Mainline DHT) and leave advanced features to application layers. Both use Ed25519, so migration paths exist.

Why Mainline DHT specifically?

It already exists. 15 years of reliability, 10+ million nodes, implementations in most languages. No need to bootstrap a new network or convince people to join.

What about human-readable names?

Public keys are not memorable by design—memorable names require registries, and registries introduce centralization. Build petname systems, phonebooks, or DNS bridges on top of Pkarr if you need human-friendly names.

License

MIT

About

Public Key Addressable Resource Records (sovereign TLDs)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 20

Languages