go/src
Daniel McCarney 992d154717 crypto/tls: update TLS 1.3 client compression validation
Unlike in earlier TLS versions, in TLS 1.3 when processing a server
hello the legacy_compression_method MUST have the value 0. It is no
longer a parameter that offers a choice of compression method.

With this in mind, it seems more appropriate to return a decode error
when we encounter a non-zero compression method in a server hello
message. We haven't found a parameter value we reject, we've found
a message that doesn't decode according to its specification.

Making this change also aligns with BoringSSL and allows enabling the
TLS13-HRR-InvalidCompressionMethod bogo test.

Updates #72006

Change-Id: I27a2cd231e4b8762b0d9e2dbd3d8ddd5b87fd5c4
Reviewed-on: https://go-review.googlesource.com/c/go/+/669156
Reviewed-by: Roland Shoemaker <roland@golang.org>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Cherry Mui <cherryyz@google.com>
2025-05-09 13:38:31 -07:00
..
archive
arena
bufio
builtin
bytes bytes, strings: reduce Split{,After}Seq heap allocations 2025-05-05 19:08:23 -07:00
cmd cmd/go: change go tool to build tools missing from GOROOT/pkg/tool 2025-05-09 12:31:21 -07:00
cmp
compress
container
context
crypto crypto/tls: update TLS 1.3 client compression validation 2025-05-09 13:38:31 -07:00
database/sql database/sql: wake cleaner if maxIdleTime set to less than maxLifetime 2025-04-16 22:57:52 -07:00
debug all: use strings.ReplaceAll where applicable 2025-04-16 12:26:29 -07:00
embed
encoding encoding/json: add json/v2 with GOEXPERIMENT=jsonv2 guard 2025-04-18 08:24:07 -07:00
errors
expvar
flag
fmt
go internal/testhash: move cryptotest.TestHash to shared package 2025-05-08 16:41:44 -07:00
hash hash: use testhash.TestHash in all hash functions 2025-05-08 16:41:48 -07:00
html
image
index/suffixarray
internal internal/bytealg: optimize the function indexbyte using SIMD on loong64 2025-05-08 19:13:30 -07:00
io fs: clarify documentation for ReadDir method 2025-04-19 16:07:50 -07:00
iter
log log/slog: export Source method in Record for custom handler support 2025-05-06 03:58:07 -07:00
maps
math math/big: fix incorrect register allocation for mipsx/mips64x 2025-05-01 05:04:39 -07:00
mime mime: speed up ParseMediaType 2025-04-26 08:01:54 -07:00
net net,os: support converting between *os.File and net.Conn on Windows 2025-05-05 04:05:18 -07:00
os os: avoid escape from Root via paths ending in ../ 2025-05-06 11:33:18 -07:00
path
plugin
reflect
regexp regexp/syntax: recognize category aliases like \p{Letter} 2025-04-18 14:13:38 -07:00
runtime runtime: avoid overflow in mutex delay calculation 2025-05-08 12:07:41 -07:00
slices
sort
strconv
strings bytes, strings: reduce Split{,After}Seq heap allocations 2025-05-05 19:08:23 -07:00
structs
sync runtime: schedule cleanups across multiple goroutines 2025-05-08 11:10:33 -07:00
syscall syscall: cache Errno.Error() on Windows 2025-04-30 08:41:56 -07:00
testdata
testing runtime, testing/synctest: stop advancing time when main goroutine exits 2025-05-07 13:14:25 -07:00
text
time encoding/json: add json/v2 with GOEXPERIMENT=jsonv2 guard 2025-04-18 08:24:07 -07:00
unicode unicode: add CategoryAliases, Cn, LC 2025-04-18 14:13:31 -07:00
unique runtime: schedule cleanups across multiple goroutines 2025-05-08 11:10:33 -07:00
unsafe
vendor cmd/vendor: update x/tools and x/text 2025-04-23 15:34:39 -07:00
weak
Make.dist
README.vendor
all.bash
all.bat
all.rc
bootstrap.bash
buildall.bash
clean.bash
clean.bat
clean.rc
cmp.bash
go.mod cmd/vendor: update x/tools and x/text 2025-04-23 15:34:39 -07:00
go.sum cmd/vendor: update x/tools and x/text 2025-04-23 15:34:39 -07:00
make.bash
make.bat
make.rc
race.bash cmd,runtime: enable race detector on loong64 2025-05-07 11:52:31 -07:00
race.bat
run.bash
run.bat
run.rc

README.vendor

Vendoring in std and cmd
========================

The Go command maintains copies of external packages needed by the
standard library in the src/vendor and src/cmd/vendor directories.

There are two modules, std and cmd, defined in src/go.mod and
src/cmd/go.mod. When a package outside std or cmd is imported
by a package inside std or cmd, the import path is interpreted
as if it had a "vendor/" prefix. For example, within "crypto/tls",
an import of "golang.org/x/crypto/cryptobyte" resolves to
"vendor/golang.org/x/crypto/cryptobyte". When a package with the
same path is imported from a package outside std or cmd, it will
be resolved normally. Consequently, a binary may be built with two
copies of a package at different versions if the package is
imported normally and vendored by the standard library.

Vendored packages are internally renamed with a "vendor/" prefix
to preserve the invariant that all packages have distinct paths.
This is necessary to avoid compiler and linker conflicts. Adding
a "vendor/" prefix also maintains the invariant that standard
library packages begin with a dotless path element.

The module requirements of std and cmd do not influence version
selection in other modules. They are only considered when running
module commands like 'go get' and 'go mod vendor' from a directory
in GOROOT/src.

Maintaining vendor directories
==============================

Before updating vendor directories, ensure that module mode is enabled.
Make sure that GO111MODULE is not set in the environment, or that it is
set to 'on' or 'auto', and if you use a go.work file, set GOWORK=off.

Also, ensure that 'go env GOROOT' shows the root of this Go source
tree. Otherwise, the results are undefined. It's recommended to build
Go from source and use that 'go' binary to update its source tree.

Requirements may be added, updated, and removed with 'go get'.
The vendor directory may be updated with 'go mod vendor'.
A typical sequence might be:

    cd src  # or src/cmd
    go get golang.org/x/net@master
    go mod tidy
    go mod vendor

Use caution when passing '-u' to 'go get'. The '-u' flag updates
modules providing all transitively imported packages, not only
the module providing the target package.

Note that 'go mod vendor' only copies packages that are transitively
imported by packages in the current module. If a new package is needed,
it should be imported before running 'go mod vendor'.