Update to go 1.18.6 to address CVE-2022-27664, CVE-2022-32190
From the mailing list:
We have just released Go versions 1.19.1 and 1.18.6, minor point releases.
These minor releases include 2 security fixes following the security policy:
- net/http: handle server errors after sending GOAWAY
A closing HTTP/2 server connection could hang forever waiting for a clean
shutdown that was preempted by a subsequent fatal error. This failure mode
could be exploited to cause a denial of service.
Thanks to Bahruz Jabiyev, Tommaso Innocenti, Anthony Gavazzi, Steven Sprecher,
and Kaan Onarlioglu for reporting this.
This is CVE-2022-27664 and Go issue https://go.dev/issue/54658.
- net/url: JoinPath does not strip relative path components in all circumstances
JoinPath and URL.JoinPath would not remove `../` path components appended to a
relative path. For example, `JoinPath("https://go.dev", "../go")` returned the
URL `https://go.dev/../go`, despite the JoinPath documentation stating that
`../` path elements are cleaned from the result.
Thanks to q0jt for reporting this issue.
This is CVE-2022-32190 and Go issue https://go.dev/issue/54385.
Release notes:
go1.18.6 (released 2022-09-06) includes security fixes to the net/http package,
as well as bug fixes to the compiler, the go command, the pprof command, the
runtime, and the crypto/tls, encoding/xml, and net packages. See the Go 1.18.6
milestone on the issue tracker for details;
https://github.com/golang/go/issues?q=milestone%3AGo1.18.6+label%3ACherryPickApproved
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
(cherry picked from commit cba36a064dc82ba49d5caab566f88f0501279ecb)
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
2022-09-06 20:23:40 +00:00
|
|
|
ARG GO_VERSION=1.18.6
|
2019-07-17 11:59:16 +00:00
|
|
|
|
|
|
|
FROM golang:${GO_VERSION}-alpine AS base
|
2019-09-11 07:36:53 +00:00
|
|
|
ENV GO111MODULE=off
|
2018-10-03 00:57:42 +00:00
|
|
|
RUN apk --no-cache add \
|
2017-09-08 14:43:04 +00:00
|
|
|
bash \
|
2017-11-03 09:09:06 +00:00
|
|
|
btrfs-progs-dev \
|
2017-09-08 14:43:04 +00:00
|
|
|
build-base \
|
|
|
|
curl \
|
|
|
|
lvm2-dev \
|
2018-10-03 00:57:42 +00:00
|
|
|
jq
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2019-04-19 14:15:03 +00:00
|
|
|
RUN mkdir -p /build/
|
2017-09-08 14:43:04 +00:00
|
|
|
RUN mkdir -p /go/src/github.com/docker/docker/
|
|
|
|
WORKDIR /go/src/github.com/docker/docker/
|
|
|
|
|
2019-04-19 14:15:03 +00:00
|
|
|
FROM base AS frozen-images
|
|
|
|
# Get useful and necessary Hub images so we can "docker load" locally instead of pulling
|
|
|
|
COPY contrib/download-frozen-image-v2.sh /
|
|
|
|
RUN /download-frozen-image-v2.sh /build \
|
2020-06-30 03:06:03 +00:00
|
|
|
buildpack-deps:buster@sha256:d0abb4b1e5c664828b93e8b6ac84d10bce45ee469999bef88304be04a2709491 \
|
|
|
|
busybox:latest@sha256:95cf004f559831017cdf4628aaf1bb30133677be8702a8c5f2994629f637a209 \
|
|
|
|
busybox:glibc@sha256:1f81263701cddf6402afe9f33fca0266d9fff379e59b1748f33d3072da71ee85 \
|
2020-12-16 13:53:49 +00:00
|
|
|
debian:bullseye@sha256:7190e972ab16aefea4d758ebe42a293f4e5c5be63595f4d03a5b9bf6839a4344 \
|
2020-06-30 03:06:03 +00:00
|
|
|
hello-world:latest@sha256:d58e752213a51785838f9eed2b7a498ffa1cb3aa7f946dda11af39286c3db9a9
|
2020-12-16 13:53:49 +00:00
|
|
|
# See also frozenImages in "testutil/environment/protect.go" (which needs to be updated when adding images to this list)
|
2019-04-19 14:15:03 +00:00
|
|
|
|
2019-04-19 14:24:33 +00:00
|
|
|
FROM base AS dockercli
|
|
|
|
ENV INSTALL_BINARY_NAME=dockercli
|
|
|
|
COPY hack/dockerfile/install/install.sh ./install.sh
|
|
|
|
COPY hack/dockerfile/install/$INSTALL_BINARY_NAME.installer ./
|
|
|
|
RUN PREFIX=/build ./install.sh $INSTALL_BINARY_NAME
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2019-04-19 14:26:10 +00:00
|
|
|
# Build DockerSuite.TestBuild* dependency
|
|
|
|
FROM base AS contrib
|
|
|
|
COPY contrib/syscall-test /build/syscall-test
|
|
|
|
COPY contrib/httpserver/Dockerfile /build/httpserver/Dockerfile
|
|
|
|
COPY contrib/httpserver contrib/httpserver
|
|
|
|
RUN CGO_ENABLED=0 go build -buildmode=pie -o /build/httpserver/httpserver github.com/docker/docker/contrib/httpserver
|
|
|
|
|
|
|
|
# Build the integration tests and copy the resulting binaries to /build/tests
|
2019-04-19 14:24:33 +00:00
|
|
|
FROM base AS builder
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2017-09-12 12:53:20 +00:00
|
|
|
# Set tag and add sources
|
2019-04-19 14:20:24 +00:00
|
|
|
COPY . .
|
2019-04-27 04:38:55 +00:00
|
|
|
# Copy test sources tests that use assert can print errors
|
|
|
|
RUN mkdir -p /build${PWD} && find integration integration-cli -name \*_test.go -exec cp --parents '{}' /build${PWD} \;
|
|
|
|
# Build and install test binaries
|
2019-04-30 07:22:22 +00:00
|
|
|
ARG DOCKER_GITCOMMIT=undefined
|
2017-09-08 14:43:04 +00:00
|
|
|
RUN hack/make.sh build-integration-test-binary
|
2019-04-27 04:38:55 +00:00
|
|
|
RUN mkdir -p /build/tests && find . -name test.main -exec cp --parents '{}' /build/tests \;
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2019-04-19 14:15:03 +00:00
|
|
|
## Generate testing image
|
2019-06-23 17:39:20 +00:00
|
|
|
FROM alpine:3.10 as runner
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2019-04-19 14:20:24 +00:00
|
|
|
ENV DOCKER_REMOTE_DAEMON=1
|
|
|
|
ENV DOCKER_INTEGRATION_DAEMON_DEST=/
|
|
|
|
ENTRYPOINT ["/scripts/run.sh"]
|
|
|
|
|
|
|
|
# Add an unprivileged user to be used for tests which need it
|
|
|
|
RUN addgroup docker && adduser -D -G docker unprivilegeduser -s /bin/ash
|
|
|
|
|
2017-09-08 14:43:04 +00:00
|
|
|
# GNU tar is used for generating the emptyfs image
|
2018-10-03 00:57:42 +00:00
|
|
|
RUN apk --no-cache add \
|
2017-09-08 14:43:04 +00:00
|
|
|
bash \
|
|
|
|
ca-certificates \
|
|
|
|
g++ \
|
|
|
|
git \
|
|
|
|
iptables \
|
2018-01-16 18:49:18 +00:00
|
|
|
pigz \
|
2017-09-08 14:43:04 +00:00
|
|
|
tar \
|
2018-10-03 00:57:42 +00:00
|
|
|
xz
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2019-04-19 14:20:24 +00:00
|
|
|
COPY hack/test/e2e-run.sh /scripts/run.sh
|
|
|
|
COPY hack/make/.ensure-emptyfs /scripts/ensure-emptyfs.sh
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2019-04-19 14:02:22 +00:00
|
|
|
COPY integration/testdata /tests/integration/testdata
|
|
|
|
COPY integration/build/testdata /tests/integration/build/testdata
|
|
|
|
COPY integration-cli/fixtures /tests/integration-cli/fixtures
|
2017-09-08 14:43:04 +00:00
|
|
|
|
2019-04-19 14:15:03 +00:00
|
|
|
COPY --from=frozen-images /build/ /docker-frozen-images
|
2019-04-19 14:24:33 +00:00
|
|
|
COPY --from=dockercli /build/ /usr/bin/
|
2019-04-19 14:26:10 +00:00
|
|
|
COPY --from=contrib /build/ /tests/contrib/
|
2019-04-27 04:38:55 +00:00
|
|
|
COPY --from=builder /build/ /
|