Documentation ¶
Index ¶
- Constants
- Variables
- func BundleStringToAPIBundle(bundleString string) (*api.Bundle, error)
- func BundleStringToObjectStrings(bundleString string) ([]string, error)
- func ChannelEntryToAPIChannelEntry(entry *ChannelEntry) *api.ChannelEntry
- func ContextWithPackage(ctx context.Context, pkg string) context.Context
- func DecodeFile(path string, into interface{}) error
- func DecodeUnstructured(reader io.Reader) (obj *unstructured.Unstructured, err error)
- func DefaultYAMLDecoder() runtime.Decoder
- func ObjectsAndPropertiesFromBundle(b *Bundle) ([]string, []property.Property, error)
- func PackageChannelToAPIChannel(channel *PackageChannel) *api.Channel
- func PackageFromContext(ctx context.Context) (string, bool)
- func PackageManifestToAPIPackage(manifest *PackageManifest) *api.Package
- type APIKey
- type Annotations
- type AnnotationsFile
- type Bundle
- func (b *Bundle) Add(obj *unstructured.Unstructured)
- func (b *Bundle) AllProvidedAPIsInBundle() error
- func (b *Bundle) ClusterServiceVersion() (*ClusterServiceVersion, error)
- func (b *Bundle) CustomResourceDefinitions() ([]runtime.Object, error)
- func (b *Bundle) Description() (string, error)
- func (b *Bundle) Icons() ([]Icon, error)
- func (b *Bundle) Images() (map[string]struct{}, error)
- func (b *Bundle) ProvidedAPIs() (map[APIKey]struct{}, error)
- func (b *Bundle) Replaces() (string, error)
- func (b *Bundle) RequiredAPIs() (map[APIKey]struct{}, error)
- func (b *Bundle) Serialize() (csvName, bundleImage string, csvBytes []byte, bundleBytes []byte, ...)
- func (b *Bundle) Size() int
- func (b *Bundle) SkipRange() (string, error)
- func (b *Bundle) Skips() ([]string, error)
- func (b *Bundle) SubstitutesFor() (string, error)
- func (b *Bundle) Version() (string, error)
- type BundleGraphLoader
- type BundleImageAlreadyAddedErr
- type BundleKey
- type BundleSender
- type CelConstraint
- type Channel
- type ChannelEntry
- type ChannelEntryAnnotated
- type ClusterServiceVersion
- func (csv *ClusterServiceVersion) GetApiServiceDefinitions() (owned []*DefinitionKey, required []*DefinitionKey, err error)
- func (csv *ClusterServiceVersion) GetCustomResourceDefintions() (owned []*DefinitionKey, required []*DefinitionKey, err error)
- func (csv *ClusterServiceVersion) GetDescription() (string, error)
- func (csv *ClusterServiceVersion) GetIcons() ([]Icon, error)
- func (csv *ClusterServiceVersion) GetOperatorImages() (map[string]struct{}, error)
- func (csv *ClusterServiceVersion) GetRelatedImages() (imageSet map[string]struct{}, err error)
- func (csv *ClusterServiceVersion) GetReplaces() (string, error)
- func (csv *ClusterServiceVersion) GetSkipRange() string
- func (csv *ClusterServiceVersion) GetSkips() ([]string, error)
- func (csv *ClusterServiceVersion) GetSubstitutesFor() string
- func (csv *ClusterServiceVersion) GetVersion() (string, error)
- type DefinitionKey
- type Dependencies
- type DependenciesFile
- type Dependency
- type DeprecatedProperty
- type DirGraphLoader
- type DirectoryPopulator
- type EmptyQuery
- func (EmptyQuery) GetApisForEntry(ctx context.Context, entryId int64) (provided []*api.GroupVersionKind, required []*api.GroupVersionKind, err error)
- func (EmptyQuery) GetBundle(ctx context.Context, pkgName, channelName, csvName string) (*api.Bundle, error)
- func (EmptyQuery) GetBundleForChannel(ctx context.Context, pkgName string, channelName string) (*api.Bundle, error)
- func (EmptyQuery) GetBundlePathIfExists(ctx context.Context, csvName string) (bundlePath string, err error)
- func (EmptyQuery) GetBundlePathsForPackage(ctx context.Context, pkgName string) ([]string, error)
- func (EmptyQuery) GetBundleThatProvides(ctx context.Context, group, version, kind string) (*api.Bundle, error)
- func (EmptyQuery) GetBundleThatReplaces(ctx context.Context, name, pkgName, channelName string) (*api.Bundle, error)
- func (EmptyQuery) GetBundleVersion(ctx context.Context, image string) (string, error)
- func (EmptyQuery) GetBundlesForPackage(ctx context.Context, pkgName string) (map[BundleKey]struct{}, error)
- func (EmptyQuery) GetChannelEntriesFromPackage(ctx context.Context, packageName string) ([]ChannelEntryAnnotated, error)
- func (EmptyQuery) GetChannelEntriesThatProvide(ctx context.Context, group, version, kind string) (entries []*ChannelEntry, err error)
- func (EmptyQuery) GetChannelEntriesThatReplace(ctx context.Context, name string) (entries []*ChannelEntry, err error)
- func (EmptyQuery) GetCurrentCSVNameForChannel(ctx context.Context, pkgName, channel string) (string, error)
- func (EmptyQuery) GetDefaultChannelForPackage(ctx context.Context, pkgName string) (string, error)
- func (EmptyQuery) GetDefaultPackage(ctx context.Context, name string) (string, error)
- func (EmptyQuery) GetDependenciesForBundle(ctx context.Context, name, version, path string) (dependencies []*api.Dependency, err error)
- func (EmptyQuery) GetImagesForBundle(ctx context.Context, bundleName string) ([]string, error)
- func (EmptyQuery) GetLatestChannelEntriesThatProvide(ctx context.Context, group, version, kind string) (entries []*ChannelEntry, err error)
- func (EmptyQuery) GetPackage(ctx context.Context, name string) (*PackageManifest, error)
- func (EmptyQuery) ListBundles(ctx context.Context) ([]*api.Bundle, error)
- func (EmptyQuery) ListChannels(ctx context.Context, pkgName string) ([]string, error)
- func (EmptyQuery) ListImages(ctx context.Context) ([]string, error)
- func (EmptyQuery) ListPackages(ctx context.Context) ([]string, error)
- func (EmptyQuery) ListRegistryBundles(ctx context.Context) ([]*Bundle, error)
- func (EmptyQuery) ListTables(ctx context.Context) ([]string, error)
- func (EmptyQuery) SendBundles(ctx context.Context, stream BundleSender) error
- type GRPCQuery
- type GVKDependency
- type GVKProperty
- type GraphLoader
- type HeadOverwriter
- type Icon
- type ImageInput
- type LabelDependency
- type LabelProperty
- type Load
- type Mode
- type OverwriteErr
- type Package
- type PackageChannel
- type PackageDependency
- type PackageManifest
- type PackageProperty
- type PackageVersionAlreadyAddedErr
- type PropertiesFile
- type Property
- type Querier
- func (q Querier) Close() error
- func (q Querier) GetBundle(_ context.Context, pkgName, channelName, csvName string) (*api.Bundle, error)
- func (q Querier) GetBundleForChannel(_ context.Context, pkgName string, channelName string) (*api.Bundle, error)
- func (q Querier) GetBundleThatProvides(ctx context.Context, group, version, kind string) (*api.Bundle, error)
- func (q Querier) GetBundleThatReplaces(_ context.Context, name, pkgName, channelName string) (*api.Bundle, error)
- func (q Querier) GetChannelEntriesThatProvide(_ context.Context, group, version, kind string) ([]*ChannelEntry, error)
- func (q Querier) GetChannelEntriesThatReplace(_ context.Context, name string) ([]*ChannelEntry, error)
- func (q Querier) GetLatestChannelEntriesThatProvide(_ context.Context, group, version, kind string) ([]*ChannelEntry, error)
- func (q Querier) GetPackage(_ context.Context, name string) (*PackageManifest, error)
- func (q Querier) ListBundles(ctx context.Context) ([]*api.Bundle, error)
- func (q Querier) ListPackages(_ context.Context) ([]string, error)
- func (q Querier) SendBundles(_ context.Context, s BundleSender) error
- type Query
- type RegistryPopulator
- type SliceBundleSender
Constants ¶
const ( ReplacesMode = iota SemVerMode SkipPatchMode )
const ( GVKType = "olm.gvk" PackageType = "olm.package" DeprecatedType = "olm.deprecated" LabelType = "olm.label" PropertyKey = "olm.properties" ConstraintType = "olm.constraint" )
const (
CRDKind = "CustomResourceDefinition"
)
Variables ¶
var ( // ErrPackageNotInDatabase is an error that describes a package not found error when querying the registry ErrPackageNotInDatabase = errors.New("Package not in database") // ErrBundleImageNotInDatabase is an error that describes a bundle image not found when querying the registry ErrBundleImageNotInDatabase = errors.New("Bundle Image not in database") // ErrRemovingDefaultChannelDuringDeprecation is an error that describes a bundle deprecation causing the deletion // of the default channel ErrRemovingDefaultChannelDuringDeprecation = errors.New("Bundle deprecation causing default channel removal") )
var Codecs = serializer.NewCodecFactory(Scheme)
Codecs provides access to encoding and decoding for the scheme
var Scheme = runtime.NewScheme()
Scheme is the default instance of runtime.Scheme to which types in the Kubernetes API are already registered.
Functions ¶
func BundleStringToAPIBundle ¶
func BundleStringToObjectStrings ¶
Bundle strings are appended json objects, we need to split them apart e.g. {"my":"obj"}{"csv":"data"}{"crd":"too"}
func ChannelEntryToAPIChannelEntry ¶
func ChannelEntryToAPIChannelEntry(entry *ChannelEntry) *api.ChannelEntry
func ContextWithPackage ¶
ContextWithPackage adds a package value to a context.
func DecodeFile ¶
DecodeFile decodes the file at a path into the given interface.
func DecodeUnstructured ¶
func DecodeUnstructured(reader io.Reader) (obj *unstructured.Unstructured, err error)
DecodeUnstructured decodes a raw stream into a an unstructured.Unstructured instance.
func DefaultYAMLDecoder ¶
func PackageChannelToAPIChannel ¶
func PackageChannelToAPIChannel(channel *PackageChannel) *api.Channel
func PackageFromContext ¶
PackageFromContext returns the package value of the context if set, returns false if unset.
func PackageManifestToAPIPackage ¶
func PackageManifestToAPIPackage(manifest *PackageManifest) *api.Package
Types ¶
type Annotations ¶
type Annotations struct { // PackageName is the name of the overall package, ala `etcd`. PackageName string `json:"operators.operatorframework.io.bundle.package.v1" yaml:"operators.operatorframework.io.bundle.package.v1"` // Channels are a comma separated list of the declared channels for the bundle, ala `stable` or `alpha`. Channels string `json:"operators.operatorframework.io.bundle.channels.v1" yaml:"operators.operatorframework.io.bundle.channels.v1"` // DefaultChannelName is, if specified, the name of the default channel for the package. The // default channel will be installed if no other channel is explicitly given. If the package // has a single channel, then that channel is implicitly the default. DefaultChannelName string `` /* 127-byte string literal not displayed */ }
Annotations is a list of annotations for a given bundle
func (Annotations) SelectDefaultChannel ¶
func (a Annotations) SelectDefaultChannel() string
type AnnotationsFile ¶
type AnnotationsFile struct { // annotations is a list of annotations for a given bundle Annotations Annotations `json:"annotations" yaml:"annotations"` }
AnnotationsFile holds annotation information about a bundle
func (*AnnotationsFile) GetChannels ¶
func (a *AnnotationsFile) GetChannels() []string
GetChannels returns the channels that this bundle should be added to
func (*AnnotationsFile) GetDefaultChannelName ¶
func (a *AnnotationsFile) GetDefaultChannelName() string
GetDefaultChannelName returns the name of the default channel
func (*AnnotationsFile) GetName ¶
func (a *AnnotationsFile) GetName() string
GetName returns the package name of the bundle
func (*AnnotationsFile) SelectDefaultChannel ¶
func (a *AnnotationsFile) SelectDefaultChannel() string
SelectDefaultChannel returns the first item in channel list that is sorted in lexicographic order.
type Bundle ¶
type Bundle struct { Name string Objects []*unstructured.Unstructured Package string Channels []string BundleImage string Dependencies []*Dependency Properties []Property Annotations *Annotations // contains filtered or unexported fields }
func NewBundle ¶
func NewBundle(name string, annotations *Annotations, objs ...*unstructured.Unstructured) *Bundle
func NewBundleFromStrings ¶
func (*Bundle) Add ¶
func (b *Bundle) Add(obj *unstructured.Unstructured)
func (*Bundle) AllProvidedAPIsInBundle ¶
func (*Bundle) ClusterServiceVersion ¶
func (b *Bundle) ClusterServiceVersion() (*ClusterServiceVersion, error)
func (*Bundle) CustomResourceDefinitions ¶
func (*Bundle) Description ¶
func (*Bundle) ProvidedAPIs ¶
func (*Bundle) RequiredAPIs ¶
func (*Bundle) SubstitutesFor ¶
type BundleGraphLoader ¶
type BundleGraphLoader struct { }
BundleGraphLoader generates updated graphs by adding bundles to them, updating the graph implicitly via semantic version of each bundle
func (*BundleGraphLoader) AddBundleToGraph ¶
func (g *BundleGraphLoader) AddBundleToGraph(bundle *Bundle, graph *Package, annotations *AnnotationsFile, skippatch bool) (*Package, error)
AddBundleToGraph takes a bundle and an existing graph and updates the graph to insert the new bundle into each channel it is included in
type BundleImageAlreadyAddedErr ¶
type BundleImageAlreadyAddedErr struct {
ErrorString string
}
BundleImageAlreadyAddedErr is an error that describes a bundle is already added
func (BundleImageAlreadyAddedErr) Error ¶
func (e BundleImageAlreadyAddedErr) Error() string
type BundleSender ¶
type CelConstraint ¶
type CelConstraint struct { // Constraint failure message that surfaces in resolution // This field is optional FailureMessage string `json:"failureMessage" yaml:"failureMessage"` // The cel struct that contraints CEL expression // This field is required Cel *constraints.Cel `json:"cel" yaml:"cel"` }
func (*CelConstraint) Validate ¶
func (cc *CelConstraint) Validate() []error
Validate will validate constraint type and return error(s)
type ChannelEntry ¶
type ChannelEntry struct { PackageName string ChannelName string BundleName string Replaces string }
ChannelEntry is a denormalized node in a channel graph
type ChannelEntryAnnotated ¶
type ChannelEntryAnnotated struct { PackageName string ChannelName string BundleName string BundlePath string Version string Replaces string ReplacesVersion string ReplacesBundlePath string }
ChannelEntryAnnotated is a denormalized node in a channel graph annotated with additional entry level info
type ClusterServiceVersion ¶
type ClusterServiceVersion struct { // Type metadata. metav1.TypeMeta `json:",inline"` // Object metadata. metav1.ObjectMeta `json:"metadata"` // Spec is the raw representation of the 'spec' element of // ClusterServiceVersion object. Since we are // not interested in the content of spec we are not parsing it. Spec json.RawMessage `json:"spec"` }
ClusterServiceVersion is a structured representation of cluster service version object(s) specified inside the 'clusterServiceVersions' section of an operator manifest.
func ReadCSVFromBundleDirectory ¶
func ReadCSVFromBundleDirectory(bundleDir string) (*ClusterServiceVersion, error)
ReadCSVFromBundleDirectory tries to parse every YAML file in the directory without inspecting sub-directories and returns a CSV. According to the strict one CSV per bundle rule, func returns an error if more than one CSV is found.
func (*ClusterServiceVersion) GetApiServiceDefinitions ¶
func (csv *ClusterServiceVersion) GetApiServiceDefinitions() (owned []*DefinitionKey, required []*DefinitionKey, err error)
GetApiServiceDefinitions returns a list of owned and required APISerivces specified inside the 'apiservicedefinitions' section of a ClusterServiceVersion 'spec'.
owned represents the list of apiservices managed by this ClusterServiceVersion object. required represents the list of apiservices that this ClusterServiceVersion object depends on.
If owned or required is not defined in the spec then an empty list is returned respectively.
func (*ClusterServiceVersion) GetCustomResourceDefintions ¶
func (csv *ClusterServiceVersion) GetCustomResourceDefintions() (owned []*DefinitionKey, required []*DefinitionKey, err error)
GetCustomResourceDefintions returns a list of owned and required CustomResourceDefinition object(s) specified inside the 'customresourcedefinitions' section of a ClusterServiceVersion 'spec'.
owned represents the list of CRD(s) managed by this ClusterServiceVersion object. required represents the list of CRD(s) that this ClusterServiceVersion object depends on.
If owned or required is not defined in the spec then an empty list is returned respectively.
func (*ClusterServiceVersion) GetDescription ¶
func (csv *ClusterServiceVersion) GetDescription() (string, error)
GetDescription returns the description from the ClusterServiceVersion If not defined, the function returns an empty string.
func (*ClusterServiceVersion) GetIcons ¶
func (csv *ClusterServiceVersion) GetIcons() ([]Icon, error)
GetIcons returns the icons from the ClusterServiceVersion
func (*ClusterServiceVersion) GetOperatorImages ¶
func (csv *ClusterServiceVersion) GetOperatorImages() (map[string]struct{}, error)
GetOperatorImages returns a list of any images used to run the operator. Currently this pulls any images in the pod specs of operator deployments.
func (*ClusterServiceVersion) GetRelatedImages ¶
func (csv *ClusterServiceVersion) GetRelatedImages() (imageSet map[string]struct{}, err error)
GetRelatedImage returns the list of associated images for the operator
func (*ClusterServiceVersion) GetReplaces ¶
func (csv *ClusterServiceVersion) GetReplaces() (string, error)
GetReplaces returns the name of the older ClusterServiceVersion object that is replaced by this ClusterServiceVersion object.
If not defined, the function returns an empty string.
func (*ClusterServiceVersion) GetSkipRange ¶
func (csv *ClusterServiceVersion) GetSkipRange() string
GetSkipRange returns the skiprange of the CSV
If not defined, the function returns an empty string.
func (*ClusterServiceVersion) GetSkips ¶
func (csv *ClusterServiceVersion) GetSkips() ([]string, error)
GetSkips returns the name of the older ClusterServiceVersion objects that are skipped by this ClusterServiceVersion object.
If not defined, the function returns an empty string.
func (*ClusterServiceVersion) GetSubstitutesFor ¶
func (csv *ClusterServiceVersion) GetSubstitutesFor() string
GetSubstitutesFor returns the name of the ClusterServiceVersion object that is substituted by this ClusterServiceVersion object.
If not defined, the function returns an empty string.
func (*ClusterServiceVersion) GetVersion ¶
func (csv *ClusterServiceVersion) GetVersion() (string, error)
GetVersion returns the version of the CSV
If not defined, the function returns an empty string.
type DefinitionKey ¶
type DefinitionKey struct { Group string `json:"group"` Kind string `json:"kind"` Name string `json:"name"` Version string `json:"version"` }
DefinitionKey represents the metadata for either an APIservice or a CRD from a CSV spec
type Dependencies ¶
type Dependencies struct {
RawMessage []map[string]interface{} `json:"dependencies" yaml:"dependencies"`
}
type DependenciesFile ¶
type DependenciesFile struct { // Dependencies is a list of dependencies for a given bundle Dependencies []Dependency `json:"dependencies" yaml:"dependencies"` }
DependenciesFile holds dependency information about a bundle.
func (*DependenciesFile) GetDependencies ¶
func (d *DependenciesFile) GetDependencies() []*Dependency
GetDependencies returns the list of dependency
type Dependency ¶
type Dependency struct { // The type of dependency. This field is required. Type string `json:"type" yaml:"type"` // The serialized value of the dependency Value json.RawMessage `json:"value" yaml:"value"` }
Dependency specifies a single constraint that can be satisfied by a property on another bundle.
func (*Dependency) GetType ¶
func (e *Dependency) GetType() string
GetType returns the type of dependency
func (*Dependency) GetTypeValue ¶
func (e *Dependency) GetTypeValue() interface{}
GetTypeValue returns the dependency object that is converted from value string
func (*Dependency) GetValue ¶
func (e *Dependency) GetValue() string
GetValue returns the value content of dependency
type DeprecatedProperty ¶
type DeprecatedProperty struct { }
type DirGraphLoader ¶
type DirGraphLoader struct { PackageDir string CsvNameAndReplaceMap map[string]csvReplaces SortedCSVs csvs // only contains bundles with version field which will be considered for skip range. }
func NewPackageGraphLoaderFromDir ¶
func NewPackageGraphLoaderFromDir(packageDir string) (*DirGraphLoader, error)
NewPackageGraphLoaderFromDir takes the root directory of the package in the file system.
func (*DirGraphLoader) Generate ¶
func (g *DirGraphLoader) Generate() (*Package, error)
Generate returns Package graph by parsing through package directory assuming all bundles in the package exist.
type DirectoryPopulator ¶
type DirectoryPopulator struct {
// contains filtered or unexported fields
}
DirectoryPopulator loads an unpacked operator bundle from a directory into the database.
func NewDirectoryPopulator ¶
func NewDirectoryPopulator(loader Load, graphLoader GraphLoader, querier Query, imageDirMap map[image.Reference]string, overwrittenImages map[string][]string) *DirectoryPopulator
func (*DirectoryPopulator) Populate ¶
func (i *DirectoryPopulator) Populate(mode Mode) error
func (*DirectoryPopulator) ValidateEdgeBundlePackage ¶
func (i *DirectoryPopulator) ValidateEdgeBundlePackage(images []*ImageInput) error
ValidateEdgeBundlePackage ensures that all bundles in the input will only skip or replace bundles in the same package.
type EmptyQuery ¶
type EmptyQuery struct{}
EmptyQuery acts as a "zero value" implementation of the Query interface.
EmptyQuery can be used as a substitute for any operation dependent on Query.
func NewEmptyQuerier ¶
func NewEmptyQuerier() *EmptyQuery
func (EmptyQuery) GetApisForEntry ¶
func (EmptyQuery) GetApisForEntry(ctx context.Context, entryId int64) (provided []*api.GroupVersionKind, required []*api.GroupVersionKind, err error)
func (EmptyQuery) GetBundleForChannel ¶
func (EmptyQuery) GetBundlePathIfExists ¶
func (EmptyQuery) GetBundlePathsForPackage ¶
func (EmptyQuery) GetBundleThatProvides ¶
func (EmptyQuery) GetBundleThatReplaces ¶
func (EmptyQuery) GetBundleVersion ¶
func (EmptyQuery) GetBundlesForPackage ¶
func (EmptyQuery) GetChannelEntriesFromPackage ¶
func (EmptyQuery) GetChannelEntriesFromPackage(ctx context.Context, packageName string) ([]ChannelEntryAnnotated, error)
func (EmptyQuery) GetChannelEntriesThatProvide ¶
func (EmptyQuery) GetChannelEntriesThatProvide(ctx context.Context, group, version, kind string) (entries []*ChannelEntry, err error)
func (EmptyQuery) GetChannelEntriesThatReplace ¶
func (EmptyQuery) GetChannelEntriesThatReplace(ctx context.Context, name string) (entries []*ChannelEntry, err error)
func (EmptyQuery) GetCurrentCSVNameForChannel ¶
func (EmptyQuery) GetDefaultChannelForPackage ¶
func (EmptyQuery) GetDefaultPackage ¶
func (EmptyQuery) GetDependenciesForBundle ¶
func (EmptyQuery) GetDependenciesForBundle(ctx context.Context, name, version, path string) (dependencies []*api.Dependency, err error)
func (EmptyQuery) GetImagesForBundle ¶
func (EmptyQuery) GetLatestChannelEntriesThatProvide ¶
func (EmptyQuery) GetLatestChannelEntriesThatProvide(ctx context.Context, group, version, kind string) (entries []*ChannelEntry, err error)
func (EmptyQuery) GetPackage ¶
func (EmptyQuery) GetPackage(ctx context.Context, name string) (*PackageManifest, error)
func (EmptyQuery) ListBundles ¶
func (EmptyQuery) ListChannels ¶
func (EmptyQuery) ListImages ¶
func (EmptyQuery) ListImages(ctx context.Context) ([]string, error)
func (EmptyQuery) ListPackages ¶
func (EmptyQuery) ListPackages(ctx context.Context) ([]string, error)
func (EmptyQuery) ListRegistryBundles ¶
func (EmptyQuery) ListRegistryBundles(ctx context.Context) ([]*Bundle, error)
func (EmptyQuery) ListTables ¶
func (EmptyQuery) ListTables(ctx context.Context) ([]string, error)
func (EmptyQuery) SendBundles ¶
func (EmptyQuery) SendBundles(ctx context.Context, stream BundleSender) error
type GRPCQuery ¶
type GRPCQuery interface { // List all available package names in the index ListPackages(ctx context.Context) ([]string, error) // Sends all available bundles in the index SendBundles(ctx context.Context, stream BundleSender) error // List all available bundles in the index ListBundles(ctx context.Context) (bundles []*api.Bundle, err error) // Get a package by name from the index GetPackage(ctx context.Context, name string) (*PackageManifest, error) // Get a bundle by its package name, channel name and csv name from the index GetBundle(ctx context.Context, pkgName, channelName, csvName string) (*api.Bundle, error) // Get the bundle in the specified package at the head of the // specified channel. DEPRECATED. Returned bundles may have // only the "name" and "csvJson" fields populated in order to // support legacy usage. GetBundleForChannel(ctx context.Context, pkgName string, channelName string) (*api.Bundle, error) // Get all channel entries that say they replace this one GetChannelEntriesThatReplace(ctx context.Context, name string) (entries []*ChannelEntry, err error) // Get the bundle in a package/channel that replace this one GetBundleThatReplaces(ctx context.Context, name, pkgName, channelName string) (*api.Bundle, error) // Get all channel entries that provide an api GetChannelEntriesThatProvide(ctx context.Context, group, version, kind string) (entries []*ChannelEntry, err error) // Get latest channel entries that provide an api GetLatestChannelEntriesThatProvide(ctx context.Context, group, version, kind string) (entries []*ChannelEntry, err error) // Get the the latest bundle that provides the API in a default channel GetBundleThatProvides(ctx context.Context, group, version, kind string) (*api.Bundle, error) }
type GVKDependency ¶
type GVKDependency struct { // The group of GVK based dependency Group string `json:"group" yaml:"group"` // The kind of GVK based dependency Kind string `json:"kind" yaml:"kind"` // The version of GVK based dependency Version string `json:"version" yaml:"version"` }
func (*GVKDependency) Validate ¶
func (gd *GVKDependency) Validate() []error
Validate will validate GVK dependency type and return error(s)
type GVKProperty ¶
type GraphLoader ¶
GraphLoader generates a graph GraphLoader supports multiple different loading schemes GraphLoader from SQL, GraphLoader from old format (filesystem), GraphLoader from SQL + input bundles
type HeadOverwriter ¶
type ImageInput ¶
type ImageInput struct { Bundle *Bundle // contains filtered or unexported fields }
func NewImageInput ¶
func NewImageInput(to image.Reference, from string) (*ImageInput, error)
type LabelDependency ¶
type LabelDependency struct { // The Label name of dependency Label string `json:"label" yaml:"label"` }
func (*LabelDependency) Validate ¶
func (ld *LabelDependency) Validate() []error
Validate will validate Label dependency type and return error(s)
type LabelProperty ¶
type LabelProperty struct { // The name of Label Label string `json:"label" yaml:"label"` }
type Load ¶
type Load interface { AddOperatorBundle(bundle *Bundle) error AddBundleSemver(graph *Package, bundle *Bundle) error AddPackageChannels(manifest PackageManifest) error AddBundlePackageChannels(manifest PackageManifest, bundle *Bundle) error RemovePackage(packageName string) error RemoveStrandedBundles() error DeprecateBundle(path string) error ClearNonHeadBundles() error }
type OverwriteErr ¶
type OverwriteErr struct {
ErrorString string
}
OverwritesErr is an error that describes that an error with the add request with --force enabled.
func (OverwriteErr) Error ¶
func (e OverwriteErr) Error() string
type Package ¶
func (*Package) HasChannel ¶
type PackageChannel ¶
type PackageChannel struct { // Name is the name of the channel, e.g. `alpha` or `stable` Name string `json:"name" yaml:"name"` // CurrentCSVName defines a reference to the CSV holding the version of this package currently // for the channel. CurrentCSVName string `json:"currentCSV" yaml:"currentCSV"` }
PackageChannel defines a single channel under a package, pointing to a version of that package.
func (PackageChannel) IsDefaultChannel ¶
func (pc PackageChannel) IsDefaultChannel(pm PackageManifest) bool
IsDefaultChannel returns true if the PackageChennel is the default for the PackageManifest
type PackageDependency ¶
type PackageDependency struct { // The name of dependency such as 'etcd' PackageName string `json:"packageName" yaml:"packageName"` // The version range of dependency in semver range format Version string `json:"version" yaml:"version"` }
func (*PackageDependency) Validate ¶
func (pd *PackageDependency) Validate() []error
Validate will validate package dependency type and return error(s)
type PackageManifest ¶
type PackageManifest struct { // PackageName is the name of the overall package, ala `etcd`. PackageName string `json:"packageName" yaml:"packageName"` // Channels are the declared channels for the package, ala `stable` or `alpha`. Channels []PackageChannel `json:"channels" yaml:"channels"` // DefaultChannelName is, if specified, the name of the default channel for the package. The // default channel will be installed if no other channel is explicitly given. If the package // has a single channel, then that channel is implicitly the default. DefaultChannelName string `json:"defaultChannel" yaml:"defaultChannel"` }
PackageManifest holds information about a package, which is a reference to one (or more) channels under a single package.
func DecodePackageManifest ¶
func DecodePackageManifest(reader io.Reader) (manifest *PackageManifest, err error)
DecodePackageManifest decodes a raw stream into a a PackageManifest instance. If a package name is empty we consider the object invalid!
func SemverPackageManifest ¶
func SemverPackageManifest(bundles []*Bundle) (*PackageManifest, error)
SemverPackageManifest generates a PackageManifest from a set of bundles, determining channel heads and the default channel using semver. Bundles with the highest version field (according to semver) are chosen as channel heads, and the default channel is taken from the last, highest versioned bundle in the entire set to define it. The given bundles must all belong to the same package or an error is thrown.
func (PackageManifest) GetDefaultChannel ¶
func (m PackageManifest) GetDefaultChannel() string
GetDefaultChannel gets the default channel or returns the only one if there's only one. returns empty string if it can't determine the default
type PackageProperty ¶
type PackageVersionAlreadyAddedErr ¶
type PackageVersionAlreadyAddedErr struct {
ErrorString string
}
PackageVersionAlreadyAddedErr is an error that describes that a bundle that is already in the databse that provides this package and version
func (PackageVersionAlreadyAddedErr) Error ¶
func (e PackageVersionAlreadyAddedErr) Error() string
type PropertiesFile ¶
type PropertiesFile struct { // Properties is a list of properties. Properties []Property `json:"properties" yaml:"properties"` }
PropertiesFile holds the properties associated with a bundle.
type Property ¶
type Property struct { // The type of property. This field is required. Type string `json:"type" yaml:"type"` // The serialized value of the propertuy Value json.RawMessage `json:"value" yaml:"value"` }
Property defines a single piece of the public interface for a bundle. Dependencies are specified over properties. The Type of the property determines how to interpret the Value, but the value is treated opaquely for for non-first-party types.
type Querier ¶
type Querier struct {
// contains filtered or unexported fields
}
func (Querier) GetBundleForChannel ¶
func (Querier) GetBundleThatProvides ¶
func (Querier) GetBundleThatReplaces ¶
func (Querier) GetChannelEntriesThatProvide ¶
func (Querier) GetChannelEntriesThatReplace ¶
func (Querier) GetLatestChannelEntriesThatProvide ¶
func (q Querier) GetLatestChannelEntriesThatProvide(_ context.Context, group, version, kind string) ([]*ChannelEntry, error)
TODO(joelanford): Need to review the expected functionality of this function. I ran
some experiments with the sqlite version of this function and it seems to only return channel heads that provide the GVK (rather than searching down the graph if parent bundles don't provide the API). Based on that, this function currently looks at channel heads only. --- Separate, but possibly related, I noticed there are several channels in the channel entry table who's minimum depth is 1. What causes 1 to be minimum depth in some cases and 0 in others?
func (Querier) GetPackage ¶
func (Querier) ListBundles ¶
func (Querier) SendBundles ¶
func (q Querier) SendBundles(_ context.Context, s BundleSender) error
type Query ¶
type Query interface { GRPCQuery ListTables(ctx context.Context) ([]string, error) GetDefaultPackage(ctx context.Context, name string) (string, error) GetChannelEntriesFromPackage(ctx context.Context, packageName string) ([]ChannelEntryAnnotated, error) // List all images in the database ListImages(ctx context.Context) ([]string, error) // List all images for a particular bundle GetImagesForBundle(ctx context.Context, bundleName string) ([]string, error) // Get Provided and Required APIs for a particular bundle GetApisForEntry(ctx context.Context, entryID int64) (provided []*api.GroupVersionKind, required []*api.GroupVersionKind, err error) // Get Version of a Bundle Image GetBundleVersion(ctx context.Context, image string) (string, error) // List Images for Package GetBundlePathsForPackage(ctx context.Context, pkgName string) ([]string, error) // List Bundles for Package GetBundlesForPackage(ctx context.Context, pkgName string) (map[BundleKey]struct{}, error) // Get DefaultChannel for Package GetDefaultChannelForPackage(ctx context.Context, pkgName string) (string, error) // List channels for package ListChannels(ctx context.Context, pkgName string) ([]string, error) // Get CurrentCSV name for channel and package GetCurrentCSVNameForChannel(ctx context.Context, pkgName, channel string) (string, error) // Get the list of dependencies for a bundle GetDependenciesForBundle(ctx context.Context, name, version, path string) (dependencies []*api.Dependency, err error) // Get the bundle path if it exists GetBundlePathIfExists(ctx context.Context, csvName string) (string, error) // ListRegistryBundles returns a set of registry bundles. ListRegistryBundles(ctx context.Context) ([]*Bundle, error) }
type RegistryPopulator ¶
type RegistryPopulator interface {
Populate() error
}
RegistryPopulator populates a registry.