# A QUIC implementation in pure Go <img src="docs/quic.png" width=303 height=124> [data:image/s3,"s3://crabby-images/e000f/e000f2ba6ab6889d8b500140499ea7fa4b962499" alt="PkgGoDev"](https://pkg.go.dev/github.com/lucas-clemente/quic-go) [data:image/s3,"s3://crabby-images/9ccd7/9ccd715e20e7554bd0b9a298826fea5b1b3fae50" alt="Travis Build Status"](https://travis-ci.org/lucas-clemente/quic-go) [data:image/s3,"s3://crabby-images/80718/80718b769dee8d9965eaf77e50c7c92d5d70a77e" alt="CircleCI Build Status"](https://circleci.com/gh/lucas-clemente/quic-go) [data:image/s3,"s3://crabby-images/6e47a/6e47a7305271cb42b5905ac5371da62608607d3e" alt="Windows Build Status"](https://ci.appveyor.com/project/lucas-clemente/quic-go/branch/master) [data:image/s3,"s3://crabby-images/ec188/ec18824dfc4fd022c38bf5e1afdbefa40f754870" alt="Code Coverage"](https://codecov.io/gh/lucas-clemente/quic-go/) quic-go is an implementation of the [QUIC protocol, RFC 9000](https://datatracker.ietf.org/doc/html/rfc9000) protocol in Go. In addition to RFC 9000, it currently implements the [IETF QUIC draft-29](https://tools.ietf.org/html/draft-ietf-quic-transport-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 and Go 1.17.x.* Running tests: go test ./... ### QUIC without HTTP/3 Take a look at [this echo example](example/echo/echo.go). ## Usage ### As a server See the [example server](example/main.go). Starting a QUIC server is very similar to the standard lib http in go: ```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](example/client/main.go). Use a `http3.RoundTripper` as a `Transport` in a `http.Client`. ```go http.Client{ Transport: &http3.RoundTripper{}, } ``` ## Projects using quic-go | Project | Description | Stars | |------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-------| | [algernon](https://github.com/xyproto/algernon) | Small self-contained pure-Go web server with Lua, Markdown, HTTP/2, QUIC, Redis and PostgreSQL support | data:image/s3,"s3://crabby-images/50904/50904cb5c780fef9a83793b6bf2298d2b969996e" alt="GitHub Repo stars" | | [caddy](https://github.com/caddyserver/caddy/) | Fast, multi-platform web server with automatic HTTPS | data:image/s3,"s3://crabby-images/eeb91/eeb919e83bc135fe4ecd679afe9139b473def00a" alt="GitHub Repo stars" | | [go-ipfs](https://github.com/ipfs/go-ipfs) | IPFS implementation in go | data:image/s3,"s3://crabby-images/7985a/7985afffa224b3ba8a12ab6b05faeed9c8f30dd4" alt="GitHub Repo stars" | | [nextdns](https://github.com/nextdns/nextdns) | NextDNS CLI client (DoH Proxy) | data:image/s3,"s3://crabby-images/e5df3/e5df3901f20e39cb5d2565c0066f967ba4e8283a" alt="GitHub Repo stars" | | [syncthing](https://github.com/syncthing/syncthing/) | Open Source Continuous File Synchronization | data:image/s3,"s3://crabby-images/623fb/623fb138e5ad6cab82f2970ae6adfedcf190030b" alt="GitHub Repo stars" | | [traefik](https://github.com/traefik/traefik) | The Cloud Native Application Proxy | data:image/s3,"s3://crabby-images/c278f/c278f1f40b3a5b0ca0bc48672829d0b4677d6e6f" alt="GitHub Repo stars" | | [v2ray-core](https://github.com/v2fly/v2ray-core) | A platform for building proxies to bypass network restrictions | data:image/s3,"s3://crabby-images/5d592/5d592714a0dca9294860bc15846947ddd5f92bc4" alt="GitHub Repo stars" | ## 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](https://github.com/lucas-clemente/quic-go/issues?q=is%3Aissue+is%3Aopen+label%3A%22help+wanted%22). If you have any questions, please feel free to reach out by opening an issue or leaving a comment.