diff --git a/api/porch/types.go b/api/porch/types.go index c903ce10..3f041283 100644 --- a/api/porch/types.go +++ b/api/porch/types.go @@ -448,7 +448,6 @@ type NameMeta struct { Namespace string `json:"namespace,omitempty"` } - // PackageRevisionResources // +genclient // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object diff --git a/api/porch/v1alpha1/types.go b/api/porch/v1alpha1/types.go index 96903c86..1d5dd3f3 100644 --- a/api/porch/v1alpha1/types.go +++ b/api/porch/v1alpha1/types.go @@ -523,7 +523,6 @@ type PackageRevisionResourcesStatus struct { RenderStatus RenderStatus `json:"renderStatus,omitempty"` } - // Package // +genclient // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object @@ -559,4 +558,4 @@ type PackageStatus struct { // LatestRevision identifies the package revision that is the latest // published package revision belonging to this package LatestRevision string `json:"latestRevision,omitempty"` -} \ No newline at end of file +} diff --git a/api/porch/v1alpha1/util.go b/api/porch/v1alpha1/util.go index de032757..71a0ffa9 100644 --- a/api/porch/v1alpha1/util.go +++ b/api/porch/v1alpha1/util.go @@ -18,7 +18,6 @@ func LifecycleIsPublished(lifecycle PackageRevisionLifecycle) bool { return lifecycle == PackageRevisionLifecyclePublished || lifecycle == PackageRevisionLifecycleDeletionProposed } - // Check ReadinessGates checks if the package has met all readiness gates func PackageRevisionIsReady(readinessGates []ReadinessGate, conditions []Condition) bool { // Index our conditions @@ -38,4 +37,4 @@ func PackageRevisionIsReady(readinessGates []ReadinessGate, conditions []Conditi } return true -} \ No newline at end of file +} diff --git a/api/porchconfig/v1alpha1/types.go b/api/porchconfig/v1alpha1/types.go index 5c7239f1..32457723 100644 --- a/api/porchconfig/v1alpha1/types.go +++ b/api/porchconfig/v1alpha1/types.go @@ -46,7 +46,7 @@ const ( type RepositoryContent string const ( - RepositoryContentPackage RepositoryContent = "Package" + RepositoryContentPackage RepositoryContent = "Package" ) // RepositorySpec defines the desired state of Repository @@ -60,12 +60,12 @@ type RepositorySpec struct { Deployment bool `json:"deployment,omitempty"` // Type of the repository (i.e. git, OCI) Type RepositoryType `json:"type,omitempty"` - // The Content field is deprecated, please do not specify it in new manifests. + // The Content field is deprecated, please do not specify it in new manifests. // For partial backward compatibility it is still recognized, but its only valid value is "Package", and if not specified its default value is also "Package". // +kubebuilder:validation:XValidation:message="The 'content' field is deprecated, its only valid value is 'Package'",rule="self == '' || self == 'Package'" // +kubebuilder:default="Package" Content *RepositoryContent `json:"content,omitempty"` - + // Git repository details. Required if `type` is `git`. Ignored if `type` is not `git`. Git *GitRepository `json:"git,omitempty"` // OCI repository details. Required if `type` is `oci`. Ignored if `type` is not `oci`. diff --git a/pkg/cache/fake/credentialresolver.go b/pkg/cache/fake/credentialresolver.go index 1eff82c4..c9845672 100644 --- a/pkg/cache/fake/credentialresolver.go +++ b/pkg/cache/fake/credentialresolver.go @@ -16,8 +16,8 @@ package fake import ( "context" - "github.com/nephio-project/porch/pkg/repository" "github.com/go-git/go-git/v5/plumbing/transport" + "github.com/nephio-project/porch/pkg/repository" ) type credential struct { @@ -36,7 +36,7 @@ func (c *credential) ToAuthMethod() transport.AuthMethod { panic("unimplemented") } -type CredentialResolver struct{ +type CredentialResolver struct { cabundle string } diff --git a/pkg/cache/memory/cache_test.go b/pkg/cache/memory/cache_test.go index ed8dd323..c2523d8d 100644 --- a/pkg/cache/memory/cache_test.go +++ b/pkg/cache/memory/cache_test.go @@ -112,7 +112,7 @@ func TestPublishedLatest(t *testing.T) { if err := update.UpdateLifecycle(ctx, api.PackageRevisionLifecyclePublished); err != nil { t.Fatalf("UpdateLifecycle failed; %v", err) } - closed, err := update.Close(ctx, "") + closed, err := cachedRepo.ClosePackageRevisionDraft(ctx, update, "") if err != nil { t.Fatalf("Close failed: %v", err) } @@ -158,7 +158,7 @@ func TestDeletePublishedMain(t *testing.T) { if err := update.UpdateLifecycle(ctx, api.PackageRevisionLifecyclePublished); err != nil { t.Fatalf("UpdateLifecycle failed; %v", err) } - closed, err := update.Close(ctx, "") + closed, err := cachedRepo.ClosePackageRevisionDraft(ctx, update, "") if err != nil { t.Fatalf("Close failed: %v", err) } diff --git a/pkg/cache/memory/draft.go b/pkg/cache/memory/draft.go deleted file mode 100644 index ba60354a..00000000 --- a/pkg/cache/memory/draft.go +++ /dev/null @@ -1,71 +0,0 @@ -// Copyright 2022, 2024 The kpt and Nephio Authors -// -// Licensed under the Apache License, Version 2.0 (the "License"); -// you may not use this file except in compliance with the License. -// You may obtain a copy of the License at -// -// http://www.apache.org/licenses/LICENSE-2.0 -// -// Unless required by applicable law or agreed to in writing, software -// distributed under the License is distributed on an "AS IS" BASIS, -// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -// See the License for the specific language governing permissions and -// limitations under the License. - -package memory - -import ( - "context" - - "github.com/nephio-project/porch/api/porch/v1alpha1" - "github.com/nephio-project/porch/pkg/repository" - "go.opentelemetry.io/otel/trace" -) - -type cachedDraft struct { - repository.PackageRevisionDraft - cache *cachedRepository -} - -var _ repository.PackageRevisionDraft = &cachedDraft{} - -func (cd *cachedDraft) Close(ctx context.Context, version string) (repository.PackageRevision, error) { - ctx, span := tracer.Start(ctx, "cachedDraft::Close", trace.WithAttributes()) - defer span.End() - v, err := cd.cache.Version(ctx) - if err != nil { - return nil, err - } - - if v != cd.cache.lastVersion { - _, _, err = cd.cache.refreshAllCachedPackages(ctx) - if err != nil { - return nil, err - } - } - - revisions, err := cd.cache.ListPackageRevisions(ctx, repository.ListPackageRevisionFilter{ - Package: cd.GetName(), - }) - if err != nil { - return nil, err - } - - var publishedRevisions []string - for _, rev := range revisions { - if v1alpha1.LifecycleIsPublished(rev.Lifecycle()) { - publishedRevisions = append(publishedRevisions, rev.Key().Revision) - } - } - - nextVersion, err := repository.NextRevisionNumber(publishedRevisions) - if err != nil { - return nil, err - } - - if closed, err := cd.PackageRevisionDraft.Close(ctx, nextVersion); err != nil { - return nil, err - } else { - return cd.cache.update(ctx, closed) - } -} diff --git a/pkg/cache/memory/repository.go b/pkg/cache/memory/repository.go index b50e511e..2412c7fe 100644 --- a/pkg/cache/memory/repository.go +++ b/pkg/cache/memory/repository.go @@ -1,4 +1,4 @@ -// Copyright 2022,2024 The kpt and Nephio Authors +// Copyright 2022, 2024 The kpt and Nephio Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -168,29 +168,56 @@ func (r *cachedRepository) getCachedPackages(ctx context.Context, forceRefresh b } func (r *cachedRepository) CreatePackageRevision(ctx context.Context, obj *v1alpha1.PackageRevision) (repository.PackageRevisionDraft, error) { - created, err := r.repo.CreatePackageRevision(ctx, obj) + return r.repo.CreatePackageRevision(ctx, obj) +} + +func (r *cachedRepository) ClosePackageRevisionDraft(ctx context.Context, prd repository.PackageRevisionDraft, version string) (repository.PackageRevision, error) { + ctx, span := tracer.Start(ctx, "cachedRepository::ClosePackageRevisionDraft", trace.WithAttributes()) + defer span.End() + + v, err := r.Version(ctx) + if err != nil { + return nil, err + } + + if v != r.lastVersion { + _, _, err = r.refreshAllCachedPackages(ctx) + if err != nil { + return nil, err + } + } + + revisions, err := r.ListPackageRevisions(ctx, repository.ListPackageRevisionFilter{ + Package: prd.GetName(), + }) if err != nil { return nil, err } - return &cachedDraft{ - PackageRevisionDraft: created, - cache: r, - }, nil + var publishedRevisions []string + for _, rev := range revisions { + if v1alpha1.LifecycleIsPublished(rev.Lifecycle()) { + publishedRevisions = append(publishedRevisions, rev.Key().Revision) + } + } + + nextVersion, err := repository.NextRevisionNumber(publishedRevisions) + if err != nil { + return nil, err + } + + if closed, err := r.repo.ClosePackageRevisionDraft(ctx, prd, nextVersion); err != nil { + return nil, err + } else { + return r.update(ctx, closed) + } } func (r *cachedRepository) UpdatePackageRevision(ctx context.Context, old repository.PackageRevision) (repository.PackageRevisionDraft, error) { // Unwrap unwrapped := old.(*cachedPackageRevision).PackageRevision - created, err := r.repo.UpdatePackageRevision(ctx, unwrapped) - if err != nil { - return nil, err - } - return &cachedDraft{ - PackageRevisionDraft: created, - cache: r, - }, nil + return r.repo.UpdatePackageRevision(ctx, unwrapped) } func (r *cachedRepository) update(ctx context.Context, updated repository.PackageRevision) (*cachedPackageRevision, error) { diff --git a/pkg/cli/commands/rpkg/approve/command_test.go b/pkg/cli/commands/rpkg/approve/command_test.go index 89c5d7f8..3886fdb6 100644 --- a/pkg/cli/commands/rpkg/approve/command_test.go +++ b/pkg/cli/commands/rpkg/approve/command_test.go @@ -101,16 +101,16 @@ func TestCmd(t *testing.T) { Spec: porchapi.PackageRevisionSpec{ Lifecycle: porchapi.PackageRevisionLifecycleProposed, RepositoryName: repoName, - ReadinessGates: []porchapi.ReadinessGate { + ReadinessGates: []porchapi.ReadinessGate{ { ConditionType: "nephio.org.Specializer.specialize", }, }, }, Status: porchapi.PackageRevisionStatus{ - Conditions: []porchapi.Condition { + Conditions: []porchapi.Condition{ { - Type: "nephio.org.Specializer.specialize", + Type: "nephio.org.Specializer.specialize", Status: "False", }, }, diff --git a/pkg/engine/engine.go b/pkg/engine/engine.go index 75272209..ec88f8f5 100644 --- a/pkg/engine/engine.go +++ b/pkg/engine/engine.go @@ -1,4 +1,4 @@ -// Copyright 2022,2024 The kpt and Nephio Authors +// Copyright 2022, 2024 The kpt and Nephio Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -184,7 +184,7 @@ func (cad *cadEngine) CreatePackageRevision(ctx context.Context, repositoryObj * } // Updates are done. - repoPkgRev, err := draft.Close(ctx, "") + repoPkgRev, err := repo.ClosePackageRevisionDraft(ctx, draft, "") if err != nil { return nil, err } @@ -312,7 +312,7 @@ func (cad *cadEngine) UpdatePackageRevision(ctx context.Context, version string, } // Updates are done. - repoPkgRev, err = draft.Close(ctx, version) + repoPkgRev, err = repo.ClosePackageRevisionDraft(ctx, draft, version) if err != nil { return nil, err } @@ -512,7 +512,7 @@ func (cad *cadEngine) UpdatePackageResources(ctx context.Context, repositoryObj return nil, renderStatus, err } // No lifecycle change when updating package resources; updates are done. - repoPkgRev, err := draft.Close(ctx, "") + repoPkgRev, err := repo.ClosePackageRevisionDraft(ctx, draft, "") if err != nil { return nil, renderStatus, err } @@ -565,7 +565,7 @@ func (cad *cadEngine) RecloneAndReplay(ctx context.Context, parentPR repository. return nil, err } - repoPkgRev, err := draft.Close(ctx, version) + repoPkgRev, err := repo.ClosePackageRevisionDraft(ctx, draft, version) if err != nil { return nil, err diff --git a/pkg/git/draft.go b/pkg/git/draft.go index 34048da0..cb33d2b1 100644 --- a/pkg/git/draft.go +++ b/pkg/git/draft.go @@ -1,4 +1,4 @@ -// Copyright 2022 The kpt and Nephio Authors +// Copyright 2022, 2024 The kpt and Nephio Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -63,14 +63,6 @@ func (d *gitPackageRevisionDraft) UpdateLifecycle(ctx context.Context, new v1alp return nil } -// Finish round of updates. -func (d *gitPackageRevisionDraft) Close(ctx context.Context, version string) (repository.PackageRevision, error) { - ctx, span := tracer.Start(ctx, "gitPackageDraft::Close", trace.WithAttributes()) - defer span.End() - - return d.parent.CloseDraft(ctx, version, d) -} - func (d *gitPackageRevisionDraft) GetName() string { packageDirectory := d.parent.directory packageName := strings.TrimPrefix(d.path, packageDirectory+"/") diff --git a/pkg/git/git.go b/pkg/git/git.go index 7a6e84ab..f718662c 100644 --- a/pkg/git/git.go +++ b/pkg/git/git.go @@ -1480,10 +1480,15 @@ func (r *gitRepository) UpdateDraftResources(ctx context.Context, draft *gitPack return nil } -func (r *gitRepository) CloseDraft(ctx context.Context, version string, d *gitPackageRevisionDraft) (*gitPackageRevision, error) { +func (r *gitRepository) ClosePackageRevisionDraft(ctx context.Context, prd repository.PackageRevisionDraft, version string) (repository.PackageRevision, error) { + ctx, span := tracer.Start(ctx, "GitRepository::UpdateLifecycle", trace.WithAttributes()) + defer span.End() + r.mutex.Lock() defer r.mutex.Unlock() + d := prd.(*gitPackageRevisionDraft) + refSpecs := newPushRefSpecBuilder() draftBranch := createDraftName(d.path, d.workspaceName) proposedBranch := createProposedName(d.path, d.workspaceName) diff --git a/pkg/git/git_test.go b/pkg/git/git_test.go index 1578caeb..9c8614cb 100644 --- a/pkg/git/git_test.go +++ b/pkg/git/git_test.go @@ -1,4 +1,4 @@ -// Copyright 2022 The kpt and Nephio Authors +// Copyright 2022, 2024 The kpt and Nephio Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -180,7 +180,7 @@ func (g GitSuite) TestGitPackageRoundTrip(t *testing.T) { t.Fatalf("draft.UpdateResources(%#v, %#v) failed: %v", newResources, task, err) } - revision, err := draft.Close(ctx, "v1") + revision, err := repo.ClosePackageRevisionDraft(ctx, draft, "v1") if err != nil { t.Fatalf("draft.Close() failed: %v", err) } @@ -207,7 +207,7 @@ func (g GitSuite) TestGitPackageRoundTrip(t *testing.T) { if err := update.UpdateLifecycle(ctx, v1alpha1.PackageRevisionLifecyclePublished); err != nil { t.Fatalf("UpdateLifecycle failed: %v", err) } - approved, err := update.Close(ctx, "v1") + approved, err := repo.ClosePackageRevisionDraft(ctx, update, "v1") if err != nil { t.Fatalf("Close() of %q, %q failed: %v", packageName, workspace, err) } @@ -418,7 +418,7 @@ func (g GitSuite) TestListPackagesTrivial(t *testing.T) { }); err != nil { t.Fatalf("UpdateResources() failed: %v", err) } - newRevision, err := draft.Close(ctx, "") + newRevision, err := git.ClosePackageRevisionDraft(ctx, draft, "") if err != nil { t.Fatalf("draft.Close() failed: %v", err) } @@ -506,7 +506,7 @@ func (g GitSuite) TestCreatePackageInTrivialRepository(t *testing.T) { }); err != nil { t.Fatalf("UpdateResources() failed: %v", err) } - newRevision, err := draft.Close(ctx, "") + newRevision, err := git.ClosePackageRevisionDraft(ctx, draft, "") if err != nil { t.Fatalf("draft.Close() failed: %v", err) } @@ -688,7 +688,7 @@ func (g GitSuite) TestApproveDraft(t *testing.T) { update.UpdateLifecycle(ctx, v1alpha1.PackageRevisionLifecyclePublished) - new, err := update.Close(ctx, "v1") + new, err := git.ClosePackageRevisionDraft(ctx, update, "v1") if err != nil { t.Fatalf("Close failed: %v", err) } @@ -750,7 +750,7 @@ func (g GitSuite) TestApproveDraftWithHistory(t *testing.T) { update.UpdateLifecycle(ctx, v1alpha1.PackageRevisionLifecyclePublished) - new, err := update.Close(ctx, "v1") + new, err := git.ClosePackageRevisionDraft(ctx, update, "v1") if err != nil { t.Fatalf("Close failed: %v", err) } diff --git a/pkg/kpt/fn/third_party/GoogleContainerTools/kpt-functions-catalog/functions/go/starlark/generated/docs.go b/pkg/kpt/fn/third_party/GoogleContainerTools/kpt-functions-catalog/functions/go/starlark/generated/docs.go index 2d899c61..ba13be6d 100644 --- a/pkg/kpt/fn/third_party/GoogleContainerTools/kpt-functions-catalog/functions/go/starlark/generated/docs.go +++ b/pkg/kpt/fn/third_party/GoogleContainerTools/kpt-functions-catalog/functions/go/starlark/generated/docs.go @@ -1,5 +1,3 @@ - - // Code generated by "mdtogo"; DO NOT EDIT. package generated diff --git a/pkg/oci/mutate.go b/pkg/oci/mutate.go index 54ab526d..98964500 100644 --- a/pkg/oci/mutate.go +++ b/pkg/oci/mutate.go @@ -1,4 +1,4 @@ -// Copyright 2022 The kpt and Nephio Authors +// Copyright 2022, 2024 The kpt and Nephio Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -55,7 +55,7 @@ func (r *ociRepository) CreatePackageRevision(ctx context.Context, obj *v1alpha1 } // digestName := ImageDigestName{} - return &ociPackageDraft{ + return &ociPackageRevisionDraft{ packageName: packageName, parent: r, tasks: []v1alpha1.Task{}, @@ -92,7 +92,7 @@ func (r *ociRepository) UpdatePackageRevision(ctx context.Context, old repositor return nil, fmt.Errorf("error fetching image %q: %w", ref, err) } - return &ociPackageDraft{ + return &ociPackageRevisionDraft{ packageName: packageName, parent: r, tasks: []v1alpha1.Task{}, @@ -102,7 +102,7 @@ func (r *ociRepository) UpdatePackageRevision(ctx context.Context, old repositor }, nil } -type ociPackageDraft struct { +type ociPackageRevisionDraft struct { packageName string created time.Time @@ -118,10 +118,10 @@ type ociPackageDraft struct { lifecycle v1alpha1.PackageRevisionLifecycle // New value of the package revision lifecycle } -var _ repository.PackageRevisionDraft = (*ociPackageDraft)(nil) +var _ repository.PackageRevisionDraft = (*ociPackageRevisionDraft)(nil) -func (p *ociPackageDraft) UpdateResources(ctx context.Context, new *v1alpha1.PackageRevisionResources, task *v1alpha1.Task) error { - _, span := tracer.Start(ctx, "ociPackageDraft::UpdateResources", trace.WithAttributes()) +func (p *ociPackageRevisionDraft) UpdateResources(ctx context.Context, new *v1alpha1.PackageRevisionResources, task *v1alpha1.Task) error { + _, span := tracer.Start(ctx, "ociPackageRevisionDraft::UpdateResources", trace.WithAttributes()) defer span.End() buf := bytes.NewBuffer(nil) @@ -190,20 +190,22 @@ func (p *ociPackageDraft) UpdateResources(ctx context.Context, new *v1alpha1.Pac return nil } -func (p *ociPackageDraft) UpdateLifecycle(ctx context.Context, new v1alpha1.PackageRevisionLifecycle) error { +func (p *ociPackageRevisionDraft) UpdateLifecycle(ctx context.Context, new v1alpha1.PackageRevisionLifecycle) error { p.lifecycle = new return nil } -func (p *ociPackageDraft) GetName() string { +func (p *ociPackageRevisionDraft) GetName() string { return p.packageName } // Finish round of updates. -func (p *ociPackageDraft) Close(ctx context.Context, version string) (repository.PackageRevision, error) { - ctx, span := tracer.Start(ctx, "ociPackageDraft::Close", trace.WithAttributes()) +func (r *ociRepository) ClosePackageRevisionDraft(ctx context.Context, prd repository.PackageRevisionDraft, version string) (repository.PackageRevision, error) { + ctx, span := tracer.Start(ctx, "ociRepository::ClosePackageRevisionDraft", trace.WithAttributes()) defer span.End() + p := prd.(*ociPackageRevisionDraft) + ref := p.tag option := remote.WithAuthFromKeychain(gcrane.Keychain) diff --git a/pkg/registry/porch/packagerevisions_approval.go b/pkg/registry/porch/packagerevisions_approval.go index 17b7801c..07f1d396 100644 --- a/pkg/registry/porch/packagerevisions_approval.go +++ b/pkg/registry/porch/packagerevisions_approval.go @@ -59,7 +59,7 @@ func (a *packageRevisionsApproval) Get(ctx context.Context, name string, options // Update finds a resource in the storage and updates it. Some implementations // may allow updates creates the object - they should set the created boolean // to true. -func (a *packageRevisionsApproval) Update(ctx context.Context, name string, objInfo rest.UpdatedObjectInfo, createValidation rest.ValidateObjectFunc, +func (a *packageRevisionsApproval) Update(ctx context.Context, name string, objInfo rest.UpdatedObjectInfo, createValidation rest.ValidateObjectFunc, updateValidation rest.ValidateObjectUpdateFunc, forceAllowCreate bool, options *metav1.UpdateOptions) (runtime.Object, bool, error) { allowCreate := false // do not allow create on update return a.common.updatePackageRevision(ctx, name, objInfo, createValidation, updateValidation, allowCreate) diff --git a/pkg/registry/porch/secret.go b/pkg/registry/porch/secret.go index 066f708d..17df0360 100644 --- a/pkg/registry/porch/secret.go +++ b/pkg/registry/porch/secret.go @@ -39,10 +39,10 @@ const ( WorkloadIdentityAuthType = "kpt.dev/workload-identity-auth" // Annotation used to specify the gsa for a ksa. - WIGCPSAAnnotation = "iam.gke.io/gcp-service-account" - + WIGCPSAAnnotation = "iam.gke.io/gcp-service-account" + //Secret.Data key required for the caBundle - CaBundleDataName = "ca.crt" + CaBundleDataName = "ca.crt" ) func NewCredentialResolver(coreClient client.Reader, resolverChain []Resolver) repository.CredentialResolver { diff --git a/pkg/registry/porch/secret_test.go b/pkg/registry/porch/secret_test.go index 022c118b..8a3e203b 100644 --- a/pkg/registry/porch/secret_test.go +++ b/pkg/registry/porch/secret_test.go @@ -149,7 +149,7 @@ func TestCaBundleCredentialResolver(t *testing.T) { }, }, expectedCredential: nil, - expectedErrString: "error resolving credential: CaBundle secret.Data key must be set as ca.crt", + expectedErrString: "error resolving credential: CaBundle secret.Data key must be set as ca.crt", }, } @@ -177,7 +177,7 @@ func TestCaBundleCredentialResolver(t *testing.T) { if cred != nil { assert.Equal(t, cred.ToString(), "blah") assert.Equal(t, cred.Valid(), true) - assert.Panics(t, func() {cred.ToAuthMethod()}) + assert.Panics(t, func() { cred.ToAuthMethod() }) } }) } diff --git a/pkg/repository/fake/repository.go b/pkg/repository/fake/repository.go index 689bba28..864d5e89 100644 --- a/pkg/repository/fake/repository.go +++ b/pkg/repository/fake/repository.go @@ -61,6 +61,10 @@ func (r *Repository) CreatePackageRevision(_ context.Context, pr *v1alpha1.Packa return nil, nil } +func (r *Repository) ClosePackageRevisionDraft(ctx context.Context, prd repository.PackageRevisionDraft, version string) (repository.PackageRevision, error) { + return nil, nil +} + func (r *Repository) DeletePackageRevision(context.Context, repository.PackageRevision) error { return nil } diff --git a/pkg/repository/repository.go b/pkg/repository/repository.go index 543dd0ac..36c7fc6a 100644 --- a/pkg/repository/repository.go +++ b/pkg/repository/repository.go @@ -127,8 +127,6 @@ type PackageRevisionDraft interface { UpdateResources(ctx context.Context, new *v1alpha1.PackageRevisionResources, task *v1alpha1.Task) error // Updates desired lifecycle of the package. The lifecycle is applied on Close. UpdateLifecycle(ctx context.Context, new v1alpha1.PackageRevisionLifecycle) error - // Finish round of updates. - Close(ctx context.Context, version string) (PackageRevision, error) GetName() string } @@ -203,6 +201,9 @@ type Repository interface { // CreatePackageRevision creates a new package revision CreatePackageRevision(ctx context.Context, obj *v1alpha1.PackageRevision) (PackageRevisionDraft, error) + // ClosePackageRevisionDraft closes out a Package Revision Draft + ClosePackageRevisionDraft(ctx context.Context, prd PackageRevisionDraft, version string) (PackageRevision, error) + // DeletePackageRevision deletes a package revision DeletePackageRevision(ctx context.Context, old PackageRevision) error