From 66d23eecfeae8a67698fbe5eb1dbaa8d6cf9bce0 Mon Sep 17 00:00:00 2001 From: Catalin Stratulat Date: Tue, 23 Jul 2024 11:25:53 +0100 Subject: [PATCH 1/4] preserve latest render status in kptfile & packageRevisionResources --- pkg/engine/engine.go | 38 +++++++++++++++++++++++++++++++++ pkg/git/package.go | 11 ++++++++++ pkg/kpt/api/kptfile/v1/types.go | 2 ++ 3 files changed, 51 insertions(+) diff --git a/pkg/engine/engine.go b/pkg/engine/engine.go index b1898949..aff0ee64 100644 --- a/pkg/engine/engine.go +++ b/pkg/engine/engine.go @@ -1035,6 +1035,44 @@ func (cad *cadEngine) UpdatePackageResources(ctx context.Context, repositoryObj runtime: cad.runtime, }}) + var kptFileContents kptfile.KptFile + unmarshErr := yaml.Unmarshal([]byte(appliedResources.Contents["Kptfile"]), &kptFileContents) + if unmarshErr != nil { + klog.Errorf("Error in Umarshaling Kptfile: %v", unmarshErr) + } + + kptFileContents.Status = &kptfile.Status{ + RenderStatus: &api.RenderStatus{ + Result: api.ResultList{ + TypeMeta: renderStatus.Result.TypeMeta, + // ignore object meta (not relevant) + ExitCode: renderStatus.Result.ExitCode, + Items: renderStatus.Result.Items, + }, + Err: renderStatus.Err, + }, + } + + byteKptfile, marshErr := yaml.Marshal(&kptFileContents) + if marshErr != nil { + klog.Errorf("Error in Marshaling Kptfile: %v", marshErr) + } + postRenderPkgRev := new + + postRenderPkgRev.Spec.Resources["Kptfile"] = string(byteKptfile) + postRenderPkgRev.Status.RenderStatus = *renderStatus + + mutations = []mutation{ + &mutationReplaceResources{ + newResources: postRenderPkgRev, + oldResources: new, + }, + } + _, _, err = applyResourceMutations(ctx, draft, appliedResources, mutations) + if err != nil { + return nil, nil, err + } + // No lifecycle change when updating package resources; updates are done. repoPkgRev, err := draft.Close(ctx) if err != nil { diff --git a/pkg/git/package.go b/pkg/git/package.go index b23c05f0..b4cf0387 100644 --- a/pkg/git/package.go +++ b/pkg/git/package.go @@ -193,6 +193,14 @@ func (p *gitPackageRevision) GetResources(ctx context.Context) (*v1alpha1.Packag key := p.Key() + kf, err := p.GetKptfile(ctx) + if err != nil { + klog.Errorf("error: %v", err) + } + var dummyrenderstatus v1alpha1.RenderStatus + if kf.Status != nil { + dummyrenderstatus = *kf.Status.RenderStatus + } return &v1alpha1.PackageRevisionResources{ TypeMeta: metav1.TypeMeta{ Kind: "PackageRevisionResources", @@ -216,6 +224,9 @@ func (p *gitPackageRevision) GetResources(ctx context.Context) (*v1alpha1.Packag Resources: resources, }, + Status: v1alpha1.PackageRevisionResourcesStatus{ + RenderStatus: dummyrenderstatus, + }, }, nil } diff --git a/pkg/kpt/api/kptfile/v1/types.go b/pkg/kpt/api/kptfile/v1/types.go index b8d885ee..726ea4b2 100644 --- a/pkg/kpt/api/kptfile/v1/types.go +++ b/pkg/kpt/api/kptfile/v1/types.go @@ -20,6 +20,7 @@ package v1 import ( "fmt" + api "github.com/nephio-project/porch/api/porch/v1alpha1" "k8s.io/apimachinery/pkg/runtime/schema" "sigs.k8s.io/kustomize/kyaml/yaml" ) @@ -379,6 +380,7 @@ func (i Inventory) IsValid() bool { type Status struct { Conditions []Condition `yaml:"conditions,omitempty" json:"conditions,omitempty"` + RenderStatus *api.RenderStatus `json:"renderStatus,omitempty"` } type Condition struct { From b6567744f474cb71b1a7799e0d0fd3f411dcdf90 Mon Sep 17 00:00:00 2001 From: Catalin Stratulat Date: Fri, 23 Aug 2024 14:05:28 +0100 Subject: [PATCH 2/4] changing to using PorchFile instead of storing meta in Kptfile --- api/porch/v1alpha1/types.go | 8 ++++++++ internal/kpt/pkg/pkg.go | 19 ++++++++++++++++++ pkg/engine/engine.go | 35 ++++++++++++++++++++++----------- pkg/git/package.go | 26 +++++++++++++++++++----- pkg/kpt/api/kptfile/v1/types.go | 2 -- 5 files changed, 71 insertions(+), 19 deletions(-) diff --git a/api/porch/v1alpha1/types.go b/api/porch/v1alpha1/types.go index f3c4375f..bf31db39 100644 --- a/api/porch/v1alpha1/types.go +++ b/api/porch/v1alpha1/types.go @@ -39,6 +39,14 @@ const ( LatestPackageRevisionValue = "true" ) +// Porchfile +type PorchFile struct { + metav1.TypeMeta `yaml:",inline"` + metav1.ObjectMeta `yaml:"metadata,omitempty"` + + Status *RenderStatus `yaml:"status,omitempty"` +} + // PackageRevisionList // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object type PackageRevisionList struct { diff --git a/internal/kpt/pkg/pkg.go b/internal/kpt/pkg/pkg.go index f14c062b..efbbdff3 100644 --- a/internal/kpt/pkg/pkg.go +++ b/internal/kpt/pkg/pkg.go @@ -24,6 +24,7 @@ import ( "sort" rgfilev1alpha1 "github.com/GoogleContainerTools/kpt/pkg/api/resourcegroup/v1alpha1" + "github.com/nephio-project/porch/api/porch/v1alpha1" "github.com/nephio-project/porch/internal/kpt/errors" "github.com/nephio-project/porch/internal/kpt/types" "github.com/nephio-project/porch/internal/kpt/util/git" @@ -266,6 +267,24 @@ func DecodeKptfile(in io.Reader) (*kptfilev1.KptFile, error) { return kf, nil } +func DecodePorchfile(in io.Reader) (*v1alpha1.PorchFile, error) { + pf := &v1alpha1.PorchFile{} + c, err := io.ReadAll(in) + if err != nil { + return pf, err + } + // if err := CheckKptfileVersion(c); err != nil { + // return kf, err + // } + + d := yaml.NewDecoder(bytes.NewBuffer(c)) + d.KnownFields(true) + if err := d.Decode(pf); err != nil { + return pf, err + } + return pf, nil +} + // CheckKptfileVersion verifies the apiVersion and kind of the resource // within the Kptfile. If the legacy version is found, the DeprecatedKptfileError // is returned. If the currently supported apiVersion and kind is found, no diff --git a/pkg/engine/engine.go b/pkg/engine/engine.go index aff0ee64..5c823b7b 100644 --- a/pkg/engine/engine.go +++ b/pkg/engine/engine.go @@ -39,6 +39,7 @@ import ( "go.opentelemetry.io/otel/trace" corev1 "k8s.io/api/core/v1" apierrors "k8s.io/apimachinery/pkg/api/errors" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "k8s.io/apimachinery/pkg/runtime" "k8s.io/apimachinery/pkg/runtime/schema" @@ -1035,14 +1036,18 @@ func (cad *cadEngine) UpdatePackageResources(ctx context.Context, repositoryObj runtime: cad.runtime, }}) - var kptFileContents kptfile.KptFile - unmarshErr := yaml.Unmarshal([]byte(appliedResources.Contents["Kptfile"]), &kptFileContents) - if unmarshErr != nil { - klog.Errorf("Error in Umarshaling Kptfile: %v", unmarshErr) - } - - kptFileContents.Status = &kptfile.Status{ - RenderStatus: &api.RenderStatus{ + porchFileContents := api.PorchFile{ + TypeMeta: metav1.TypeMeta{ + APIVersion: "v1alpha1", + Kind: "PorchFile", + }, + ObjectMeta: metav1.ObjectMeta{ + Name: "Porch-Metadata", + Annotations: map[string]string{ + "config.kubernetes.io/local-config": "true", + }, + }, + Status: &api.RenderStatus{ Result: api.ResultList{ TypeMeta: renderStatus.Result.TypeMeta, // ignore object meta (not relevant) @@ -1053,14 +1058,20 @@ func (cad *cadEngine) UpdatePackageResources(ctx context.Context, repositoryObj }, } - byteKptfile, marshErr := yaml.Marshal(&kptFileContents) + if value, ok := appliedResources.Contents["PorchFile"]; ok { + unmarshErr := yaml.Unmarshal([]byte(value), &porchFileContents) + if unmarshErr != nil { + klog.Errorf("Error in Umarshaling PorchFile: %v", unmarshErr) + } + } + + bytePorchfile, marshErr := yaml.Marshal(&porchFileContents) if marshErr != nil { - klog.Errorf("Error in Marshaling Kptfile: %v", marshErr) + klog.Errorf("Error in Marshaling PorchFile: %v", marshErr) } postRenderPkgRev := new - postRenderPkgRev.Spec.Resources["Kptfile"] = string(byteKptfile) - postRenderPkgRev.Status.RenderStatus = *renderStatus + postRenderPkgRev.Spec.Resources["PorchFile"] = string(bytePorchfile) mutations = []mutation{ &mutationReplaceResources{ diff --git a/pkg/git/package.go b/pkg/git/package.go index b4cf0387..ffb32567 100644 --- a/pkg/git/package.go +++ b/pkg/git/package.go @@ -193,13 +193,13 @@ func (p *gitPackageRevision) GetResources(ctx context.Context) (*v1alpha1.Packag key := p.Key() - kf, err := p.GetKptfile(ctx) + pf, err := p.GetPorchfile(ctx) if err != nil { klog.Errorf("error: %v", err) } - var dummyrenderstatus v1alpha1.RenderStatus - if kf.Status != nil { - dummyrenderstatus = *kf.Status.RenderStatus + var rs v1alpha1.RenderStatus + if pf.Status != nil { + rs = *pf.Status } return &v1alpha1.PackageRevisionResources{ TypeMeta: metav1.TypeMeta{ @@ -225,7 +225,7 @@ func (p *gitPackageRevision) GetResources(ctx context.Context) (*v1alpha1.Packag Resources: resources, }, Status: v1alpha1.PackageRevisionResourcesStatus{ - RenderStatus: dummyrenderstatus, + RenderStatus: rs, }, }, nil } @@ -246,6 +246,22 @@ func (p *gitPackageRevision) GetKptfile(ctx context.Context) (kptfile.KptFile, e return *kf, nil } +func (p *gitPackageRevision) GetPorchfile(ctx context.Context) (v1alpha1.PorchFile, error) { + resources, err := p.repo.GetResources(p.tree) + if err != nil { + return v1alpha1.PorchFile{}, fmt.Errorf("error loading package resources: %w", err) + } + pfString, found := resources["PorchFile"] + if !found { + return v1alpha1.PorchFile{}, nil + } + pf, err := pkg.DecodePorchfile(strings.NewReader(pfString)) + if err != nil { + return v1alpha1.PorchFile{}, fmt.Errorf("error decoding PorchFile: %w", err) + } + return *pf, nil +} + // GetUpstreamLock returns the upstreamLock info present in the Kptfile of the package. func (p *gitPackageRevision) GetUpstreamLock(ctx context.Context) (kptfile.Upstream, kptfile.UpstreamLock, error) { kf, err := p.GetKptfile(ctx) diff --git a/pkg/kpt/api/kptfile/v1/types.go b/pkg/kpt/api/kptfile/v1/types.go index 726ea4b2..b8d885ee 100644 --- a/pkg/kpt/api/kptfile/v1/types.go +++ b/pkg/kpt/api/kptfile/v1/types.go @@ -20,7 +20,6 @@ package v1 import ( "fmt" - api "github.com/nephio-project/porch/api/porch/v1alpha1" "k8s.io/apimachinery/pkg/runtime/schema" "sigs.k8s.io/kustomize/kyaml/yaml" ) @@ -380,7 +379,6 @@ func (i Inventory) IsValid() bool { type Status struct { Conditions []Condition `yaml:"conditions,omitempty" json:"conditions,omitempty"` - RenderStatus *api.RenderStatus `json:"renderStatus,omitempty"` } type Condition struct { From f09f06f322f70b000e5b291f77111af27b3faee1 Mon Sep 17 00:00:00 2001 From: Catalin Stratulat Date: Fri, 23 Aug 2024 15:49:33 +0100 Subject: [PATCH 3/4] added replace for api. NEEDS ALTERNATIVE solution --- go.mod | 2 ++ 1 file changed, 2 insertions(+) diff --git a/go.mod b/go.mod index cdae39dd..4a73f670 100644 --- a/go.mod +++ b/go.mod @@ -2,6 +2,8 @@ module github.com/nephio-project/porch go 1.22 +replace github.com/nephio-project/porch/api => ./api + require ( cloud.google.com/go/iam v1.1.1 github.com/GoogleContainerTools/kpt v1.0.0-beta.48 From 7c9ecaed740e268bf958829157e5fbd2c8534791 Mon Sep 17 00:00:00 2001 From: Catalin Stratulat Date: Tue, 27 Aug 2024 14:05:39 +0100 Subject: [PATCH 4/4] modified go.mod with go mod tidy to update it to main --- go.mod | 10 +++++----- go.sum | 39 ++++++++++++++++++--------------------- 2 files changed, 23 insertions(+), 26 deletions(-) diff --git a/go.mod b/go.mod index 3b056205..2f7d2cef 100644 --- a/go.mod +++ b/go.mod @@ -95,7 +95,7 @@ require ( github.com/docker/distribution v2.8.2+incompatible // indirect github.com/docker/docker-credential-helpers v0.7.0 // indirect github.com/dustmop/soup v1.1.2-0.20190516214245-38228baa104e // indirect - github.com/emicklei/go-restful/v3 v3.11.0 // indirect + github.com/emicklei/go-restful/v3 v3.12.1 // indirect github.com/emirpasic/gods v1.18.1 // indirect github.com/evanphx/json-patch v4.12.0+incompatible // indirect github.com/evanphx/json-patch/v5 v5.9.0 // indirect @@ -105,9 +105,9 @@ require ( github.com/go-git/gcfg v1.5.1-0.20230307220236-3a3c6141e376 // indirect github.com/go-logr/logr v1.4.2 // indirect github.com/go-logr/stdr v1.2.2 // indirect - github.com/go-openapi/jsonpointer v0.19.6 // indirect - github.com/go-openapi/jsonreference v0.20.2 // indirect - github.com/go-openapi/swag v0.22.3 // indirect + github.com/go-openapi/jsonpointer v0.21.0 // indirect + github.com/go-openapi/jsonreference v0.21.0 // indirect + github.com/go-openapi/swag v0.23.0 // indirect github.com/gogo/protobuf v1.3.2 // indirect github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect github.com/google/btree v1.1.2 // indirect @@ -188,7 +188,7 @@ require ( gopkg.in/warnings.v0 v0.1.2 // indirect k8s.io/apiextensions-apiserver v0.30.1 // indirect k8s.io/kms v0.30.3 // indirect - k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 // indirect + k8s.io/kube-openapi v0.0.0-20240731051651-4f2adb0a5ce0 // indirect sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.29.0 // indirect sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect sigs.k8s.io/structured-merge-diff/v4 v4.4.1 // indirect diff --git a/go.sum b/go.sum index a6e52f8c..7883585e 100644 --- a/go.sum +++ b/go.sum @@ -98,7 +98,6 @@ github.com/cpuguy83/go-md2man/v2 v2.0.0/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsr github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= github.com/cpuguy83/go-md2man/v2 v2.0.4 h1:wfIWP927BUkWJb2NmU/kNDYIBTh/ziUX91+lVfRxZq4= github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= -github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= github.com/creack/pty v1.1.18 h1:n56/Zwd5o6whRC5PMGretI4IdRLlmBXYNjScPaBgsbY= github.com/creack/pty v1.1.18/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4= github.com/cyphar/filepath-securejoin v0.2.4 h1:Ugdm7cg7i6ZK6x3xDF1oEu1nfkyfH53EtKeQYTC3kyg= @@ -122,8 +121,8 @@ github.com/dustmop/soup v1.1.2-0.20190516214245-38228baa104e/go.mod h1:CgNC6SGbT github.com/elazarl/goproxy v0.0.0-20230808193330-2592e75ae04a h1:mATvB/9r/3gvcejNsXKSkQ6lcIaNec2nyfOdlTBR2lU= github.com/elazarl/goproxy v0.0.0-20230808193330-2592e75ae04a/go.mod h1:Ro8st/ElPeALwNFlcTpWmkr6IoMFfkjXAvTHpevnDsM= github.com/emicklei/go-restful v0.0.0-20170410110728-ff4f55a20633/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= -github.com/emicklei/go-restful/v3 v3.11.0 h1:rAQeMHw1c7zTmncogyy8VvRZwtkmkZ4FxERmMY4rD+g= -github.com/emicklei/go-restful/v3 v3.11.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= +github.com/emicklei/go-restful/v3 v3.12.1 h1:PJMDIM/ak7btuL8Ex0iYET9hxM3CI2sjZtzpL63nKAU= +github.com/emicklei/go-restful/v3 v3.12.1/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= github.com/emirpasic/gods v1.18.1 h1:FXtiHYKDGKCW2KzwZKx0iC0PQmdlorYgdFG9jPXJ1Bc= github.com/emirpasic/gods v1.18.1/go.mod h1:8tpGGwCnJ5H4r6BWwaV6OrWmMoPhUl5jm/FMNAnJvWQ= github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= @@ -169,17 +168,18 @@ github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre github.com/go-logr/zapr v1.3.0 h1:XGdV8XW8zdwFiwOA2Dryh1gj2KRQyOOoNmBy4EplIcQ= github.com/go-logr/zapr v1.3.0/go.mod h1:YKepepNBd1u/oyhd/yQmtjVXmm9uML4IXUgMOwR8/Gg= github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= -github.com/go-openapi/jsonpointer v0.19.6 h1:eCs3fxoIi3Wh6vtgmLTOjdhSpiqphQ+DaPn38N2ZdrE= -github.com/go-openapi/jsonpointer v0.19.6/go.mod h1:osyAmYz/mB/C3I+WsTTSgw1ONzaLJoLCyoi6/zppojs= +github.com/go-openapi/jsonpointer v0.21.0 h1:YgdVicSA9vH5RiHs9TZW5oyafXZFc6+2Vc1rr/O9oNQ= +github.com/go-openapi/jsonpointer v0.21.0/go.mod h1:IUyH9l/+uyhIYQ/PXVA41Rexl+kOkAPDdXEYns6fzUY= github.com/go-openapi/jsonreference v0.19.3/go.mod h1:rjx6GuL8TTa9VaixXglHmQmIL98+wF9xc8zWvFonSJ8= -github.com/go-openapi/jsonreference v0.20.2 h1:3sVjiK66+uXK/6oQ8xgcRKcFgQ5KXa2KvnJRumpMGbE= -github.com/go-openapi/jsonreference v0.20.2/go.mod h1:Bl1zwGIM8/wsvqjsOQLJ/SH+En5Ap4rVB5KVcIDZG2k= +github.com/go-openapi/jsonreference v0.21.0 h1:Rs+Y7hSXT83Jacb7kFyjn4ijOuVGSvOdF2+tg1TRrwQ= +github.com/go-openapi/jsonreference v0.21.0/go.mod h1:LmZmgsrTkVg9LG4EaHeY8cBDslNPMo06cago5JNLkm4= github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= -github.com/go-openapi/swag v0.22.3 h1:yMBqmnQ0gyZvEb/+KzuWZOXgllrXT4SADYbvDaXHv/g= -github.com/go-openapi/swag v0.22.3/go.mod h1:UzaqsxGiab7freDnrUUra0MwWfN/q7tE4j+VcZ0yl14= +github.com/go-openapi/swag v0.23.0 h1:vsEVJDUo2hPJ2tu0/Xc+4noaxyEffXNIs3cOULZ+GrE= +github.com/go-openapi/swag v0.23.0/go.mod h1:esZ8ITTYEsH1V2trKHjAN8Ai7xHb8RV+YSZ577vPjgQ= github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 h1:tfuBGBXKqDEevZMzYi5KSi8KkcZtzBcTgAUUtapy0OI= -github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572/go.mod h1:9Pwr4B2jHnOSGXyyzV8ROjYa2ojvAY6HCGYYfMoC3Ls= +github.com/go-task/slim-sprig/v3 v3.0.0 h1:sUs3vkvUymDpBKi3qH1YSqBQk9+9D/8M2mN1vB6EwHI= +github.com/go-task/slim-sprig/v3 v3.0.0/go.mod h1:W848ghGpv3Qj3dhTPRyJypKRiqCdHZiAzKg9hl15HA8= github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ= github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4= @@ -229,8 +229,8 @@ github.com/google/go-containerregistry v0.20.2/go.mod h1:z38EKdKh4h7IP2gSfUUqEva github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0= github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= -github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1 h1:K6RDEckDVWvDI9JAJYCmNdQXq6neHJOYx3V6jnqNEec= -github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20240424215950-a892ee059fd6 h1:k7nVchz72niMH6YLQNvHSdIE7iqsQxK1P41mySCvssg= +github.com/google/pprof v0.0.0-20240424215950-a892ee059fd6/go.mod h1:kf6iHlnVGwgKolg33glAes7Yg/8iWP8ukqeldJSO7jw= github.com/google/s2a-go v0.1.8 h1:zZDs9gcbt9ZPLV0ndSyQk6Kacx2g/X+SKYovpnz3SMM= github.com/google/s2a-go v0.1.8/go.mod h1:6iNWHTpQ+nfNRN5E00MSdfDwVesa8hhS32PhPO8deJA= github.com/google/shlex v0.0.0-20191202100458-e7afc7fbc510 h1:El6M4kTTCOh6aBiKaUGG7oYTSPP8MxqL4YI3kZKwcP4= @@ -291,7 +291,6 @@ github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxv github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc= github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= -github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= @@ -334,17 +333,15 @@ github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8m github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f h1:y5//uYreIhSUg3J1GEMiLbxo1LJaP8RfCpH6pymGZus= github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f/go.mod h1:ZdcZmHo+o7JKHSa8/e818NopupXU1YMK5fe1lsApnBw= -github.com/nephio-project/porch/api v0.0.0-20240722132258-c4b36b7a5fb1 h1:/eKsBYxcv7VJBGxzezee34JuX5P0dhcxYCumiY5IL04= -github.com/nephio-project/porch/api v0.0.0-20240722132258-c4b36b7a5fb1/go.mod h1:qHyDwqL9NeZwbkZkqaZGjJ12OjEId57Fbwhwbf+ufdE= github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U= github.com/onsi/ginkgo v0.0.0-20170829012221-11459a886d9c h1:Hww8mOyEKTeON4bZn7FrlLismspbPc1teNRUVH7wLQ8= github.com/onsi/ginkgo v0.0.0-20170829012221-11459a886d9c/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= -github.com/onsi/ginkgo/v2 v2.17.1 h1:V++EzdbhI4ZV4ev0UTIj0PzhzOcReJFyJaLjtSF55M8= -github.com/onsi/ginkgo/v2 v2.17.1/go.mod h1:llBI3WDLL9Z6taip6f33H76YcWtJv+7R3HigUjbIBOs= +github.com/onsi/ginkgo/v2 v2.19.0 h1:9Cnnf7UHo57Hy3k6/m5k3dRfGTMXGvxhHFvkDTCTpvA= +github.com/onsi/ginkgo/v2 v2.19.0/go.mod h1:rlwLi9PilAFJ8jCg9UE1QP6VBpd6/xj3SRC0d6TU0To= github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= -github.com/onsi/gomega v1.32.0 h1:JRYU78fJ1LPxlckP6Txi/EYqJvjtMrDC04/MM5XRHPk= -github.com/onsi/gomega v1.32.0/go.mod h1:a4x4gW6Pz2yK1MAmvluYme5lvYTn61afQ2ETw/8n4Lg= +github.com/onsi/gomega v1.33.1 h1:dsYjIxxSR755MDmKVsaFQTE22ChNBcuuTWgkUDSubOk= +github.com/onsi/gomega v1.33.1/go.mod h1:U4R44UsT+9eLIaYRB2a5qajjtQYn0hauxvRm16AVYg0= github.com/opencontainers/go-digest v1.0.0 h1:apOUWs51W5PlhuyGyz9FCeeBIOUDA/6nW8Oi/yOhh5U= github.com/opencontainers/go-digest v1.0.0/go.mod h1:0JzlMkj0TRzQZfJkVvzbP0HBR3IKzErnv2BNG4W4MAM= github.com/opencontainers/image-spec v1.1.0-rc3 h1:fzg1mXZFj8YdPeNkRXMg+zb88BFV0Ys52cJydRwBkb8= @@ -726,8 +723,8 @@ k8s.io/kms v0.30.3/go.mod h1:GrMurD0qk3G4yNgGcsCEmepqf9KyyIrTXYR2lyUOJC4= k8s.io/kube-aggregator v0.30.3 h1:hy5zfQ7p6BuJgc/XtGp3GBh2MPfOj6b1n3raKKMHOQE= k8s.io/kube-aggregator v0.30.3/go.mod h1:2SP0IckvQoOwwZN8lmtWUnTZTgIpwOWvidWtxyqLwuk= k8s.io/kube-openapi v0.0.0-20210421082810-95288971da7e/go.mod h1:vHXdDvt9+2spS2Rx9ql3I8tycm3H9FDfdUoIuKCefvw= -k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 h1:BZqlfIlq5YbRMFko6/PM7FjZpUb45WallggurYhKGag= -k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340/go.mod h1:yD4MZYeKMBwQKVht279WycxKyM84kkAx2DPrTXaeb98= +k8s.io/kube-openapi v0.0.0-20240731051651-4f2adb0a5ce0 h1:AhBLFxqbax8I0LjZFbO9VoYx7hIn3/vCCRNyK825wYM= +k8s.io/kube-openapi v0.0.0-20240731051651-4f2adb0a5ce0/go.mod h1:0CVn9SVo8PeW5/JgsBZZIFmmTk5noOM8WXf2e1tCihE= k8s.io/kubectl v0.30.3 h1:YIBBvMdTW0xcDpmrOBzcpUVsn+zOgjMYIu7kAq+yqiI= k8s.io/kubectl v0.30.3/go.mod h1:IcR0I9RN2+zzTRUa1BzZCm4oM0NLOawE6RzlDvd1Fpo= k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 h1:pUdcCO1Lk/tbT5ztQWOBi5HBgbBP1J8+AsQnQCKsi8A=