|
|
||
|---|---|---|
| .. | ||
| internal | ||
| logging | ||
| quicvarint | ||
| .gitignore | ||
| .golangci.yml | ||
| Changelog.md | ||
| LICENSE | ||
| README.md | ||
| buffer_pool.go | ||
| client.go | ||
| closed_conn.go | ||
| codecov.yml | ||
| config.go | ||
| conn_id_generator.go | ||
| conn_id_manager.go | ||
| connection.go | ||
| crypto_stream.go | ||
| crypto_stream_manager.go | ||
| datagram_queue.go | ||
| errors.go | ||
| frame_sorter.go | ||
| framer.go | ||
| interface.go | ||
| mockgen.go | ||
| mockgen_private.sh | ||
| mtu_discoverer.go | ||
| multiplexer.go | ||
| packet_handler_map.go | ||
| packet_packer.go | ||
| packet_unpacker.go | ||
| receive_stream.go | ||
| retransmission_queue.go | ||
| send_conn.go | ||
| send_queue.go | ||
| send_stream.go | ||
| server.go | ||
| stream.go | ||
| streams_map.go | ||
| streams_map_generic_helper.go | ||
| streams_map_incoming_bidi.go | ||
| streams_map_incoming_generic.go | ||
| streams_map_incoming_uni.go | ||
| streams_map_outgoing_bidi.go | ||
| streams_map_outgoing_generic.go | ||
| streams_map_outgoing_uni.go | ||
| sys_conn.go | ||
| sys_conn_df.go | ||
| sys_conn_df_linux.go | ||
| sys_conn_df_windows.go | ||
| sys_conn_helper_darwin.go | ||
| sys_conn_helper_freebsd.go | ||
| sys_conn_helper_linux.go | ||
| sys_conn_no_oob.go | ||
| sys_conn_oob.go | ||
| sys_conn_windows.go | ||
| token_store.go | ||
| tools.go | ||
| window_update_queue.go | ||
README.md
A QUIC implementation in pure Go
quic-go is an implementation of the QUIC protocol (RFC 9000, RFC 9001, RFC 9002) in Go, including the Unreliable Datagram Extension, RFC 9221. It has support for HTTP/3 RFC 9114.
In addition the RFCs listed above, it currently implements the IETF QUIC draft-29. Support for draft-29 will eventually be dropped, as it is phased out of the ecosystem.
Guides
We currently support Go 1.16.x, Go 1.17.x, and Go 1.18.x.
Running tests:
go test ./...
QUIC without HTTP/3
Take a look at this echo example.
Usage
As a server
See the example server. Starting a QUIC server is very similar to the standard lib http in go:
http.Handle("/", http.FileServer(http.Dir(wwwDir)))
http3.ListenAndServeQUIC("localhost:4242", "/path/to/cert/chain.pem", "/path/to/privkey.pem", nil)
As a client
See the example client. Use a http3.RoundTripper as a Transport in a http.Client.
http.Client{
Transport: &http3.RoundTripper{},
}
Projects using quic-go
| Project | Description | Stars |
|---|---|---|
| algernon | Small self-contained pure-Go web server with Lua, Markdown, HTTP/2, QUIC, Redis and PostgreSQL support | |
| caddy | Fast, multi-platform web server with automatic HTTPS | |
| go-ipfs | IPFS implementation in go | |
| syncthing | Open Source Continuous File Synchronization | |
| traefik | The Cloud Native Application Proxy | |
| v2ray-core | A platform for building proxies to bypass network restrictions | |
| cloudflared | A tunneling daemon that proxies traffic from the Cloudflare network to your origins | |
| OONI Probe | The Open Observatory of Network Interference (OONI) aims to empower decentralized efforts in documenting Internet censorship around the world. |
Contributing
We are always happy to welcome new contributors! We have a number of self-contained issues that are suitable for first-time contributors, they are tagged with help wanted. If you have any questions, please feel free to reach out by opening an issue or leaving a comment.