Categorygithub.com/libp2p/go-libp2p-http
modulepackage
0.5.0
Repository: https://github.com/libp2p/go-libp2p-http.git
Documentation: pkg.go.dev

# README

go-libp2p-http

Build Status codecov standard-readme compliant

HTTP on top of libp2p

Package p2phttp allows to serve HTTP endpoints and make HTTP requests through libp2p using Go's standard "http" and "net" stack.

Instead of the regular "host:port" addressing, p2phttp uses a Peer ID and lets libp2p take care of the routing, thus taking advantage of features like multi-routes, NAT transversal and stream multiplexing over a single connection.

Table of Contents

Install

This package is a library that uses Go modules for dependency management.

Usage

Full documentation can be read at Godoc. The important bits follow.

A simple http.Server on libp2p works as:

listener, _ := gostream.Listen(host1, p2phttp.DefaultP2PProtocol)
defer listener.Close()
go func() {
	http.HandleFunc("/hello", func(w http.ResponseWriter, r *http.Request) {
		w.Write([]byte("Hi!"))
	})
	server := &http.Server{}
	server.Serve(listener)
}

The listener is provided by https://github.com/libp2p/go-libp2p-gostream .

A client just needs to be initialized with a custom libp2p host-based transport to perform requests to such server:

tr := &http.Transport{}
tr.RegisterProtocol("libp2p", p2phttp.NewTransport(clientHost))
client := &http.Client{Transport: tr}
res, err := client.Get("libp2p://Qmaoi4isbcTbFfohQyn28EiYM5CDWQx9QRCjDh3CTeiY7P/hello")

Contribute

PRs accepted.

License

MIT © Protocol Labs, Inc.

# Functions

NewTransport returns a new RoundTripper which uses the provided libP2P host to perform an http request and obtain the response.
ProtocolOption sets the Protocol Tag associated to the libp2p roundtripper.

# Variables

DefaultP2PProtocol is used to tag and identify streams handled by go-libp2p-http.

# Structs

RoundTripper implemenets http.RoundTrip and can be used as custom transport with Go http.Client.

# Type aliases

Option allows to set the libp2p transport options.