From bf87803e60d26be3b0bbfc6d60d280f9bd5349d9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lubo=C5=A1=20Pokorn=C3=BD?= Date: Mon, 24 Jun 2024 10:00:38 +0200 Subject: [PATCH] =?UTF-8?q?build:=20=F0=9F=94=92Enable=20and=20enforce=20`?= =?UTF-8?q?boringcrypto`=20experiment=20(#2353)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Makefile | 6 +++--- cmd/wave/main.go | 7 +++++++ cmd/wavedb/main.go | 7 +++++++ 3 files changed, 17 insertions(+), 3 deletions(-) diff --git a/Makefile b/Makefile index 6970b25856..bd15078941 100644 --- a/Makefile +++ b/Makefile @@ -104,10 +104,10 @@ test-ui-watch: ## Run UI unit tests cd ui && $(MAKE) test build-server: ## Build server for current OS/Arch - go build $(LDFLAGS) -o waved cmd/wave/main.go + GOEXPERIMENT=boringcrypto go build $(LDFLAGS) -o waved cmd/wave/main.go build-db: ## Build database server for current OS/Arch - go build $(LDFLAGS) -o wavedb cmd/wavedb/main.go + GOEXPERIMENT=boringcrypto go build $(LDFLAGS) -o wavedb cmd/wavedb/main.go build-db-micro: go build -ldflags '-s -w -X main.Version=$(VERSION) -X main.BuildDate=$(BUILD_DATE)' -o wavedb cmd/wavedb/main.go @@ -201,7 +201,7 @@ release-os: rm -rf test/cypress/screenshots/*.* rm -rf test/cypress/videos/*.* rsync --exclude node_modules -a test build/$(REL)/ - GOOS=$(OS) GOARCH=$(ARCH) go build $(LDFLAGS) -o build/$(REL)/waved$(EXE_EXT) cmd/wave/main.go + GOOS=$(OS) GOARCH=$(ARCH) GOEXPERIMENT=boringcrypto go build $(LDFLAGS) -o build/$(REL)/waved$(EXE_EXT) cmd/wave/main.go cd build && tar -czf $(REL).tar.gz --exclude='*.state' --exclude='__pycache__' $(REL) .PHONY: website diff --git a/cmd/wave/main.go b/cmd/wave/main.go index f357d2d92f..4e572740e8 100644 --- a/cmd/wave/main.go +++ b/cmd/wave/main.go @@ -29,6 +29,13 @@ import ( "strings" "time" + // Blank import of "crypto/tls/fipsonly" enforces that only FIPS-approved algorithms + // are used for TLS. + // Package is only available only when GOEXPERIMENT=boringcrypto is set. + // We do not hide the import behind a build tag so that we enforce that the binary is built with + // the boring crypto experiment enabled. + _ "crypto/tls/fipsonly" + "github.com/h2oai/goconfig" _ "github.com/h2oai/goconfig/env" "github.com/h2oai/wave" diff --git a/cmd/wavedb/main.go b/cmd/wavedb/main.go index 366a5a9ad7..e6f6ad7afa 100644 --- a/cmd/wavedb/main.go +++ b/cmd/wavedb/main.go @@ -19,6 +19,13 @@ import ( "fmt" "runtime" + // Blank import of "crypto/tls/fipsonly" enforces that only FIPS-approved algorithms + // are used for TLS. + // Package is only available only when GOEXPERIMENT=boringcrypto is set. + // We do not hide the import behind a build tag so that we enforce that the binary is built with + // the boring crypto experiment enabled. + _ "crypto/tls/fipsonly" + "github.com/h2oai/wave/pkg/db" "github.com/h2oai/wave/pkg/keychain" )