From 1ce10b453fbfd01aae7887c4ff8e5730f7908f50 Mon Sep 17 00:00:00 2001 From: Matthew Holt Date: Tue, 10 Sep 2019 13:11:27 -0600 Subject: Require Go 1.13; use Go 1.13's default support for TLS 1.3 --- README.md | 19 ++++++++++++------- modules/caddytls/tls.go | 8 -------- 2 files changed, 12 insertions(+), 15 deletions(-) diff --git a/README.md b/README.md index 6a43d12..08baecf 100644 --- a/README.md +++ b/README.md @@ -22,8 +22,8 @@ Please file issues to propose new features and report bugs, and after the bug or Requirements: -- [Go 1.12 or newer](https://golang.org/dl/) -- [Go modules](https://github.com/golang/go/wiki/Modules) enabled: `export GO111MODULE=on` +- [Go 1.13 or newer](https://golang.org/dl/) +- Make sure you do not disable [Go modules](https://github.com/golang/go/wiki/Modules) (`export GO111MODULE=auto`) Download source code: @@ -40,11 +40,13 @@ $ go build That will put a `caddy(.exe)` binary into the current directory. You can move it into your PATH or use `go install` to do that automatically (assuming `$GOPATH/bin` is already in your PATH). You can also use `go run main.go` for quick, temporary builds while developing. -The initial build may be slow as dependencies are downloaded. Subsequent builds should be very fast. If you encounter any Go-module-related errors, try clearing your Go module cache (`$GOPATH/pkg/mod`) and read [the Go wiki page about modules for help](https://github.com/golang/go/wiki/Modules). +The initial build may be slow as dependencies are downloaded. Subsequent builds should be very fast. If you encounter any Go-module-related errors, try clearing your Go module cache (`$GOPATH/pkg/mod`) and read [the Go wiki page about modules for help](https://github.com/golang/go/wiki/Modules). If you have issues with Go modules, please consult the Go community for help. But if there is an actual error in Caddy, please report it to us. ## Quick Start +(Until the stable 2.0 release, there may be breaking changes in v2, please be aware!) + These instructions assume an executable build of Caddy 2 is named `caddy` in the current folder. If it's in your PATH, you may omit the path to the binary (`./`). Start Caddy: @@ -119,11 +121,11 @@ example.com templates encode gzip zstd try_files {path}.html {path} -proxy /api http://localhost:9005 +reverse_proxy /api localhost:9005 file_server ``` -Instead of being its core method of configuration, an internal _config adapter_ adapts the Caddyfile to Caddy's native JSON structure. You can see it in action with the [`adapt-config` command](https://github.com/caddyserver/caddy/wiki/v2:-Documentation#adapt-config): +Instead of being its primary mode of configuration, an internal _config adapter_ adapts the Caddyfile to Caddy's native JSON structure. You can see it in action with the [`adapt-config` command](https://github.com/caddyserver/caddy/wiki/v2:-Documentation#adapt-config): ```bash $ ./caddy adapt-config --input path/to/Caddyfile --adapter caddyfile --pretty @@ -164,6 +166,8 @@ Caddy 2 is very much in development, so the documentation is an ongoing WIP, but **https://github.com/caddyserver/caddy/wiki/v2:-Documentation** +Note that breaking changes are expected until the stable 2.0 release. + ## List of Improvements @@ -219,9 +223,8 @@ The following is a non-comprehensive list of significant improvements over Caddy And a few major features still being worked on: - Logging -- More powerful, dynamic reverse proxy - Kubernetes ingress controller (mostly done, just polishing it -- and it's amazing) -- Config adapters. Caddy's native JSON config structure is powerful and complex. Config adapters upsample various formats to Caddy's native config. Planned adapters include Caddyfile, NGINX config, YAML, and TOML. The community might be interested in building Traefik and Apache config adapters! +- More config adapters. Caddy's native JSON config structure is powerful and complex. Config adapters upsample various formats to Caddy's native config. There are already adapters for Caddyfile, JSON 5, and JSON-C. Planned are NGINX config, YAML, and TOML. The community might be interested in building Traefik and Apache config adapters! @@ -250,6 +253,8 @@ Caddy's default _config adapter_ is the Caddyfile adapter. This takes a Caddyfil The following _config adapters_ are already being built or plan to be built: - Caddyfile +- JSON 5 +- JSON-C - nginx - YAML - TOML diff --git a/modules/caddytls/tls.go b/modules/caddytls/tls.go index 88b7790..62ec98d 100644 --- a/modules/caddytls/tls.go +++ b/modules/caddytls/tls.go @@ -18,9 +18,7 @@ import ( "crypto/tls" "encoding/json" "fmt" - "log" "net/http" - "os" "time" "github.com/caddyserver/caddy/v2" @@ -31,12 +29,6 @@ import ( func init() { caddy.RegisterModule(TLS{}) - - // opt-in TLS 1.3 for Go1.12 - // TODO: remove this line when Go1.13 is released. - if err := os.Setenv("GODEBUG", os.Getenv("GODEBUG")+",tls13=1"); err != nil { - log.Println("[ERROR] failed to set environment variable: ", err) - } } // TLS represents a process-wide TLS configuration. -- cgit v1.2.3