2014-07-03 23:42:24 -07:00
|
|
|
# go-multiaddr
|
|
|
|
|
|
|
|
[multiaddr](https://github.com/jbenet/multiaddr) implementation in Go.
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
|
|
|
### Simple
|
|
|
|
|
|
|
|
```go
|
|
|
|
import "github.com/jbenet/go-multiaddr"
|
|
|
|
|
2014-07-04 00:48:33 -07:00
|
|
|
m := multiaddr.NewMultiaddr("/ip4/127.0.0.1/udp/1234")
|
2014-07-03 23:42:24 -07:00
|
|
|
// <Multiaddr /ip4/127.0.0.1/udp/1234>
|
|
|
|
m.buffer
|
|
|
|
// <Buffer >
|
|
|
|
m.String()
|
|
|
|
// /ip4/127.0.0.1/udp/1234
|
|
|
|
|
|
|
|
// construct with Buffer
|
|
|
|
m = multiaddr.Multiaddr{ Bytes: m.Bytes }
|
|
|
|
// <Multiaddr /ip4/127.0.0.1/udp/1234>
|
|
|
|
```
|
|
|
|
|
|
|
|
### 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
|
|
|
// }
|
|
|
|
```
|
|
|
|
|
|
|
|
### Other formats
|
|
|
|
|
|
|
|
```go
|
|
|
|
// handles the stupid url version too
|
|
|
|
m = multiaddr.NewUrl("udp4://127.0.0.1:1234")
|
|
|
|
// <Multiaddr /ip4/127.0.0.1/udp/1234>
|
|
|
|
m.Url(buf)
|
|
|
|
// udp4://127.0.0.1:1234
|
|
|
|
```
|
|
|
|
|
|
|
|
### En/decapsulate
|
|
|
|
|
|
|
|
```go
|
2014-07-04 00:48:33 -07:00
|
|
|
m.Encapsulate(m.NewMultiaddr("/sctp/5678"))
|
2014-07-03 23:42:24 -07:00
|
|
|
// <Multiaddr /ip4/127.0.0.1/udp/1234/sctp/5678>
|
2014-07-04 00:48:33 -07:00
|
|
|
m.Decapsulate(m.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-07-04 00:48:33 -07:00
|
|
|
printer := multiaddr.NewMultiaddr("/ip4/192.168.0.13/tcp/80")
|
|
|
|
proxy := multiaddr.NewMultiaddr("/ip4/10.20.30.40/tcp/443")
|
2014-07-03 23:42:24 -07:00
|
|
|
printerOverProxy := proxy.Encapsulate(printer)
|
|
|
|
// <Multiaddr /ip4/10.20.30.40/tcp/443/ip4/192.168.0.13/tcp/80>
|
|
|
|
|
2014-07-04 00:48:33 -07:00
|
|
|
proxyAgain := printerOverProxy.Decapsulate(multiaddr.NewMultiaddr("/ip4"))
|
2014-07-03 23:42:24 -07:00
|
|
|
// <Multiaddr /ip4/10.20.30.40/tcp/443>
|
|
|
|
```
|