Setting up federated addresses with Stellar

Fun fact: the username you sign up with on Stellar’s hosted web client is actually a federated address rather than a username. That is, the username gdb is actually short for gdb@stellar.org. If you control a domain, you can set up federated addresses for your domain.

We’ve now set up federated addresses on stripe.com. You can now use your client to make a payment to gdb@stripe.com.

Setting up federation #

You can set up federation for your domain too — it’s pretty easy (though per the below, the protocol may end up being changed). I’ll walk you through how a client or browser resolves gdb@stripe.com.

stellar.txt #

First, the client finds Stripe’s stellar.txt file by requesting the following URLs until one works:

We’ve set up our stellar.txt on stripe.com, which is served as follows:

$ curl -i https://stripe.com/stellar.txt
HTTP/1.1 200 OK
...
Access-Control-Allow-Origin: *

[federation_url]
https://stripe.com/stellar/federation

Note that the response sets an Access-Control-Allow-Origin: * header, so that the user’s browser can actually read the response.

Federation server #

Next, the client makes a request to the federation server with query string destination=gdb&domain=stripe.com&type=federation&user=gdb (I think the duplicated gdb parameter is an artifact that will be end up being removed). We respond with a federation record:

$ curl -i 'https://stripe.com/stellar/federation?destination=gdb&domain=stripe.com&type=federation&user=gdb'
HTTP/1.1 200 OK
...
Access-Control-Allow-Origin: *

{
  "federation_json": {
    "type": "federation_record",
    "destination": "gdb",
    "domain": "stripe.com",
    "destination_address": "gpFfX9931eSbjUhtu3ujb6Tu7Z48u53uiL"
  }
}

At this point, the client knows which address gdb@stripe.com resolves to.

Code #

You can find the code for a sample federation server on Github. (If you write one in another language, you should add it to that repository!)


Note that the protocol is not fully stable yet. The current implementation is forked from Ripple’s, and it’s likely that the Stellar devs will want to give it a once-over, based on lessons learned, before fully baking it in.


It would be awesome to see someone create a hosted federation service. Users would set up stellar.example.com to point to the service, provide the service with the corresponding SSL cert, and then configure their user accounts through a webface. I don’t think it’d be all that hard to build, and it could be a viable business on its own.

 
81
Kudos
 
81
Kudos

Now read this

OpenAI Five Finals Intro

The text of my speech introducing OpenAI Five at Saturday’s OpenAI Five Finals event, where our AI beat the world champions at Dota 2: “Welcome everyone. This is an exciting day. First, this is an historic moment: this will be the first... Continue →