bake: use build.IsRemoteURL

Signed-off-by: Justin Chadwell <me@jedevc.com>
pull/1710/head
Justin Chadwell 2 years ago
parent 589d4e4cf5
commit 87a120e8e3

@ -789,7 +789,7 @@ func updateContext(t *build.Inputs, inp *Input) {
if strings.HasPrefix(v.Path, "cwd://") || strings.HasPrefix(v.Path, "target:") || strings.HasPrefix(v.Path, "docker-image:") { if strings.HasPrefix(v.Path, "cwd://") || strings.HasPrefix(v.Path, "target:") || strings.HasPrefix(v.Path, "docker-image:") {
continue continue
} }
if IsRemoteURL(v.Path) { if build.IsRemoteURL(v.Path) {
continue continue
} }
st := llb.Scratch().File(llb.Copy(*inp.State, v.Path, "/"), llb.WithCustomNamef("set context %s to %s", k, v.Path)) st := llb.Scratch().File(llb.Copy(*inp.State, v.Path, "/"), llb.WithCustomNamef("set context %s to %s", k, v.Path))
@ -803,7 +803,7 @@ func updateContext(t *build.Inputs, inp *Input) {
if strings.HasPrefix(t.ContextPath, "cwd://") { if strings.HasPrefix(t.ContextPath, "cwd://") {
return return
} }
if IsRemoteURL(t.ContextPath) { if build.IsRemoteURL(t.ContextPath) {
return return
} }
st := llb.Scratch().File(llb.Copy(*inp.State, t.ContextPath, "/"), llb.WithCustomNamef("set context to %s", t.ContextPath)) st := llb.Scratch().File(llb.Copy(*inp.State, t.ContextPath, "/"), llb.WithCustomNamef("set context to %s", t.ContextPath))
@ -839,7 +839,7 @@ func validateContextsEntitlements(t build.Inputs, inp *Input) error {
} }
func checkPath(p string) error { func checkPath(p string) error {
if IsRemoteURL(p) || strings.HasPrefix(p, "target:") || strings.HasPrefix(p, "docker-image:") { if build.IsRemoteURL(p) || strings.HasPrefix(p, "target:") || strings.HasPrefix(p, "docker-image:") {
return nil return nil
} }
p, err := filepath.EvalSymlinks(p) p, err := filepath.EvalSymlinks(p)
@ -875,7 +875,7 @@ func toBuildOpt(t *Target, inp *Input) (*build.Options, error) {
if t.Context != nil { if t.Context != nil {
contextPath = *t.Context contextPath = *t.Context
} }
if !strings.HasPrefix(contextPath, "cwd://") && !IsRemoteURL(contextPath) { if !strings.HasPrefix(contextPath, "cwd://") && !build.IsRemoteURL(contextPath) {
contextPath = path.Clean(contextPath) contextPath = path.Clean(contextPath)
} }
dockerfilePath := "Dockerfile" dockerfilePath := "Dockerfile"

@ -83,16 +83,6 @@ func ReadRemoteFiles(ctx context.Context, nodes []builder.Node, url string, name
return files, inp, nil return files, inp, nil
} }
func IsRemoteURL(url string) bool {
if _, _, ok := detectHTTPContext(url); ok {
return true
}
if _, ok := detectGitContext(url); ok {
return true
}
return false
}
func detectHTTPContext(url string) (*llb.State, string, bool) { func detectHTTPContext(url string) (*llb.State, string, bool) {
if httpPrefix.MatchString(url) { if httpPrefix.MatchString(url) {
httpContext := llb.HTTP(url, llb.Filename("context"), llb.WithCustomName("[internal] load remote build context")) httpContext := llb.HTTP(url, llb.Filename("context"), llb.WithCustomName("[internal] load remote build context"))

@ -47,11 +47,11 @@ func runBake(dockerCli command.Cli, targets []string, in bakeOptions, cFlags com
cmdContext := "cwd://" cmdContext := "cwd://"
if len(targets) > 0 { if len(targets) > 0 {
if bake.IsRemoteURL(targets[0]) { if build.IsRemoteURL(targets[0]) {
url = targets[0] url = targets[0]
targets = targets[1:] targets = targets[1:]
if len(targets) > 0 { if len(targets) > 0 {
if bake.IsRemoteURL(targets[0]) { if build.IsRemoteURL(targets[0]) {
cmdContext = targets[0] cmdContext = targets[0]
targets = targets[1:] targets = targets[1:]
} }

Loading…
Cancel
Save