mirror of https://github.com/docker/compose.git
pass authprovider to buildkit session in addition to driver's Auth parameter
Signed-off-by: Nicolas De Loof <nicolas.deloof@gmail.com>
This commit is contained in:
parent
f1aaab1943
commit
e0ae9d21b4
43
go.mod
43
go.mod
|
@ -4,6 +4,7 @@ go 1.16
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/AlecAivazis/survey/v2 v2.2.3
|
github.com/AlecAivazis/survey/v2 v2.2.3
|
||||||
|
github.com/Azure/azure-pipeline-go v0.2.2 // indirect
|
||||||
github.com/Azure/azure-sdk-for-go v48.2.0+incompatible
|
github.com/Azure/azure-sdk-for-go v48.2.0+incompatible
|
||||||
github.com/Azure/azure-storage-file-go v0.8.0
|
github.com/Azure/azure-storage-file-go v0.8.0
|
||||||
github.com/Azure/go-autorest/autorest v0.11.12
|
github.com/Azure/go-autorest/autorest v0.11.12
|
||||||
|
@ -12,21 +13,22 @@ require (
|
||||||
github.com/Azure/go-autorest/autorest/azure/cli v0.4.2
|
github.com/Azure/go-autorest/autorest/azure/cli v0.4.2
|
||||||
github.com/Azure/go-autorest/autorest/date v0.3.0
|
github.com/Azure/go-autorest/autorest/date v0.3.0
|
||||||
github.com/Azure/go-autorest/autorest/to v0.4.0
|
github.com/Azure/go-autorest/autorest/to v0.4.0
|
||||||
github.com/Microsoft/go-winio v0.4.15
|
github.com/Azure/go-autorest/autorest/validation v0.2.0 // indirect
|
||||||
|
github.com/Microsoft/go-winio v0.4.17
|
||||||
github.com/aws/aws-sdk-go v1.35.33
|
github.com/aws/aws-sdk-go v1.35.33
|
||||||
github.com/awslabs/goformation/v4 v4.15.6
|
github.com/awslabs/goformation/v4 v4.15.6
|
||||||
github.com/buger/goterm v1.0.0
|
github.com/buger/goterm v1.0.0
|
||||||
github.com/cnabio/cnab-to-oci v0.3.1-beta1
|
github.com/cnabio/cnab-to-oci v0.3.1-beta1
|
||||||
github.com/compose-spec/compose-go v0.0.0-20210505145624-6dcd3d18b38b
|
github.com/compose-spec/compose-go v0.0.0-20210505145624-6dcd3d18b38b
|
||||||
github.com/containerd/console v1.0.1
|
github.com/containerd/console v1.0.2
|
||||||
github.com/containerd/containerd v1.4.3
|
github.com/containerd/containerd v1.5.0
|
||||||
github.com/containerd/continuity v0.0.0-20200928162600-f2cc35102c2a // indirect
|
|
||||||
github.com/distribution/distribution/v3 v3.0.0-20210316161203-a01c71e2477e
|
github.com/distribution/distribution/v3 v3.0.0-20210316161203-a01c71e2477e
|
||||||
github.com/docker/buildx v0.5.2-0.20210309210748-c9f02c32d495
|
github.com/docker/buildx v0.5.2-0.20210422185057-908a856079fc
|
||||||
github.com/docker/cli v20.10.3-0.20210127070556-d26bdfd4ea23+incompatible
|
github.com/docker/cli v20.10.6+incompatible
|
||||||
github.com/docker/docker v20.10.1+incompatible
|
github.com/docker/docker v20.10.5+incompatible
|
||||||
github.com/docker/go-connections v0.4.0
|
github.com/docker/go-connections v0.4.0
|
||||||
github.com/docker/go-units v0.4.0
|
github.com/docker/go-units v0.4.0
|
||||||
|
github.com/fatih/color v1.9.0 // indirect
|
||||||
github.com/gobwas/httphead v0.0.0-20180130184737-2c6c146eadee // indirect
|
github.com/gobwas/httphead v0.0.0-20180130184737-2c6c146eadee // indirect
|
||||||
github.com/gobwas/pool v0.2.0 // indirect
|
github.com/gobwas/pool v0.2.0 // indirect
|
||||||
github.com/gobwas/ws v1.0.4
|
github.com/gobwas/ws v1.0.4
|
||||||
|
@ -37,40 +39,51 @@ require (
|
||||||
github.com/hashicorp/go-uuid v1.0.2
|
github.com/hashicorp/go-uuid v1.0.2
|
||||||
github.com/iancoleman/strcase v0.1.2
|
github.com/iancoleman/strcase v0.1.2
|
||||||
github.com/joho/godotenv v1.3.0
|
github.com/joho/godotenv v1.3.0
|
||||||
|
github.com/kr/pty v1.1.8 // indirect
|
||||||
github.com/labstack/echo v3.3.10+incompatible
|
github.com/labstack/echo v3.3.10+incompatible
|
||||||
github.com/labstack/gommon v0.3.0 // indirect
|
github.com/labstack/gommon v0.3.0 // indirect
|
||||||
|
github.com/mattn/go-colorable v0.1.6 // indirect
|
||||||
|
github.com/mattn/go-ieproxy v0.0.1 // indirect
|
||||||
github.com/mattn/go-isatty v0.0.12
|
github.com/mattn/go-isatty v0.0.12
|
||||||
github.com/mattn/go-shellwords v1.0.11
|
github.com/mattn/go-shellwords v1.0.11
|
||||||
github.com/moby/buildkit v0.8.1-0.20201205083753-0af7b1b9c693
|
github.com/moby/buildkit v0.8.2-0.20210401015549-df49b648c8bf
|
||||||
github.com/moby/term v0.0.0-20201110203204-bea5bbe245bf
|
github.com/moby/term v0.0.0-20201110203204-bea5bbe245bf
|
||||||
github.com/morikuni/aec v1.0.0
|
github.com/morikuni/aec v1.0.0
|
||||||
github.com/opencontainers/go-digest v1.0.0
|
github.com/opencontainers/go-digest v1.0.0
|
||||||
github.com/opencontainers/image-spec v1.0.1
|
github.com/opencontainers/image-spec v1.0.1
|
||||||
github.com/pkg/errors v0.9.1
|
github.com/pkg/errors v0.9.1
|
||||||
github.com/prometheus/tsdb v0.10.0
|
github.com/prometheus/tsdb v0.10.0
|
||||||
|
github.com/rogpeppe/go-internal v1.5.2 // indirect
|
||||||
github.com/sanathkr/go-yaml v0.0.0-20170819195128-ed9d249f429b
|
github.com/sanathkr/go-yaml v0.0.0-20170819195128-ed9d249f429b
|
||||||
github.com/sirupsen/logrus v1.8.1
|
github.com/sirupsen/logrus v1.8.1
|
||||||
github.com/spf13/cobra v1.1.1
|
github.com/smartystreets/assertions v1.0.0 // indirect
|
||||||
|
github.com/spf13/cobra v1.1.3
|
||||||
|
github.com/spf13/jwalterweatherman v1.1.0 // indirect
|
||||||
github.com/spf13/pflag v1.0.5
|
github.com/spf13/pflag v1.0.5
|
||||||
github.com/stretchr/testify v1.6.1
|
github.com/stretchr/testify v1.7.0
|
||||||
github.com/valyala/fasttemplate v1.2.1 // indirect
|
github.com/valyala/fasttemplate v1.2.1 // indirect
|
||||||
golang.org/x/oauth2 v0.0.0-20201109201403-9fd604954f58
|
golang.org/x/oauth2 v0.0.0-20201109201403-9fd604954f58
|
||||||
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c
|
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c
|
||||||
golang.org/x/sys v0.0.0-20210331175145-43e1dd70ce54
|
golang.org/x/sys v0.0.0-20210331175145-43e1dd70ce54
|
||||||
google.golang.org/grpc v1.33.2
|
google.golang.org/grpc v1.35.0
|
||||||
google.golang.org/protobuf v1.25.0
|
google.golang.org/protobuf v1.25.0
|
||||||
gopkg.in/ini.v1 v1.62.0
|
gopkg.in/ini.v1 v1.62.0
|
||||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c
|
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c
|
||||||
gotest.tools v2.2.0+incompatible
|
gotest.tools v2.2.0+incompatible
|
||||||
gotest.tools/v3 v3.0.3
|
gotest.tools/v3 v3.0.3
|
||||||
helm.sh/helm/v3 v3.5.0
|
helm.sh/helm/v3 v3.5.0
|
||||||
k8s.io/api v0.20.1
|
k8s.io/api v0.20.6
|
||||||
k8s.io/apimachinery v0.20.1
|
k8s.io/apimachinery v0.20.6
|
||||||
k8s.io/cli-runtime v0.20.1
|
k8s.io/cli-runtime v0.20.6
|
||||||
k8s.io/client-go v0.20.1
|
k8s.io/client-go v0.20.6
|
||||||
rsc.io/letsencrypt v0.0.3 // indirect
|
rsc.io/letsencrypt v0.0.3 // indirect
|
||||||
sigs.k8s.io/kustomize/kyaml v0.10.5
|
sigs.k8s.io/kustomize/kyaml v0.10.5
|
||||||
)
|
)
|
||||||
|
|
||||||
// (for buildx)
|
// (for buildx)
|
||||||
replace github.com/jaguilar/vt100 => github.com/tonistiigi/vt100 v0.0.0-20190402012908-ad4c4a574305
|
replace github.com/jaguilar/vt100 => github.com/tonistiigi/vt100 v0.0.0-20190402012908-ad4c4a574305
|
||||||
|
|
||||||
|
// helm uses deislabs/oras which uses containerd 1.4, while buildx relies on containerd 1.5
|
||||||
|
// with incompatible signature changes. This fork adopt oras-project/oras-go which is up-to-date on containerd 1.5
|
||||||
|
// see https://github.com/helm/helm/pull/9675
|
||||||
|
replace helm.sh/helm/v3 => github.com/ndeloof/helm/v3 v3.1.0-rc.1.0.20210507084602-d0ceda767d95
|
||||||
|
|
|
@ -27,9 +27,12 @@ import (
|
||||||
"github.com/docker/buildx/build"
|
"github.com/docker/buildx/build"
|
||||||
"github.com/docker/buildx/driver"
|
"github.com/docker/buildx/driver"
|
||||||
_ "github.com/docker/buildx/driver/docker" // required to get default driver registered
|
_ "github.com/docker/buildx/driver/docker" // required to get default driver registered
|
||||||
|
"github.com/docker/buildx/util/buildflags"
|
||||||
"github.com/docker/buildx/util/progress"
|
"github.com/docker/buildx/util/progress"
|
||||||
moby "github.com/docker/docker/api/types"
|
moby "github.com/docker/docker/api/types"
|
||||||
bclient "github.com/moby/buildkit/client"
|
bclient "github.com/moby/buildkit/client"
|
||||||
|
"github.com/moby/buildkit/session"
|
||||||
|
"github.com/moby/buildkit/session/auth/authprovider"
|
||||||
specs "github.com/opencontainers/image-spec/specs-go/v1"
|
specs "github.com/opencontainers/image-spec/specs-go/v1"
|
||||||
|
|
||||||
"github.com/docker/compose-cli/api/compose"
|
"github.com/docker/compose-cli/api/compose"
|
||||||
|
@ -62,7 +65,7 @@ func (s *composeService) Build(ctx context.Context, project *types.Project, opti
|
||||||
buildOptions.BuildArgs = args
|
buildOptions.BuildArgs = args
|
||||||
buildOptions.NoCache = options.NoCache
|
buildOptions.NoCache = options.NoCache
|
||||||
opts[imageName] = buildOptions
|
opts[imageName] = buildOptions
|
||||||
buildOptions.CacheFrom, err = build.ParseCacheEntry(service.Build.CacheFrom)
|
buildOptions.CacheFrom, err = buildflags.ParseCacheEntry(service.Build.CacheFrom)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -122,6 +125,9 @@ func (s *composeService) ensureImagesExists(ctx context.Context, project *types.
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *composeService) getBuildOptions(project *types.Project, images map[string]string) (map[string]build.Options, []string, error) {
|
func (s *composeService) getBuildOptions(project *types.Project, images map[string]string) (map[string]build.Options, []string, error) {
|
||||||
|
session := []session.Attachable{
|
||||||
|
authprovider.NewDockerAuthProvider(os.Stderr),
|
||||||
|
}
|
||||||
opts := map[string]build.Options{}
|
opts := map[string]build.Options{}
|
||||||
imagesToBuild := []string{}
|
imagesToBuild := []string{}
|
||||||
for _, service := range project.Services {
|
for _, service := range project.Services {
|
||||||
|
@ -156,8 +162,9 @@ func (s *composeService) getBuildOptions(project *types.Project, images map[stri
|
||||||
DockerfilePath: "-",
|
DockerfilePath: "-",
|
||||||
InStream: strings.NewReader("FROM " + service.Image),
|
InStream: strings.NewReader("FROM " + service.Image),
|
||||||
},
|
},
|
||||||
Tags: []string{service.Image}, // Used to retrieve image to pull in case of windows engine
|
Tags: []string{service.Image}, // Used to retrieve image to pull in case of windows engine
|
||||||
Pull: true,
|
Pull: true,
|
||||||
|
Session: session,
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue