mirror of https://github.com/docker/cli.git
[20.10] vendor docker 03df974ae9e6c219862907efdd76ec2e77ec930b (v20.10.20)
full diff: c964641a0d...03df974ae9
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
parent
d18a3e9004
commit
a12c535f6e
|
@ -13,7 +13,7 @@ github.com/creack/pty 2a38352e8b4d7ab6c336eef107e4
|
||||||
github.com/davecgh/go-spew 8991bc29aa16c548c550c7ff78260e27b9ab7c73 # v1.1.1
|
github.com/davecgh/go-spew 8991bc29aa16c548c550c7ff78260e27b9ab7c73 # v1.1.1
|
||||||
github.com/docker/compose-on-kubernetes 1f9b5b8cb6aca13deee947511801cf89447c1bfe # v0.5.0
|
github.com/docker/compose-on-kubernetes 1f9b5b8cb6aca13deee947511801cf89447c1bfe # v0.5.0
|
||||||
github.com/docker/distribution b5ca020cfbe998e5af3457fda087444cf5116496 # v2.8.1
|
github.com/docker/distribution b5ca020cfbe998e5af3457fda087444cf5116496 # v2.8.1
|
||||||
github.com/docker/docker c964641a0d76733c071d606c72541b263da84a3e # v20.10.19
|
github.com/docker/docker 03df974ae9e6c219862907efdd76ec2e77ec930b # v20.10.20
|
||||||
github.com/docker/docker-credential-helpers fc9290adbcf1594e78910e2f0334090eaee0e1ee # v0.6.4
|
github.com/docker/docker-credential-helpers fc9290adbcf1594e78910e2f0334090eaee0e1ee # v0.6.4
|
||||||
github.com/docker/go d30aec9fd63c35133f8f79c3412ad91a3b08be06 # Contains a customized version of canonical/json and is used by Notary. The package is periodically rebased on current Go versions.
|
github.com/docker/go d30aec9fd63c35133f8f79c3412ad91a3b08be06 # Contains a customized version of canonical/json and is used by Notary. The package is periodically rebased on current Go versions.
|
||||||
github.com/docker/go-connections 7395e3f8aa162843a74ed6d48e79627d9792ac55 # v0.4.0
|
github.com/docker/go-connections 7395e3f8aa162843a74ed6d48e79627d9792ac55 # v0.4.0
|
||||||
|
|
|
@ -17,21 +17,37 @@ type gitRepo struct {
|
||||||
remote string
|
remote string
|
||||||
ref string
|
ref string
|
||||||
subdir string
|
subdir string
|
||||||
|
|
||||||
|
isolateConfig bool
|
||||||
|
}
|
||||||
|
|
||||||
|
type CloneOption func(*gitRepo)
|
||||||
|
|
||||||
|
// WithIsolatedConfig disables reading the user or system gitconfig files when
|
||||||
|
// performing Git operations.
|
||||||
|
func WithIsolatedConfig(v bool) CloneOption {
|
||||||
|
return func(gr *gitRepo) {
|
||||||
|
gr.isolateConfig = v
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clone clones a repository into a newly created directory which
|
// Clone clones a repository into a newly created directory which
|
||||||
// will be under "docker-build-git"
|
// will be under "docker-build-git"
|
||||||
func Clone(remoteURL string) (string, error) {
|
func Clone(remoteURL string, opts ...CloneOption) (string, error) {
|
||||||
repo, err := parseRemoteURL(remoteURL)
|
repo, err := parseRemoteURL(remoteURL)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
return cloneGitRepo(repo)
|
for _, opt := range opts {
|
||||||
|
opt(&repo)
|
||||||
|
}
|
||||||
|
|
||||||
|
return repo.clone()
|
||||||
}
|
}
|
||||||
|
|
||||||
func cloneGitRepo(repo gitRepo) (checkoutDir string, err error) {
|
func (repo gitRepo) clone() (checkoutDir string, err error) {
|
||||||
fetch := fetchArgs(repo.remote, repo.ref)
|
fetch := fetchArgs(repo.remote, repo.ref)
|
||||||
|
|
||||||
root, err := ioutil.TempDir("", "docker-build-git")
|
root, err := ioutil.TempDir("", "docker-build-git")
|
||||||
|
@ -45,21 +61,21 @@ func cloneGitRepo(repo gitRepo) (checkoutDir string, err error) {
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
if out, err := gitWithinDir(root, "init"); err != nil {
|
if out, err := repo.gitWithinDir(root, "init"); err != nil {
|
||||||
return "", errors.Wrapf(err, "failed to init repo at %s: %s", root, out)
|
return "", errors.Wrapf(err, "failed to init repo at %s: %s", root, out)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add origin remote for compatibility with previous implementation that
|
// Add origin remote for compatibility with previous implementation that
|
||||||
// used "git clone" and also to make sure local refs are created for branches
|
// used "git clone" and also to make sure local refs are created for branches
|
||||||
if out, err := gitWithinDir(root, "remote", "add", "origin", repo.remote); err != nil {
|
if out, err := repo.gitWithinDir(root, "remote", "add", "origin", repo.remote); err != nil {
|
||||||
return "", errors.Wrapf(err, "failed add origin repo at %s: %s", repo.remote, out)
|
return "", errors.Wrapf(err, "failed add origin repo at %s: %s", repo.remote, out)
|
||||||
}
|
}
|
||||||
|
|
||||||
if output, err := gitWithinDir(root, fetch...); err != nil {
|
if output, err := repo.gitWithinDir(root, fetch...); err != nil {
|
||||||
return "", errors.Wrapf(err, "error fetching: %s", output)
|
return "", errors.Wrapf(err, "error fetching: %s", output)
|
||||||
}
|
}
|
||||||
|
|
||||||
checkoutDir, err = checkoutGit(root, repo.ref, repo.subdir)
|
checkoutDir, err = repo.checkout(root)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
|
@ -163,20 +179,20 @@ func supportsShallowClone(remoteURL string) bool {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkoutGit(root, ref, subdir string) (string, error) {
|
func (repo gitRepo) checkout(root string) (string, error) {
|
||||||
// Try checking out by ref name first. This will work on branches and sets
|
// Try checking out by ref name first. This will work on branches and sets
|
||||||
// .git/HEAD to the current branch name
|
// .git/HEAD to the current branch name
|
||||||
if output, err := gitWithinDir(root, "checkout", ref); err != nil {
|
if output, err := repo.gitWithinDir(root, "checkout", repo.ref); err != nil {
|
||||||
// If checking out by branch name fails check out the last fetched ref
|
// If checking out by branch name fails check out the last fetched ref
|
||||||
if _, err2 := gitWithinDir(root, "checkout", "FETCH_HEAD"); err2 != nil {
|
if _, err2 := repo.gitWithinDir(root, "checkout", "FETCH_HEAD"); err2 != nil {
|
||||||
return "", errors.Wrapf(err, "error checking out %s: %s", ref, output)
|
return "", errors.Wrapf(err, "error checking out %s: %s", repo.ref, output)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if subdir != "" {
|
if repo.subdir != "" {
|
||||||
newCtx, err := symlink.FollowSymlinkInScope(filepath.Join(root, subdir), root)
|
newCtx, err := symlink.FollowSymlinkInScope(filepath.Join(root, repo.subdir), root)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", errors.Wrapf(err, "error setting git context, %q not within git root", subdir)
|
return "", errors.Wrapf(err, "error setting git context, %q not within git root", repo.subdir)
|
||||||
}
|
}
|
||||||
|
|
||||||
fi, err := os.Stat(newCtx)
|
fi, err := os.Stat(newCtx)
|
||||||
|
@ -192,13 +208,21 @@ func checkoutGit(root, ref, subdir string) (string, error) {
|
||||||
return root, nil
|
return root, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func gitWithinDir(dir string, args ...string) ([]byte, error) {
|
func (repo gitRepo) gitWithinDir(dir string, args ...string) ([]byte, error) {
|
||||||
a := []string{"--work-tree", dir, "--git-dir", filepath.Join(dir, ".git")}
|
args = append([]string{"-c", "protocol.file.allow=never"}, args...) // Block sneaky repositories from using repos from the filesystem as submodules.
|
||||||
return git(append(a, args...)...)
|
cmd := exec.Command("git", args...)
|
||||||
}
|
cmd.Dir = dir
|
||||||
|
// Disable unsafe remote protocols.
|
||||||
|
cmd.Env = append(cmd.Env, "GIT_PROTOCOL_FROM_USER=0")
|
||||||
|
|
||||||
func git(args ...string) ([]byte, error) {
|
if repo.isolateConfig {
|
||||||
return exec.Command("git", args...).CombinedOutput()
|
cmd.Env = append(cmd.Env,
|
||||||
|
"GIT_CONFIG_NOSYSTEM=1", // Disable reading from system gitconfig.
|
||||||
|
"HOME=/dev/null", // Disable reading from user gitconfig.
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
return cmd.CombinedOutput()
|
||||||
}
|
}
|
||||||
|
|
||||||
// isGitTransport returns true if the provided str is a git transport by inspecting
|
// isGitTransport returns true if the provided str is a git transport by inspecting
|
||||||
|
|
|
@ -33,7 +33,7 @@ github.com/imdario/mergo 1afb36080aec31e0d1528973ebe6
|
||||||
golang.org/x/sync cd5d95a43a6e21273425c7ae415d3df9ea832eeb
|
golang.org/x/sync cd5d95a43a6e21273425c7ae415d3df9ea832eeb
|
||||||
|
|
||||||
# buildkit
|
# buildkit
|
||||||
github.com/moby/buildkit 3a1eeca59a9263613d996ead67d53a4b7d45723d # v0.8.3-29-g3a1eeca5
|
github.com/moby/buildkit c014937225cba29cfb1d5161fd134316c0e9bdaa # v0.8.3-31-gc0149372
|
||||||
github.com/tonistiigi/fsutil 0834f99b7b85462efb69b4f571a4fa3ca7da5ac9
|
github.com/tonistiigi/fsutil 0834f99b7b85462efb69b4f571a4fa3ca7da5ac9
|
||||||
github.com/tonistiigi/units 6950e57a87eaf136bbe44ef2ec8e75b9e3569de2
|
github.com/tonistiigi/units 6950e57a87eaf136bbe44ef2ec8e75b9e3569de2
|
||||||
github.com/grpc-ecosystem/grpc-opentracing 8e809c8a86450a29b90dcc9efbf062d0fe6d9746
|
github.com/grpc-ecosystem/grpc-opentracing 8e809c8a86450a29b90dcc9efbf062d0fe6d9746
|
||||||
|
|
Loading…
Reference in New Issue