Skip to content
This repository has been archived by the owner on Aug 12, 2024. It is now read-only.

Commit

Permalink
(feat) dump bundle annotations into chart metadata
Browse files Browse the repository at this point in the history
  • Loading branch information
gallettilance committed Aug 5, 2024
1 parent 806c1ce commit 9d24391
Show file tree
Hide file tree
Showing 2 changed files with 69 additions and 4 deletions.
6 changes: 3 additions & 3 deletions pkg/provisioner/plain/plain.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,12 +24,12 @@ const (
manifestsDir = "manifests"
)

func HandleBundleDeployment(_ context.Context, fsys fs.FS, _ *rukpakv1alpha2.BundleDeployment) (*chart.Chart, chartutil.Values, error) {
func HandleBundleDeployment(_ context.Context, fsys fs.FS, bd *rukpakv1alpha2.BundleDeployment) (*chart.Chart, chartutil.Values, error) {
if err := ValidateBundle(fsys); err != nil {
return nil, nil, err
}

chrt, err := chartFromBundle(fsys)
chrt, err := chartFromBundle(fsys, bd)
if err != nil {
return nil, nil, err
}
Expand Down Expand Up @@ -78,7 +78,7 @@ func getObjects(bundle fs.FS, manifest fs.DirEntry) ([]client.Object, error) {
return util.ManifestObjects(manifestReader, manifestPath)
}

func chartFromBundle(fsys fs.FS) (*chart.Chart, error) {
func chartFromBundle(fsys fs.FS, bd *rukpakv1alpha2.BundleDeployment) (*chart.Chart, error) {

Check failure on line 81 in pkg/provisioner/plain/plain.go

View workflow job for this annotation

GitHub Actions / lint

`chartFromBundle` - `bd` is unused (unparam)
objects, err := getBundleObjects(fsys)
if err != nil {
return nil, fmt.Errorf("read bundle objects from bundle: %v", err)
Expand Down
67 changes: 66 additions & 1 deletion pkg/provisioner/registry/registry.go
Original file line number Diff line number Diff line change
@@ -1,14 +1,22 @@
package registry

import (
"bytes"
"context"
"errors"
"fmt"
"io"
"io/fs"
"path/filepath"

"helm.sh/helm/v3/pkg/chart"
"helm.sh/helm/v3/pkg/chartutil"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
"k8s.io/apimachinery/pkg/runtime"
apimachyaml "k8s.io/apimachinery/pkg/util/yaml"

"github.com/operator-framework/api/pkg/operators/v1alpha1"

Check failure on line 19 in pkg/provisioner/registry/registry.go

View workflow job for this annotation

GitHub Actions / lint

File is not `gci`-ed with --skip-generated -s standard -s dot -s default -s prefix(github.com/operator-framework) -s prefix(github.com/operator-framework/rukpak) --custom-order (gci)
rukpakv1alpha2 "github.com/operator-framework/rukpak/api/v1alpha2"
"github.com/operator-framework/rukpak/pkg/convert"
"github.com/operator-framework/rukpak/pkg/provisioner/plain"
Expand All @@ -24,5 +32,62 @@ func HandleBundleDeployment(ctx context.Context, fsys fs.FS, bd *rukpakv1alpha2.
if err != nil {
return nil, nil, fmt.Errorf("convert registry+v1 bundle to plain+v0 bundle: %v", err)
}
return plain.HandleBundleDeployment(ctx, plainFS, bd)
csv, err := registryV1ExtractCSV(fsys)
if err != nil {
return nil, nil, err
}
chart, vals, err := plain.HandleBundleDeployment(ctx, plainFS, bd)
if err != nil {
return nil, nil, err
}
// Append CSV Annotations to Chart Metadata Annotations
for k, v := range csv.GetAnnotations() {
chart.Metadata.Annotations[k] = v
}
return chart, vals, err
}

func registryV1ExtractCSV(fsys fs.FS) (*v1alpha1.ClusterServiceVersion, error) {
var objects []*unstructured.Unstructured
const manifestsDir = "manifests"

entries, err := fs.ReadDir(fsys, manifestsDir)
if err != nil {
return nil, err
}
for _, e := range entries {
if e.IsDir() {
return nil, fmt.Errorf("subdirectories are not allowed within the %q directory of the bundle image filesystem: found %q", manifestsDir, filepath.Join(manifestsDir, e.Name()))
}
fileData, err := fs.ReadFile(fsys, filepath.Join(manifestsDir, e.Name()))
if err != nil {
return nil, err
}

dec := apimachyaml.NewYAMLOrJSONDecoder(bytes.NewReader(fileData), 1024)
for {
obj := unstructured.Unstructured{}
err := dec.Decode(&obj)
if errors.Is(err, io.EOF) {
break
}
if err != nil {
return nil, fmt.Errorf("read %q: %v", e.Name(), err)
}
objects = append(objects, &obj)
}
}

for _, obj := range objects {
obj := obj
if obj.GetObjectKind().GroupVersionKind().Kind == "ClusterServiceVersion" {
csv := v1alpha1.ClusterServiceVersion{}
if err := runtime.DefaultUnstructuredConverter.FromUnstructured(obj.Object, &csv); err != nil {
return nil, err
}
return &csv, nil
}
}

return nil, fmt.Errorf("No ClusterServiceVersion found within the %q directory of the bundle image filesystem", manifestsDir)

Check failure on line 92 in pkg/provisioner/registry/registry.go

View workflow job for this annotation

GitHub Actions / lint

ST1005: error strings should not be capitalized (stylecheck)
}

0 comments on commit 9d24391

Please sign in to comment.