From 50d9f3a4f96e6108dfa77ee0024c0204ae00436c Mon Sep 17 00:00:00 2001 From: Carolyn Van Slyck Date: Thu, 15 Aug 2019 07:34:26 -0500 Subject: [PATCH 1/2] Bump cnab-go to pickup fetchOutputs fix --- Gopkg.lock | 6 +++--- Gopkg.toml | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/Gopkg.lock b/Gopkg.lock index 47658faeb..509cc536c 100644 --- a/Gopkg.lock +++ b/Gopkg.lock @@ -242,7 +242,7 @@ version = "v1.1.1" [[projects]] - digest = "1:dc812ff2da93b0847c67cf6e01f1552839531a98b06e77a569bbf3a48dd4e7a5" + digest = "1:7b1d8d5afbf6daf84e751156a59aa93c8413b822383a78b5c639300adada011a" name = "github.com/deislabs/cnab-go" packages = [ "action", @@ -259,8 +259,8 @@ "utils/crud", ] pruneopts = "NT" - revision = "1ef7d96a46de6e4205de8eedd80e3cf387fef72b" - version = "v0.3.1-beta1" + revision = "0ce7659aab8dbd37cc912ea64cb78f403534de42" + version = "v0.3.2-beta1" [[projects]] digest = "1:7a6852b35eb5bbc184561443762d225116ae630c26a7c4d90546619f1e7d2ad2" diff --git a/Gopkg.toml b/Gopkg.toml index 7adeefb7a..4e52eaf8a 100644 --- a/Gopkg.toml +++ b/Gopkg.toml @@ -1,11 +1,11 @@ [[constraint]] name = "github.com/deislabs/cnab-go" - version = "v0.3.1-beta1" + version = "v0.3.2-beta1" # override currently needed or else cnab-to-oci dep causes issues [[override]] name = "github.com/deislabs/cnab-go" - version = "v0.3.1-beta1" + version = "v0.3.2-beta1" # Using master until there is a release of cnab-to-oci [[constraint]] From 12e60254c7fde893645faa4b2afbc2fe9d22c7fc Mon Sep 17 00:00:00 2001 From: Carolyn Van Slyck Date: Thu, 15 Aug 2019 07:34:34 -0500 Subject: [PATCH 2/2] Sync vendor --- .../deislabs/cnab-go/action/action.go | 5 ----- .../deislabs/cnab-go/bundle/bundle.go | 5 ----- .../github.com/deislabs/cnab-go/claim/claim.go | 13 ++++++------- .../cnab-go/credentials/credentialset.go | 14 +++++++------- .../deislabs/cnab-go/driver/docker/docker.go | 18 ++++++++++++------ 5 files changed, 25 insertions(+), 30 deletions(-) diff --git a/vendor/github.com/deislabs/cnab-go/action/action.go b/vendor/github.com/deislabs/cnab-go/action/action.go index 25da3f347..04b823e41 100644 --- a/vendor/github.com/deislabs/cnab-go/action/action.go +++ b/vendor/github.com/deislabs/cnab-go/action/action.go @@ -161,11 +161,6 @@ func selectInvocationImage(d driver.Driver, c *claim.Claim) (bundle.InvocationIm for _, ii := range c.Bundle.InvocationImages { if d.Handles(ii.ImageType) { - if c.RelocationMap != nil { - if img, ok := c.RelocationMap[ii.Image]; ok { - ii.Image = img - } - } return ii, nil } } diff --git a/vendor/github.com/deislabs/cnab-go/bundle/bundle.go b/vendor/github.com/deislabs/cnab-go/bundle/bundle.go index efcf7bbca..3c344992d 100644 --- a/vendor/github.com/deislabs/cnab-go/bundle/bundle.go +++ b/vendor/github.com/deislabs/cnab-go/bundle/bundle.go @@ -98,11 +98,6 @@ type InvocationImage struct { BaseImage `yaml:",inline"` } -// ImageRelocationMap stores the relocated images -// The key is the Image in bundle.json and the value is the new Image -// from the relocated registry -type ImageRelocationMap map[string]string - // Location provides the location where a value should be written in // the invocation image. // diff --git a/vendor/github.com/deislabs/cnab-go/claim/claim.go b/vendor/github.com/deislabs/cnab-go/claim/claim.go index 57fc709dc..1355c5122 100644 --- a/vendor/github.com/deislabs/cnab-go/claim/claim.go +++ b/vendor/github.com/deislabs/cnab-go/claim/claim.go @@ -40,11 +40,11 @@ type Claim struct { Created time.Time `json:"created"` Modified time.Time `json:"modified"` Bundle *bundle.Bundle `json:"bundle"` - Result Result `json:"result"` - Parameters map[string]interface{} `json:"parameters"` + Result Result `json:"result,omitempty"` + Parameters map[string]interface{} `json:"parameters,omitempty"` // Outputs is a map from the names of outputs (defined in the bundle) to the contents of the files. - Outputs map[string]interface{} `json:"outputs"` - RelocationMap bundle.ImageRelocationMap `json:"relocationMap"` + Outputs map[string]interface{} `json:"outputs,omitempty"` + Custom interface{} `json:"custom,omitempty"` } // ValidName is a regular expression that indicates whether a name is a valid claim name. @@ -67,9 +67,8 @@ func New(name string) (*Claim, error) { Action: ActionUnknown, Status: StatusUnknown, }, - Parameters: map[string]interface{}{}, - Outputs: map[string]interface{}{}, - RelocationMap: bundle.ImageRelocationMap{}, + Parameters: map[string]interface{}{}, + Outputs: map[string]interface{}{}, }, nil } diff --git a/vendor/github.com/deislabs/cnab-go/credentials/credentialset.go b/vendor/github.com/deislabs/cnab-go/credentials/credentialset.go index e6ae6e0c1..ed4db8bd4 100644 --- a/vendor/github.com/deislabs/cnab-go/credentials/credentialset.go +++ b/vendor/github.com/deislabs/cnab-go/credentials/credentialset.go @@ -25,7 +25,7 @@ func (s Set) Expand(b *bundle.Bundle, stateless bool) (env, files map[string]str for name, val := range b.Credentials { src, ok := s[name] if !ok { - if stateless { + if stateless || !val.Required { continue } err = fmt.Errorf("credential %q is missing from the user-supplied credentials", name) @@ -77,15 +77,15 @@ func Load(path string) (*CredentialSet, error) { // Validate compares the given credentials with the spec. // -// This will result in an error only if: -// - a parameter in the spec is not present in the given set -// - a parameter in the given set does not match the format required by the spec +// This will result in an error only when the following conditions are true: +// - a credential in the spec is not present in the given set +// - the credential is required // // It is allowed for spec to specify both an env var and a file. In such case, if -// the givn set provides either, it will be considered valid. +// the given set provides either, it will be considered valid. func Validate(given Set, spec map[string]bundle.Credential) error { - for name := range spec { - if !isValidCred(given, name) { + for name, cred := range spec { + if !isValidCred(given, name) && cred.Required { return fmt.Errorf("bundle requires credential for %s", name) } } diff --git a/vendor/github.com/deislabs/cnab-go/driver/docker/docker.go b/vendor/github.com/deislabs/cnab-go/driver/docker/docker.go index 134d75eab..181c9851d 100644 --- a/vendor/github.com/deislabs/cnab-go/driver/docker/docker.go +++ b/vendor/github.com/deislabs/cnab-go/driver/docker/docker.go @@ -227,21 +227,21 @@ func (d *Driver) exec(op *driver.Operation) (driver.OperationResult, error) { select { case err := <-errc: if err != nil { - opResult, fetchErr := d.fetchOutputs(ctx, resp.ID) + opResult, fetchErr := d.fetchOutputs(ctx, resp.ID, op) return opResult, containerError("error in container", err, fetchErr) } case s := <-statusc: if s.StatusCode == 0 { - return d.fetchOutputs(ctx, resp.ID) + return d.fetchOutputs(ctx, resp.ID, op) } if s.Error != nil { - opResult, fetchErr := d.fetchOutputs(ctx, resp.ID) + opResult, fetchErr := d.fetchOutputs(ctx, resp.ID, op) return opResult, containerError(fmt.Sprintf("container exit code: %d, message", s.StatusCode), err, fetchErr) } - opResult, fetchErr := d.fetchOutputs(ctx, resp.ID) + opResult, fetchErr := d.fetchOutputs(ctx, resp.ID, op) return opResult, containerError(fmt.Sprintf("container exit code: %d, message", s.StatusCode), err, fetchErr) } - opResult, fetchErr := d.fetchOutputs(ctx, resp.ID) + opResult, fetchErr := d.fetchOutputs(ctx, resp.ID, op) if fetchErr != nil { return opResult, fmt.Errorf("fetching outputs failed: %s", fetchErr) } @@ -259,10 +259,16 @@ func containerError(containerMessage string, containerErr, fetchErr error) error // fetchOutputs takes a context and a container ID; it copies the /cnab/app/outputs directory from that container. // The goal is to collect all the files in the directory (recursively) and put them in a flat map of path to contents. // This map will be inside the OperationResult. When fetchOutputs returns an error, it may also return partial results. -func (d *Driver) fetchOutputs(ctx context.Context, container string) (driver.OperationResult, error) { +func (d *Driver) fetchOutputs(ctx context.Context, container string, op *driver.Operation) (driver.OperationResult, error) { opResult := driver.OperationResult{ Outputs: map[string]string{}, } + // The /cnab/app/outputs directory probably only exists if outputs are created. In the + // case there are no outputs defined on the operation, there probably are none to copy + // and we should return early. + if len(op.Outputs) == 0 { + return opResult, nil + } ioReader, _, err := d.dockerCli.Client().CopyFromContainer(ctx, container, "/cnab/app/outputs") if err != nil { return opResult, fmt.Errorf("error copying outputs from container: %s", err)