go-multiaddr/README.md

59 lines
1.3 KiB
Markdown
Raw Normal View History

2014-07-03 23:42:24 -07:00
# go-multiaddr
[multiaddr](https://github.com/jbenet/multiaddr) implementation in Go.
## Example
### Simple
```go
2014-10-06 04:05:20 -07:00
import ma "github.com/jbenet/go-multiaddr"
2014-07-03 23:42:24 -07:00
2014-10-06 04:05:20 -07:00
// construct from a string (err signals parse failure)
m1, err := ma.NewMultiaddr("/ip4/127.0.0.1/udp/1234")
2014-07-03 23:42:24 -07:00
2014-10-06 04:05:20 -07:00
// construct from bytes (err signals parse failure)
m2, err := ma.NewMultiaddrBytes(m1.Bytes())
// true
strings.Equal(m1.String(), "/ip4/127.0.0.1/udp/1234")
strings.Equal(m1.String(), m2.String())
bytes.Equal(m1.Bytes(), m2.Bytes())
m1.Equal(m2)
m2.Equal(m1)
2014-07-03 23:42:24 -07:00
```
### Protocols
```go
// get the multiaddr protocol description objects
2014-07-04 00:12:05 -07:00
addr.Protocols()
// []*Protocol{
// &Protocol{ Code: 4, Name: 'ip4', Size: 32},
// &Protocol{ Code: 17, Name: 'udp', Size: 16},
2014-07-03 23:42:24 -07:00
// }
```
### En/decapsulate
```go
2014-10-06 04:05:20 -07:00
m.Encapsulate(ma.NewMultiaddr("/sctp/5678"))
2014-07-03 23:42:24 -07:00
// <Multiaddr /ip4/127.0.0.1/udp/1234/sctp/5678>
2014-10-06 04:05:20 -07:00
m.Decapsulate(ma.NewMultiaddr("/udp")) // up to + inc last occurrence of subaddr
2014-07-03 23:42:24 -07:00
// <Multiaddr /ip4/127.0.0.1>
```
### Tunneling
Multiaddr allows expressing tunnels very nicely.
```js
2014-10-06 04:05:20 -07:00
printer, _ := ma.NewMultiaddr("/ip4/192.168.0.13/tcp/80")
proxy, _ := ma.NewMultiaddr("/ip4/10.20.30.40/tcp/443")
2014-07-03 23:42:24 -07:00
printerOverProxy := proxy.Encapsulate(printer)
2014-10-06 04:05:20 -07:00
// /ip4/10.20.30.40/tcp/443/ip4/192.168.0.13/tcp/80
2014-07-03 23:42:24 -07:00
2014-10-06 04:05:20 -07:00
proxyAgain := printerOverProxy.Decapsulate(printer)
// /ip4/10.20.30.40/tcp/443
2014-07-03 23:42:24 -07:00
```