go/src
Roland Shoemaker 12d5810cdb [release-branch.go1.22] net/netip: check if address is v6 mapped in Is methods
In all of the Is* methods, check if the address is a v6 mapped v4
address, and unmap it if so.

Thanks to Enze Wang of Alioth (@zer0yu) and Jianjun Chen of Zhongguancun
Lab (@chenjj) for reporting this issue.

Fixes #67680
Fixes #67682
Fixes CVE-2024-24790

Change-Id: I6bd03ca1a5d93a0b59027d861c84060967b265b0
Reviewed-on: https://go-internal-review.googlesource.com/c/go/+/1460
Reviewed-by: Russ Cox <rsc@google.com>
Reviewed-by: Damien Neil <dneil@google.com>
(cherry picked from commit f7f270c1621fdc7ee48e0487b2fac0356947d19b)
Reviewed-on: https://go-internal-review.googlesource.com/c/go/+/1480
Reviewed-by: Tatiana Bradley <tatianabradley@google.com>
Reviewed-on: https://go-review.googlesource.com/c/go/+/590296
Auto-Submit: Michael Knyszek <mknyszek@google.com>
Reviewed-by: David Chase <drchase@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
2024-06-04 17:17:27 +00:00
..
archive [release-branch.go1.22] archive/zip: treat truncated EOCDR comment as an error 2024-05-29 23:37:37 +00:00
arena
bufio
builtin builtin: mention PanicNilError in comments of recover 2023-12-18 19:42:41 +00:00
bytes bytes: add a boundary test for Count of 1 byte 2023-11-30 20:05:58 +00:00
cmd [release-branch.go1.22] cmd/link: add runtime.text.N symbols to macho symbol table in dynlink mode 2024-05-24 21:00:57 +00:00
cmp cmp: add test case for uinitptr 2024-01-17 17:58:34 +00:00
compress
container
context
crypto [release-branch.go1.22] crypto/x509: remove TestPlatformVerifierLegacy tests 2024-05-16 21:26:01 +00:00
database/sql all: remove newline characters after return statements 2023-12-14 17:22:18 +00:00
debug all: replace outdated links 2023-12-30 00:24:56 +00:00
embed embed: fix variable name in example 2023-11-17 16:35:13 +00:00
encoding [release-branch.go1.22] encoding/gob: make x509.Certificate marshalable again 2024-03-27 18:46:56 +00:00
errors errors: clarify references to Unwrap in doc 2023-11-21 22:04:29 +00:00
expvar all: make more use of the new atomic integer types 2023-11-17 16:39:52 +00:00
flag
fmt
go [release-branch.go1.22] go/types, types2: handle Alias types in substitution 2024-03-26 19:41:26 +00:00
hash all: remove newline characters after return statements 2023-12-14 17:22:18 +00:00
html [release-branch.go1.22] html/template: escape additional tokens in MarshalJSON errors 2024-02-28 19:53:38 +00:00
image
index/suffixarray
internal [release-branch.go1.22] go/types, types2: handle Alias types in substitution 2024-03-26 19:41:26 +00:00
io io/fs: godoc links to testing/fstest 2024-01-15 21:21:41 +00:00
iter iter: fix race instrumentation for Pull2 2023-12-13 16:20:09 +00:00
log log/slog: clarify SetDefault behavior 2024-01-08 18:26:18 +00:00
maps maps: fix aliasing problems with Clone 2023-12-05 17:05:56 +00:00
math math/big: fix uint64 overflow in nat.mulRange 2024-01-09 15:29:36 +00:00
mime [release-branch.go1.22] net/textproto, mime/multipart: avoid unbounded read in MIME header 2024-03-05 16:43:51 +00:00
net [release-branch.go1.22] net/netip: check if address is v6 mapped in Is methods 2024-06-04 17:17:27 +00:00
os [release-branch.go1.22] os: RemoveAll: fix symlink race for unix 2024-05-30 01:14:42 +00:00
path io/fs,path/filepath: fix typo in SkipAll/SkipDir doc 2024-01-09 08:50:19 +00:00
plugin
reflect reflect: fix typo in type.go 2023-12-30 00:23:59 +00:00
regexp
runtime [release-branch.go1.22] runtime: x_cgo_getstackbound: initialize pthread attr 2024-05-29 23:45:12 +00:00
slices slices: explicitly discard results of some functions 2024-01-05 21:35:07 +00:00
sort sort: add available godoc link 2023-11-28 16:40:32 +00:00
strconv
strings src: a/an grammar fixes 2023-11-20 15:56:08 +00:00
sync sync: use map[any]any instead of map[interface{}]interface{} in the godoc 2024-01-08 17:02:01 +00:00
syscall [release-branch.go1.22] os: RemoveAll: fix symlink race for unix 2024-05-30 01:14:42 +00:00
testdata
testing testing: add regression tests for reentrant calls to T.Run 2023-12-01 21:27:08 +00:00
text all: remove newline characters after return statements 2023-12-14 17:22:18 +00:00
time
unicode
unsafe
vendor [release-branch.go1.22] net/http: update bundled golang.org/x/net/http2 2024-04-12 22:24:00 +00:00
Make.dist
README.vendor
all.bash
all.bat
all.rc
bootstrap.bash
buildall.bash
clean.bash
clean.bat
clean.rc
cmp.bash
go.mod [release-branch.go1.22] net/http: update bundled golang.org/x/net/http2 2024-04-12 22:24:00 +00:00
go.sum [release-branch.go1.22] net/http: update bundled golang.org/x/net/http2 2024-04-12 22:24:00 +00:00
make.bash
make.bat
make.rc
race.bash
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'.

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
    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'.