Merge pull request #170 from sirlatrom/169-docker-container-driver-envs

Support environment variables in docker-container driver
pull/182/head
Tõnis Tiigi 5 years ago committed by GitHub
commit 714f181d81
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -29,6 +29,7 @@ type Driver struct {
factory driver.Factory factory driver.Factory
netMode string netMode string
image string image string
env []string
} }
func (d *Driver) Bootstrap(ctx context.Context, l progress.Logger) error { func (d *Driver) Bootstrap(ctx context.Context, l progress.Logger) error {
@ -57,6 +58,7 @@ func (d *Driver) create(ctx context.Context, l progress.SubLogger) error {
if d.image != "" { if d.image != "" {
imageName = d.image imageName = d.image
} }
env := d.env
if err := l.Wrap("pulling image "+imageName, func() error { if err := l.Wrap("pulling image "+imageName, func() error {
rc, err := d.DockerAPI.ImageCreate(ctx, imageName, types.ImageCreateOptions{}) rc, err := d.DockerAPI.ImageCreate(ctx, imageName, types.ImageCreateOptions{})
if err != nil { if err != nil {
@ -70,6 +72,7 @@ func (d *Driver) create(ctx context.Context, l progress.SubLogger) error {
cfg := &container.Config{ cfg := &container.Config{
Image: imageName, Image: imageName,
Env: env,
} }
if d.InitConfig.BuildkitFlags != nil { if d.InitConfig.BuildkitFlags != nil {
cfg.Cmd = d.InitConfig.BuildkitFlags cfg.Cmd = d.InitConfig.BuildkitFlags

@ -2,6 +2,8 @@ package docker
import ( import (
"context" "context"
"fmt"
"strings"
"github.com/docker/buildx/driver" "github.com/docker/buildx/driver"
dockerclient "github.com/docker/docker/client" dockerclient "github.com/docker/docker/client"
@ -39,14 +41,20 @@ func (f *factory) New(ctx context.Context, cfg driver.InitConfig) (driver.Driver
} }
d := &Driver{factory: f, InitConfig: cfg} d := &Driver{factory: f, InitConfig: cfg}
for k, v := range cfg.DriverOpts { for k, v := range cfg.DriverOpts {
switch k { switch {
case "network": case k == "network":
d.netMode = v d.netMode = v
if v == "host" { if v == "host" {
d.InitConfig.BuildkitFlags = append(d.InitConfig.BuildkitFlags, "--allow-insecure-entitlement=network.host") d.InitConfig.BuildkitFlags = append(d.InitConfig.BuildkitFlags, "--allow-insecure-entitlement=network.host")
} }
case "image": case k == "image":
d.image = v d.image = v
case strings.HasPrefix(k, "env."):
envName := strings.TrimPrefix(k, "env.")
if envName == "" {
return nil, errors.Errorf("invalid env option %q, expecting env.FOO=bar", k)
}
d.env = append(d.env, fmt.Sprintf("%s=%s", envName, v))
default: default:
return nil, errors.Errorf("invalid driver option %s for docker-container driver", k) return nil, errors.Errorf("invalid driver option %s for docker-container driver", k)
} }

Loading…
Cancel
Save