Documentation ¶
Overview ¶
Package v1 is the v1 version of the API.
Index ¶
Constants ¶
const ( PluginName = "image.openshift.io/ImagePolicy" // IgnorePolicyRulesAnnotation is a comma delimited list of rule names to omit from consideration // in a given namespace. Loaded from the namespace. IgnorePolicyRulesAnnotation = "alpha.image.policy.openshift.io/ignore-rules" // ResolveNamesAnnotation when placed on an object template or object requests that all relevant // image names be resolved by taking the name and tag and attempting to resolve a local image stream. // This overrides the imageLookupPolicy on the image stream. If the object is not namespaced the // annotation is ignored. The only valid value is '*'. ResolveNamesAnnotation = "alpha.image.policy.openshift.io/resolve-names" )
Variables ¶
var GroupVersion = schema.GroupVersion{Group: "image.openshift.io", Version: "v1"}
var (
Install = schemeBuilder.AddToScheme
)
Functions ¶
func SetDefaults_ImagePolicyConfig ¶
func SetDefaults_ImagePolicyConfig(obj *ImagePolicyConfig)
Types ¶
type ImageCondition ¶
type ImageCondition struct { // Name is the name of this policy rule for reference. It must be unique across all rules. Name string `json:"name"` // IgnoreNamespaceOverride prevents this condition from being overridden when the // `alpha.image.policy.openshift.io/ignore-rules` is set on a namespace and contains this rule name. IgnoreNamespaceOverride bool `json:"ignoreNamespaceOverride"` // OnResources determines which resources this applies to. Defaults to 'pods' for ImageExecutionPolicyRules. OnResources []metav1.GroupResource `json:"onResources"` // InvertMatch means the value of the condition is logically inverted (true -> false, false -> true). InvertMatch bool `json:"invertMatch"` // MatchIntegratedRegistry will only match image sources that originate from the configured integrated // registry. MatchIntegratedRegistry bool `json:"matchIntegratedRegistry"` // MatchRegistries will match image references that point to the provided registries. The image registry // must match at least one of these strings. MatchRegistries []string `json:"matchRegistries"` // SkipOnResolutionFailure allows the subsequent conditions to be bypassed if the integrated registry does // not have access to image metadata (no image exists matching the image digest). SkipOnResolutionFailure bool `json:"skipOnResolutionFailure"` // MatchDockerImageLabels checks against the resolved image for the presence of a Docker label. All // conditions must match. MatchDockerImageLabels []ValueCondition `json:"matchDockerImageLabels"` // MatchImageLabels checks against the resolved image for a label. All conditions must match. MatchImageLabels []metav1.LabelSelector `json:"matchImageLabels"` // MatchImageLabelSelectors is the processed form of MatchImageLabels. All conditions must match. // TODO: this only existed on the internal type, it's set as part of processing the configuration, // so presumably it should not be supplied by the user. Not sure the best way to deal with it. MatchImageLabelSelectors []labels.Selector `json:"-"` // MatchImageAnnotations checks against the resolved image for an annotation. All conditions must match. MatchImageAnnotations []ValueCondition `json:"matchImageAnnotations"` }
ImageCondition defines the conditions for matching a particular image source. The conditions below are all required (logical AND). If Reject is specified, the condition is false if all conditions match, and true otherwise.
func (*ImageCondition) DeepCopy ¶
func (in *ImageCondition) DeepCopy() *ImageCondition
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ImageCondition.
func (*ImageCondition) DeepCopyInto ¶
func (in *ImageCondition) DeepCopyInto(out *ImageCondition)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type ImageExecutionPolicyRule ¶
type ImageExecutionPolicyRule struct { ImageCondition `json:",inline"` // Reject means this rule, if it matches the condition, will cause an immediate failure. No // other rules will be considered. Reject bool `json:"reject"` }
ImageExecutionPolicyRule determines whether a provided image may be used on the platform.
func (*ImageExecutionPolicyRule) DeepCopy ¶
func (in *ImageExecutionPolicyRule) DeepCopy() *ImageExecutionPolicyRule
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ImageExecutionPolicyRule.
func (*ImageExecutionPolicyRule) DeepCopyInto ¶
func (in *ImageExecutionPolicyRule) DeepCopyInto(out *ImageExecutionPolicyRule)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type ImagePolicyConfig ¶
type ImagePolicyConfig struct { metav1.TypeMeta `json:",inline"` // ResolveImages indicates the default image resolution behavior. If a rewriting policy is chosen, // then the image pull specs will be updated. ResolveImages ImageResolutionType `json:"resolveImages"` // ResolutionRules allows more specific image resolution rules to be applied per resource. If // empty, it defaults to allowing local image stream lookups - "mysql" will map to the image stream // tag "mysql:latest" in the current namespace if the stream supports it. The default for this // field is all known types that support image resolution, and the policy for those rules will be // set to the overall resolution policy if an execution rule references the same resource. ResolutionRules []ImageResolutionPolicyRule `json:"resolutionRules"` // ExecutionRules determine whether the use of an image is allowed in an object with a pod spec. // By default, these rules only apply to pods, but may be extended to other resource types. // If all execution rules are negations, the default behavior is allow all. If any execution rule // is an allow, the default behavior is to reject all. ExecutionRules []ImageExecutionPolicyRule `json:"executionRules"` }
ImagePolicyConfig is the configuration for control of images running on the platform.
func (*ImagePolicyConfig) DeepCopy ¶
func (in *ImagePolicyConfig) DeepCopy() *ImagePolicyConfig
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ImagePolicyConfig.
func (*ImagePolicyConfig) DeepCopyInto ¶
func (in *ImagePolicyConfig) DeepCopyInto(out *ImagePolicyConfig)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (*ImagePolicyConfig) DeepCopyObject ¶
func (in *ImagePolicyConfig) DeepCopyObject() runtime.Object
DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
func (*ImagePolicyConfig) GetObjectKind ¶
func (obj *ImagePolicyConfig) GetObjectKind() schema.ObjectKind
type ImageResolutionPolicyRule ¶
type ImageResolutionPolicyRule struct { // Policy controls whether resolution will happen if the rule doesn't match local names. This value // overrides the global image policy for all target resources. Policy ImageResolutionType `json:"policy"` // TargetResource is the identified group and resource. If Resource is *, this rule will apply // to all resources in that group. TargetResource metav1.GroupResource `json:"targetResource"` // LocalNames will allow single segment names to be interpreted as namespace local image // stream tags, but only if the target image stream tag has the "resolveLocalNames" field // set. LocalNames bool `json:"localNames"` }
ImageResolutionPolicyRule describes resolution rules based on resource.
func (*ImageResolutionPolicyRule) DeepCopy ¶
func (in *ImageResolutionPolicyRule) DeepCopy() *ImageResolutionPolicyRule
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ImageResolutionPolicyRule.
func (*ImageResolutionPolicyRule) DeepCopyInto ¶
func (in *ImageResolutionPolicyRule) DeepCopyInto(out *ImageResolutionPolicyRule)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type ImageResolutionType ¶
type ImageResolutionType string
ImageResolutionType is an enumerated string that indicates how image pull spec resolution should be handled
var ( // require resolution to succeed and rewrite the resource to use it RequiredRewrite ImageResolutionType = "RequiredRewrite" // require resolution to succeed, but don't rewrite the image pull spec Required ImageResolutionType = "Required" // attempt resolution, rewrite if successful AttemptRewrite ImageResolutionType = "AttemptRewrite" // attempt resolution, don't rewrite Attempt ImageResolutionType = "Attempt" // don't attempt resolution DoNotAttempt ImageResolutionType = "DoNotAttempt" )
type ValueCondition ¶
type ValueCondition struct { // Key is the name of a key in a map to retrieve. Key string `json:"key"` // Set indicates the provided key exists in the map. This field is exclusive with Value. Set bool `json:"set"` // Value indicates the provided key has the given value. This field is exclusive with Set. Value string `json:"value"` }
ValueCondition reflects whether the following key in a map is set or has a given value.
func (*ValueCondition) DeepCopy ¶
func (in *ValueCondition) DeepCopy() *ValueCondition
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ValueCondition.
func (*ValueCondition) DeepCopyInto ¶
func (in *ValueCondition) DeepCopyInto(out *ValueCondition)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.