Skip to content

Dostr: Ethereum-flavoured Nostr

Icon

Links: [.XYZ] [.ETH]

Version: v0.9.9-beta.4

DOSTR 📡

Dostr ('Dost' means 'friend' in Hindi, an adoption of 'Doost' from Farsi) is an Ethereum-flavoured Nostr client. Dostr is a fully backward-compatible Nostr client with ENS and Ethereum integration. It's a collection of experimental specifications and implementations of Ethereum-aware Nostr clients to transfer signed data/messages, and transact between users and services.

Ethereum was originally designed as a 3-in-1 protocol: Ethereum/EVM as Consensus mechanism, Swarm as Storage system and Whisper as Messaging protocol. Dostr is equivalent to Whisper in this grander vision outlined in the Ethereum white paper. Dostr client allows Nostr to function with Ethereum wallets (SIWE) and leverage properties of ENS, such as allowing users to import their ENS identity, avatars and other records on Nostr. Dostr is unsurprisingly a minimal implementation of Sign In With X (SIWx).

Introduction

To understand Dostr, one must understand Nostr. Nostr is a minimal peer-to-peer networking protocol with following properties:

  • Nostr consists of Clients and Relays. Clients are local instances run by users and relays are websocket servers which communicate between clients.
  • Nostr clients have the ability to talk to relays and make requests for filtered information, which the relay fetches from another client and returns to the original requester.
  • Nostr clients are identified by their private keys and may have a nickname. Nostr clients must sign the information they send and relays must validate the information before transmitting it.

More details about the Nostr protocol may be found here (and here). In native Nostr implementation, Schnorr signature scheme is used as per Bitcoin-native BIP-340 standard. Dostr adds to this standard by deriving the Nostr-specific private keys from Ethereum-native ECDSA signature scheme outlined in EIP-191 and EIP-712 using HMAC Key Derivation Function (HKDF). In Dostr clients, ENS names of the signing wallets become the usernames of the users and users may choose to import their ENS avatars and other records.

Dostr Design

Dostr design is identical to the Nostr specifications described in NIP-01 except for two main differences - a) using ECDSA signatures to derive user keys, and b) use of ENS via a gateway to access the user properties instead of a web2 DNS server. The detailed NIP-111 proposal covering these two aspects is currently under review.

How is Dostr helpful?

Dostr allows Nostr to work with Ethereum-based wallets and leverage the rich UX of Ethereum ecosystem. Dostr replaces the current web2 centralised dependencies in Nostr ecosystem (DNS and server storage) with web3 decentralised dependencies, e.g. ENS and IPFS respectively. In course of this, Dostr has unwittingly solved the problem of secure login into Nostr network from mobile devices. No universal Nostr mobile extensions existed until Dostr (Damus recently launched a Nostr client but for iOS only). In addition, most Ethereum-wallets implement ENS by default and Dostr is the first and only protocol that allows users to utilise their NIP-02 compatible ENS names on Nostr. Dostr further leverages properties of ENS such as its DNS resolution via a gateway https://vitalik.eth.LIMO to store NIP-05 compatible public user information on decentralised storage infrastructures such as IPFS, Arweave, Swarm etc.

Is Dostr secure?

The Nostr-specific private keys derived by Dostr (using the HMAC function) are new keys which have no invertible connection to the Ethereum wallet that derived it. Users can import or export their new generated Nostr-specific private keys in other Nostr clients and continue to use the same ENS features without exposing their Ethereum wallet private keys.

Current status

Dostr client UI is ready and the prototype test build can be accessed on GitHub Pages. Dostr client is a fork of Astral (which is a fork of Branle), and it can already be used with generic Nostr keys. Developers are currently testing SIWE interfacing with the UI while NIP-111 is under active review. The expected release date for the client is March 31 2023.

Pinned Loading

  1. resources resources Public

    Dostr docs

    1 2

  2. dostr-client dostr-client Public

    Forked from monlovesmango/astral

    Dostr client made with Quasar

    JavaScript 1

  3. nips nips Public

    Forked from nostr-protocol/nips

    Nostr Implementation Possibilities

  4. nostr-tools nostr-tools Public

    Forked from nbd-wtf/nostr-tools

    Tools for developing Nostr clients.

    JavaScript

  5. homepage homepage Public

    Dostr Landing Page

    CSS

  6. CAIPs CAIPs Public

    Forked from ChainAgnostic/CAIPs

    Chain Agnostic Improvement Proposals

    HTML

Repositories

Showing 8 of 8 repositories
  • address-encoder Public Forked from ensdomains/address-encoder

    Encodes and decodes address formats for various cryptocurrencies

    dostr-eth/address-encoder’s past year of commit activity
    TypeScript 0 BSD-3-Clause 149 0 0 Updated May 31, 2023
  • dostr-client Public Forked from monlovesmango/astral

    Dostr client made with Quasar

    dostr-eth/dostr-client’s past year of commit activity
    JavaScript 1 MIT 69 0 0 Updated Apr 22, 2023
  • nostr-tools Public Forked from nbd-wtf/nostr-tools

    Tools for developing Nostr clients.

    dostr-eth/nostr-tools’s past year of commit activity
    JavaScript 0 198 0 0 Updated Apr 17, 2023
  • resources Public

    Dostr docs

    dostr-eth/resources’s past year of commit activity
    1 2 0 0 Updated Apr 8, 2023
  • nips Public Forked from nostr-protocol/nips

    Nostr Implementation Possibilities

    dostr-eth/nips’s past year of commit activity
    0 612 0 0 Updated Apr 6, 2023
  • homepage Public

    Dostr Landing Page

    dostr-eth/homepage’s past year of commit activity
    CSS 0 0 0 0 Updated Apr 3, 2023
  • .github Public
    dostr-eth/.github’s past year of commit activity
    0 0 0 0 Updated Apr 3, 2023
  • CAIPs Public Forked from ChainAgnostic/CAIPs

    Chain Agnostic Improvement Proposals

    dostr-eth/CAIPs’s past year of commit activity
    HTML 0 CC0-1.0 196 0 0 Updated Apr 3, 2023

Top languages

Loading…

Most used topics

Loading…