2019-11-04 11:08:22 +01:00
# go-ens
[](https://github.com/wealdtech/go-ens/releases/)
[](LICENSE)
[](https://godoc.org/github.com/wealdtech/go-ens)
[](https://travis-ci.org/wealdtech/go-ens)
[](https://codecov.io/github/wealdtech/go-ens)
[](https://goreportcard.com/report/github.com/wealdtech/go-ens)
Go module to simplify interacting with the [Ethereum Name Service ](https://ens.domains/ ) contracts.
## Table of Contents
- [Install ](#install )
- [Usage ](#usage )
- [Maintainers ](#maintainers )
- [Contribute ](#contribute )
- [License ](#license )
## Install
`go-ens` is a standard Go module which can be installed with:
```sh
go get github.com/wealdtech/go-ens
```
## Usage
`go-ens` provides simple access to the [Ethereum Name Service ](https://ens.domains/ ) (ENS) contracts.
### Resolution
2019-11-23 18:57:05 +01:00
The most commonly-used feature of ENS is resolution: converting an ENS name to an Ethereum address. `go-ens` provides a simple call to allow this:
2019-11-04 11:08:22 +01:00
```go
address, err := ens.Resolve(client, domain)
```
where `client` is a connection to an Ethereum client and `domain` is the fully-qualified name you wish to resolve (e.g. `foo.mydomain.eth` ) (full examples for using this are given in the [Example ](#Example ) section below).
The reverse process, converting an address to an ENS name, is just as simple:
```go
domain, err := ens.ReverseResolve(client, address)
```
Note that if the address does not have a reverse resolution this will return "". If you just want a string version of an address for on-screen display then you can use `ens.Format()` , for example:
```go
fmt.Printf("The address is %s\n", ens.Format(client, address))
```
This will carry out reverse resolution of the address and print the name if present; if not it will print a formatted version of the address.
### Management of names
A top-level name is one that sits directly underneath `.eth` , for example `mydomain.eth` . Lower-level names, such as `foo.mydomain.eth` are covered in the following section. `go-ens` provides a simplified `Name` interface to manage top-level, removing the requirement to understand registrars, controllers, _etc._
Starting out with names in `go-ens` is easy:
```go
2020-02-10 12:22:37 +01:00
client, err := ethclient.Dial("https://infura.io/v3/SECRET")
name, err := ens.NewName(client, "mydomain.eth")
2019-11-04 11:08:22 +01:00
```
2019-11-23 18:57:05 +01:00
Addresses can be set and obtained using the address functions, for example to get an address:
```go
COIN_TYPE_ETHEREUM := uint64(60)
address, err := name.Address(COIN_TYPE_ETHEREUM)
```
ENS supports addresses for multiple coin types; values of coin types can be found at https://github.com/satoshilabs/slips/blob/master/slip-0044.md
2019-11-04 11:08:22 +01:00
### Registering and extending names
Most operations on a domain will involve setting resolvers and resolver information.
### Management of subdomains
Because subdomains have their own registrars they do not work with the `Name` interface.
### Example
```go
package main
import (
"github.com/ethereum/go-ethereum/ethclient"
ens "github.com/wealdtech/go-ens"
)
func main() {
client, err := ethclient.Dial("https://infura.io/v3/SECRET")
if err != nil {
panic(err)
}
// Resolve a name to an address
domain := "wealdtech.eth"
address, err := ens.Resolve(client, domain)
if err != nil {
panic(err)
}
fmt.Printf("Address of %s is %s\n", domain, address.Hex())
// Reverse resolve an address to a name
reverse, err := ens.ReverseResolve(client, address)
if err != nil {
panic(err)
}
if reverse == "" {
fmt.Printf("%s has no reverse lookup\n", address.Hex())
} else {
fmt.Printf("Name of %s is %s\n", address.Hex(), reverse)
}
}
```
## Maintainers
Jim McDonald: [@mcdee ](https://github.com/mcdee ).
## Contribute
Contributions welcome. Please check out [the issues ](https://github.com/wealdtech/go-ens/issues ).
## License
[Apache-2.0 ](LICENSE ) © 2019 Weald Technology Trading Ltd