diff --git a/_definitions.json b/_definitions.json new file mode 100644 index 0000000..e386cea --- /dev/null +++ b/_definitions.json @@ -0,0 +1,11857 @@ +{ + "definitions": { + "notification.toolkit.fluxcd.io.v1beta1.Alert": { + "description": "Alert is the Schema for the alerts API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Alert" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "AlertSpec defines an alerting rule for events involving a list of objects", + "properties": { + "eventSeverity": { + "default": "info", + "description": "Filter events based on severity, defaults to ('info').\nIf set to 'info' no events will be filtered.", + "enum": [ + "info", + "error" + ], + "type": "string" + }, + "eventSources": { + "description": "Filter events based on the involved objects.", + "items": { + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", + "properties": { + "apiVersion": { + "description": "API version of the referent", + "type": "string" + }, + "kind": { + "description": "Kind of the referent", + "enum": [ + "Bucket", + "GitRepository", + "Kustomization", + "HelmRelease", + "HelmChart", + "HelmRepository", + "ImageRepository", + "ImagePolicy", + "ImageUpdateAutomation", + "OCIRepository" + ], + "type": "string" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + }, + "name": { + "description": "Name of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "exclusionList": { + "description": "A list of Golang regular expressions to be used for excluding messages.", + "items": { + "type": "string" + }, + "type": "array" + }, + "providerRef": { + "description": "Send events using this provider.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "summary": { + "description": "Short description of the impact and affected cluster.", + "type": "string" + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent events dispatching.\nDefaults to false.", + "type": "boolean" + } + }, + "required": [ + "eventSources", + "providerRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "AlertStatus defines the observed state of Alert", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1beta2.Alert": { + "description": "Alert is the Schema for the alerts API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Alert" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "AlertSpec defines an alerting rule for events involving a list of objects.", + "properties": { + "eventMetadata": { + "additionalProperties": { + "type": "string" + }, + "description": "EventMetadata is an optional field for adding metadata to events dispatched by the\ncontroller. This can be used for enhancing the context of the event. If a field\nwould override one already present on the original event as generated by the emitter,\nthen the override doesn't happen, i.e. the original value is preserved, and an info\nlog is printed.", + "type": "object" + }, + "eventSeverity": { + "default": "info", + "description": "EventSeverity specifies how to filter events based on severity.\nIf set to 'info' no events will be filtered.", + "enum": [ + "info", + "error" + ], + "type": "string" + }, + "eventSources": { + "description": "EventSources specifies how to filter events based\non the involved object kind, name and namespace.", + "items": { + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", + "properties": { + "apiVersion": { + "description": "API version of the referent", + "type": "string" + }, + "kind": { + "description": "Kind of the referent", + "enum": [ + "Bucket", + "GitRepository", + "Kustomization", + "HelmRelease", + "HelmChart", + "HelmRepository", + "ImageRepository", + "ImagePolicy", + "ImageUpdateAutomation", + "OCIRepository" + ], + "type": "string" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", + "type": "object" + }, + "name": { + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "exclusionList": { + "description": "ExclusionList specifies a list of Golang regular expressions\nto be used for excluding messages.", + "items": { + "type": "string" + }, + "type": "array" + }, + "inclusionList": { + "description": "InclusionList specifies a list of Golang regular expressions\nto be used for including messages.", + "items": { + "type": "string" + }, + "type": "array" + }, + "providerRef": { + "description": "ProviderRef specifies which Provider this Alert should use.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "summary": { + "description": "Summary holds a short description of the impact and affected cluster.", + "maxLength": 255, + "type": "string" + }, + "suspend": { + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Alert.", + "type": "boolean" + } + }, + "required": [ + "eventSources", + "providerRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "AlertStatus defines the observed state of the Alert.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the Alert.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1beta3.Alert": { + "description": "Alert is the Schema for the alerts API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta3" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Alert" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "AlertSpec defines an alerting rule for events involving a list of objects.", + "properties": { + "eventMetadata": { + "additionalProperties": { + "type": "string" + }, + "description": "EventMetadata is an optional field for adding metadata to events dispatched by the\ncontroller. This can be used for enhancing the context of the event. If a field\nwould override one already present on the original event as generated by the emitter,\nthen the override doesn't happen, i.e. the original value is preserved, and an info\nlog is printed.", + "type": "object" + }, + "eventSeverity": { + "default": "info", + "description": "EventSeverity specifies how to filter events based on severity.\nIf set to 'info' no events will be filtered.", + "enum": [ + "info", + "error" + ], + "type": "string" + }, + "eventSources": { + "description": "EventSources specifies how to filter events based\non the involved object kind, name and namespace.", + "items": { + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", + "properties": { + "apiVersion": { + "description": "API version of the referent", + "type": "string" + }, + "kind": { + "description": "Kind of the referent", + "enum": [ + "Bucket", + "GitRepository", + "Kustomization", + "HelmRelease", + "HelmChart", + "HelmRepository", + "ImageRepository", + "ImagePolicy", + "ImageUpdateAutomation", + "OCIRepository" + ], + "type": "string" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", + "type": "object" + }, + "name": { + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "exclusionList": { + "description": "ExclusionList specifies a list of Golang regular expressions\nto be used for excluding messages.", + "items": { + "type": "string" + }, + "type": "array" + }, + "inclusionList": { + "description": "InclusionList specifies a list of Golang regular expressions\nto be used for including messages.", + "items": { + "type": "string" + }, + "type": "array" + }, + "providerRef": { + "description": "ProviderRef specifies which Provider this Alert should use.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "summary": { + "description": "Summary holds a short description of the impact and affected cluster.", + "maxLength": 255, + "type": "string" + }, + "suspend": { + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Alert.", + "type": "boolean" + } + }, + "required": [ + "eventSources", + "providerRef" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta1.Bucket": { + "description": "Bucket is the Schema for the buckets API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Bucket" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "BucketSpec defines the desired state of an S3 compatible bucket", + "properties": { + "accessFrom": { + "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "bucketName": { + "description": "The bucket name.", + "type": "string" + }, + "endpoint": { + "description": "The bucket endpoint address.", + "type": "string" + }, + "ignore": { + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", + "type": "string" + }, + "insecure": { + "description": "Insecure allows connecting to a non-TLS S3 HTTP endpoint.", + "type": "boolean" + }, + "interval": { + "description": "The interval at which to check for bucket updates.", + "type": "string" + }, + "provider": { + "default": "generic", + "description": "The S3 compatible storage provider name, default ('generic').", + "enum": [ + "generic", + "aws", + "gcp" + ], + "type": "string" + }, + "region": { + "description": "The bucket region.", + "type": "string" + }, + "secretRef": { + "description": "The name of the secret containing authentication credentials\nfor the Bucket.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend the reconciliation of this source.", + "type": "boolean" + }, + "timeout": { + "default": "60s", + "description": "The timeout for download operations, defaults to 60s.", + "type": "string" + } + }, + "required": [ + "bucketName", + "endpoint", + "interval" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "BucketStatus defines the observed state of a bucket", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful Bucket sync.", + "properties": { + "checksum": { + "description": "Checksum is the SHA256 checksum of the artifact.", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", + "format": "date-time", + "type": "string" + }, + "path": { + "description": "Path is the relative file path of this artifact.", + "type": "string" + }, + "revision": { + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", + "type": "string" + }, + "url": { + "description": "URL is the HTTP address of this artifact.", + "type": "string" + } + }, + "required": [ + "path", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the Bucket.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the download link for the artifact output of the last Bucket sync.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta2.Bucket": { + "description": "Bucket is the Schema for the buckets API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Bucket" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "BucketSpec specifies the required configuration to produce an Artifact for\nan object storage bucket.", + "properties": { + "accessFrom": { + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "bucketName": { + "description": "BucketName is the name of the object storage bucket.", + "type": "string" + }, + "endpoint": { + "description": "Endpoint is the object storage address the BucketName is located at.", + "type": "string" + }, + "ignore": { + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", + "type": "string" + }, + "insecure": { + "description": "Insecure allows connecting to a non-TLS HTTP Endpoint.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the Bucket Endpoint is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "prefix": { + "description": "Prefix to use for server-side filtering of files in the Bucket.", + "type": "string" + }, + "provider": { + "default": "generic", + "description": "Provider of the object storage bucket.\nDefaults to 'generic', which expects an S3 (API) compatible object\nstorage.", + "enum": [ + "generic", + "aws", + "gcp", + "azure" + ], + "type": "string" + }, + "region": { + "description": "Region of the Endpoint where the BucketName is located in.", + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing authentication credentials\nfor the Bucket.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nBucket.", + "type": "boolean" + }, + "timeout": { + "default": "60s", + "description": "Timeout for fetch operations, defaults to 60s.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + } + }, + "required": [ + "bucketName", + "endpoint", + "interval" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "BucketStatus records the observed state of a Bucket.", + "properties": { + "artifact": { + "description": "Artifact represents the last successful Bucket reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the Bucket.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the Bucket object.", + "format": "int64", + "type": "integer" + }, + "observedIgnore": { + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", + "type": "string" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nBucketStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1.GitRepository": { + "description": "GitRepository is the Schema for the gitrepositories API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "GitRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "GitRepositorySpec specifies the required configuration to produce an\nArtifact for a Git repository.", + "properties": { + "ignore": { + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", + "type": "string" + }, + "include": { + "description": "Include specifies a list of GitRepository resources which Artifacts\nshould be included in the Artifact produced for this GitRepository.", + "items": { + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", + "properties": { + "fromPath": { + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", + "type": "string" + }, + "repository": { + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "toPath": { + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", + "type": "string" + } + }, + "required": [ + "repository" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "interval": { + "description": "Interval at which the GitRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "proxySecretRef": { + "description": "ProxySecretRef specifies the Secret containing the proxy configuration\nto use while communicating with the Git server.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "recurseSubmodules": { + "description": "RecurseSubmodules enables the initialization of all submodules within\nthe GitRepository as cloned from the URL, using their default settings.", + "type": "boolean" + }, + "ref": { + "description": "Reference specifies the Git reference to resolve and monitor for\nchanges, defaults to the 'master' branch.", + "properties": { + "branch": { + "description": "Branch to check out, defaults to 'master' if no other field is defined.", + "type": "string" + }, + "commit": { + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", + "type": "string" + }, + "name": { + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "type": "string" + }, + "semver": { + "description": "SemVer tag expression to check out, takes precedence over Tag.", + "type": "string" + }, + "tag": { + "description": "Tag to check out, takes precedence over Branch.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing authentication credentials for\nthe GitRepository.\nFor HTTPS repositories the Secret must contain 'username' and 'password'\nfields for basic auth or 'bearerToken' field for token auth.\nFor SSH repositories the Secret must contain 'identity'\nand 'known_hosts' fields.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nGitRepository.", + "type": "boolean" + }, + "timeout": { + "default": "60s", + "description": "Timeout for Git operations like cloning, defaults to 60s.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "url": { + "description": "URL specifies the Git repository URL, it can be an HTTP/S or SSH address.", + "pattern": "^(http|https|ssh)://.*$", + "type": "string" + }, + "verify": { + "description": "Verification specifies the configuration to verify the Git commit\nsignature(s).", + "properties": { + "mode": { + "default": "HEAD", + "description": "Mode specifies which Git object(s) should be verified.\n\n\nThe variants \"head\" and \"HEAD\" both imply the same thing, i.e. verify\nthe commit that the HEAD of the Git repository points to. The variant\n\"head\" solely exists to ensure backwards compatibility.", + "enum": [ + "head", + "HEAD", + "Tag", + "TagAndHEAD" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing the public keys of trusted Git\nauthors.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "secretRef" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "interval", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "GitRepositoryStatus records the observed state of a Git repository.", + "properties": { + "artifact": { + "description": "Artifact represents the last successful GitRepository reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the GitRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "includedArtifacts": { + "description": "IncludedArtifacts contains a list of the last successfully included\nArtifacts as instructed by GitRepositorySpec.Include.", + "items": { + "description": "Artifact represents the output of a Source reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the GitRepository\nobject.", + "format": "int64", + "type": "integer" + }, + "observedIgnore": { + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", + "type": "string" + }, + "observedInclude": { + "description": "ObservedInclude is the observed list of GitRepository resources used to\nproduce the current Artifact.", + "items": { + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", + "properties": { + "fromPath": { + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", + "type": "string" + }, + "repository": { + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "toPath": { + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", + "type": "string" + } + }, + "required": [ + "repository" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "observedRecurseSubmodules": { + "description": "ObservedRecurseSubmodules is the observed resource submodules\nconfiguration used to produce the current Artifact.", + "type": "boolean" + }, + "sourceVerificationMode": { + "description": "SourceVerificationMode is the last used verification mode indicating\nwhich Git object(s) have been verified.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta1.GitRepository": { + "description": "GitRepository is the Schema for the gitrepositories API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "GitRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "GitRepositorySpec defines the desired state of a Git repository.", + "properties": { + "accessFrom": { + "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "gitImplementation": { + "default": "go-git", + "description": "Determines which git client library to use.\nDefaults to go-git, valid values are ('go-git', 'libgit2').", + "enum": [ + "go-git", + "libgit2" + ], + "type": "string" + }, + "ignore": { + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", + "type": "string" + }, + "include": { + "description": "Extra git repositories to map into the repository", + "items": { + "description": "GitRepositoryInclude defines a source with a from and to path.", + "properties": { + "fromPath": { + "description": "The path to copy contents from, defaults to the root directory.", + "type": "string" + }, + "repository": { + "description": "Reference to a GitRepository to include.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "toPath": { + "description": "The path to copy contents to, defaults to the name of the source ref.", + "type": "string" + } + }, + "required": [ + "repository" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "interval": { + "description": "The interval at which to check for repository updates.", + "type": "string" + }, + "recurseSubmodules": { + "description": "When enabled, after the clone is created, initializes all submodules within,\nusing their default settings.\nThis option is available only when using the 'go-git' GitImplementation.", + "type": "boolean" + }, + "ref": { + "description": "The Git reference to checkout and monitor for changes, defaults to\nmaster branch.", + "properties": { + "branch": { + "description": "The Git branch to checkout, defaults to master.", + "type": "string" + }, + "commit": { + "description": "The Git commit SHA to checkout, if specified Tag filters will be ignored.", + "type": "string" + }, + "semver": { + "description": "The Git tag semver expression, takes precedence over Tag.", + "type": "string" + }, + "tag": { + "description": "The Git tag to checkout, takes precedence over Branch.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "secretRef": { + "description": "The secret name containing the Git credentials.\nFor HTTPS repositories the secret must contain username and password\nfields.\nFor SSH repositories the secret must contain identity and known_hosts\nfields.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend the reconciliation of this source.", + "type": "boolean" + }, + "timeout": { + "default": "60s", + "description": "The timeout for remote Git operations like cloning, defaults to 60s.", + "type": "string" + }, + "url": { + "description": "The repository URL, can be a HTTP/S or SSH address.", + "pattern": "^(http|https|ssh)://.*$", + "type": "string" + }, + "verify": { + "description": "Verify OpenPGP signature for the Git commit HEAD points to.", + "properties": { + "mode": { + "description": "Mode describes what git object should be verified, currently ('head').", + "enum": [ + "head" + ], + "type": "string" + }, + "secretRef": { + "description": "The secret name containing the public keys of all trusted Git authors.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "mode" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "interval", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "GitRepositoryStatus defines the observed state of a Git repository.", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful repository sync.", + "properties": { + "checksum": { + "description": "Checksum is the SHA256 checksum of the artifact.", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", + "format": "date-time", + "type": "string" + }, + "path": { + "description": "Path is the relative file path of this artifact.", + "type": "string" + }, + "revision": { + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", + "type": "string" + }, + "url": { + "description": "URL is the HTTP address of this artifact.", + "type": "string" + } + }, + "required": [ + "path", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the GitRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "includedArtifacts": { + "description": "IncludedArtifacts represents the included artifacts from the last successful repository sync.", + "items": { + "description": "Artifact represents the output of a source synchronisation.", + "properties": { + "checksum": { + "description": "Checksum is the SHA256 checksum of the artifact.", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", + "format": "date-time", + "type": "string" + }, + "path": { + "description": "Path is the relative file path of this artifact.", + "type": "string" + }, + "revision": { + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", + "type": "string" + }, + "url": { + "description": "URL is the HTTP address of this artifact.", + "type": "string" + } + }, + "required": [ + "path", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the download link for the artifact output of the last repository\nsync.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta2.GitRepository": { + "description": "GitRepository is the Schema for the gitrepositories API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "GitRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "GitRepositorySpec specifies the required configuration to produce an\nArtifact for a Git repository.", + "properties": { + "accessFrom": { + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "gitImplementation": { + "default": "go-git", + "description": "GitImplementation specifies which Git client library implementation to\nuse. Defaults to 'go-git', valid values are ('go-git', 'libgit2').\nDeprecated: gitImplementation is deprecated now that 'go-git' is the\nonly supported implementation.", + "enum": [ + "go-git", + "libgit2" + ], + "type": "string" + }, + "ignore": { + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", + "type": "string" + }, + "include": { + "description": "Include specifies a list of GitRepository resources which Artifacts\nshould be included in the Artifact produced for this GitRepository.", + "items": { + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", + "properties": { + "fromPath": { + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", + "type": "string" + }, + "repository": { + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "toPath": { + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", + "type": "string" + } + }, + "required": [ + "repository" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "interval": { + "description": "Interval at which to check the GitRepository for updates.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "recurseSubmodules": { + "description": "RecurseSubmodules enables the initialization of all submodules within\nthe GitRepository as cloned from the URL, using their default settings.", + "type": "boolean" + }, + "ref": { + "description": "Reference specifies the Git reference to resolve and monitor for\nchanges, defaults to the 'master' branch.", + "properties": { + "branch": { + "description": "Branch to check out, defaults to 'master' if no other field is defined.", + "type": "string" + }, + "commit": { + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", + "type": "string" + }, + "name": { + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "type": "string" + }, + "semver": { + "description": "SemVer tag expression to check out, takes precedence over Tag.", + "type": "string" + }, + "tag": { + "description": "Tag to check out, takes precedence over Branch.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing authentication credentials for\nthe GitRepository.\nFor HTTPS repositories the Secret must contain 'username' and 'password'\nfields for basic auth or 'bearerToken' field for token auth.\nFor SSH repositories the Secret must contain 'identity'\nand 'known_hosts' fields.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nGitRepository.", + "type": "boolean" + }, + "timeout": { + "default": "60s", + "description": "Timeout for Git operations like cloning, defaults to 60s.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "url": { + "description": "URL specifies the Git repository URL, it can be an HTTP/S or SSH address.", + "pattern": "^(http|https|ssh)://.*$", + "type": "string" + }, + "verify": { + "description": "Verification specifies the configuration to verify the Git commit\nsignature(s).", + "properties": { + "mode": { + "description": "Mode specifies what Git object should be verified, currently ('head').", + "enum": [ + "head" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing the public keys of trusted Git\nauthors.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "mode", + "secretRef" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "interval", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "GitRepositoryStatus records the observed state of a Git repository.", + "properties": { + "artifact": { + "description": "Artifact represents the last successful GitRepository reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the GitRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "contentConfigChecksum": { + "description": "ContentConfigChecksum is a checksum of all the configurations related to\nthe content of the source artifact:\n - .spec.ignore\n - .spec.recurseSubmodules\n - .spec.included and the checksum of the included artifacts\nobserved in .status.observedGeneration version of the object. This can\nbe used to determine if the content of the included repository has\nchanged.\nIt has the format of `:`, for example: `sha256:`.\n\n\nDeprecated: Replaced with explicit fields for observed artifact content\nconfig in the status.", + "type": "string" + }, + "includedArtifacts": { + "description": "IncludedArtifacts contains a list of the last successfully included\nArtifacts as instructed by GitRepositorySpec.Include.", + "items": { + "description": "Artifact represents the output of a Source reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the GitRepository\nobject.", + "format": "int64", + "type": "integer" + }, + "observedIgnore": { + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", + "type": "string" + }, + "observedInclude": { + "description": "ObservedInclude is the observed list of GitRepository resources used to\nto produce the current Artifact.", + "items": { + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", + "properties": { + "fromPath": { + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", + "type": "string" + }, + "repository": { + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "toPath": { + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", + "type": "string" + } + }, + "required": [ + "repository" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "observedRecurseSubmodules": { + "description": "ObservedRecurseSubmodules is the observed resource submodules\nconfiguration used to produce the current Artifact.", + "type": "boolean" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nGitRepositoryStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1.HelmChart": { + "description": "HelmChart is the Schema for the helmcharts API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmChart" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmChartSpec specifies the desired state of a Helm chart.", + "properties": { + "chart": { + "description": "Chart is the name or path the Helm chart is available at in the\nSourceRef.", + "type": "string" + }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values\nfiles rather than failing.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the HelmChart SourceRef is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "ReconcileStrategy determines what enables the creation of a new artifact.\nValid values are ('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "SourceRef is the reference to the Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository',\n'Bucket').", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nsource.", + "type": "boolean" + }, + "valuesFiles": { + "description": "ValuesFiles is an alternative list of values files to use as the chart\nvalues (values.yaml is not included by default), expected to be a\nrelative path in the SourceRef.\nValues files are merged in the order of this list with the last file\noverriding the first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported when using HelmRepository source with spec.type 'oci'.\nChart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", + "properties": { + "matchOIDCIdentity": { + "description": "MatchOIDCIdentity specifies the identity matching criteria to use\nwhile verifying an OCI artifact which was signed using Cosign keyless\nsigning. The artifact's identity is deemed to be verified if any of the\nspecified matchers match against the identity.", + "items": { + "description": "OIDCIdentityMatch specifies options for verifying the certificate identity,\ni.e. the issuer and the subject of the certificate.", + "properties": { + "issuer": { + "description": "Issuer specifies the regex pattern to match against to verify\nthe OIDC issuer in the Fulcio certificate. The pattern must be a\nvalid Go regular expression.", + "type": "string" + }, + "subject": { + "description": "Subject specifies the regex pattern to match against to verify\nthe identity subject in the Fulcio certificate. The pattern must\nbe a valid Go regular expression.", + "type": "string" + } + }, + "required": [ + "issuer", + "subject" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Artifact.", + "enum": [ + "cosign", + "notation" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "version": { + "default": "*", + "description": "Version is the chart version semver expression, ignored for charts from\nGitRepository and Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "interval", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmChartStatus records the observed state of the HelmChart.", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmChart.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedChartName": { + "description": "ObservedChartName is the last observed chart name as specified by the\nresolved chart reference.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the HelmChart\nobject.", + "format": "int64", + "type": "integer" + }, + "observedSourceArtifactRevision": { + "description": "ObservedSourceArtifactRevision is the last observed Artifact.Revision\nof the HelmChartSpec.SourceRef.", + "type": "string" + }, + "observedValuesFiles": { + "description": "ObservedValuesFiles are the observed value files of the last successful\nreconciliation.\nIt matches the chart in the last successfully reconciled artifact.", + "items": { + "type": "string" + }, + "type": "array" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nBucketStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta1.HelmChart": { + "description": "HelmChart is the Schema for the helmcharts API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmChart" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmChartSpec defines the desired state of a Helm chart.", + "properties": { + "accessFrom": { + "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "chart": { + "description": "The name or path the Helm chart is available at in the SourceRef.", + "type": "string" + }, + "interval": { + "description": "The interval at which to check the Source for updates.", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "The reference to the Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository',\n'Bucket').", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend the reconciliation of this source.", + "type": "boolean" + }, + "valuesFile": { + "description": "Alternative values file to use as the default chart values, expected to\nbe a relative path in the SourceRef. Deprecated in favor of ValuesFiles,\nfor backwards compatibility the file defined here is merged before the\nValuesFiles items. Ignored when omitted.", + "type": "string" + }, + "valuesFiles": { + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "version": { + "default": "*", + "description": "The chart version semver expression, ignored for charts from GitRepository\nand Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "interval", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmChartStatus defines the observed state of the HelmChart.", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful chart sync.", + "properties": { + "checksum": { + "description": "Checksum is the SHA256 checksum of the artifact.", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", + "format": "date-time", + "type": "string" + }, + "path": { + "description": "Path is the relative file path of this artifact.", + "type": "string" + }, + "revision": { + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", + "type": "string" + }, + "url": { + "description": "URL is the HTTP address of this artifact.", + "type": "string" + } + }, + "required": [ + "path", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmChart.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the download link for the last chart pulled.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta2.HelmChart": { + "description": "HelmChart is the Schema for the helmcharts API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmChart" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmChartSpec specifies the desired state of a Helm chart.", + "properties": { + "accessFrom": { + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "chart": { + "description": "Chart is the name or path the Helm chart is available at in the\nSourceRef.", + "type": "string" + }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values\nfiles rather than failing.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the HelmChart SourceRef is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "ReconcileStrategy determines what enables the creation of a new artifact.\nValid values are ('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "SourceRef is the reference to the Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository',\n'Bucket').", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nsource.", + "type": "boolean" + }, + "valuesFile": { + "description": "ValuesFile is an alternative values file to use as the default chart\nvalues, expected to be a relative path in the SourceRef. Deprecated in\nfavor of ValuesFiles, for backwards compatibility the file specified here\nis merged before the ValuesFiles items. Ignored when omitted.", + "type": "string" + }, + "valuesFiles": { + "description": "ValuesFiles is an alternative list of values files to use as the chart\nvalues (values.yaml is not included by default), expected to be a\nrelative path in the SourceRef.\nValues files are merged in the order of this list with the last file\noverriding the first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported when using HelmRepository source with spec.type 'oci'.\nChart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", + "properties": { + "matchOIDCIdentity": { + "description": "MatchOIDCIdentity specifies the identity matching criteria to use\nwhile verifying an OCI artifact which was signed using Cosign keyless\nsigning. The artifact's identity is deemed to be verified if any of the\nspecified matchers match against the identity.", + "items": { + "description": "OIDCIdentityMatch specifies options for verifying the certificate identity,\ni.e. the issuer and the subject of the certificate.", + "properties": { + "issuer": { + "description": "Issuer specifies the regex pattern to match against to verify\nthe OIDC issuer in the Fulcio certificate. The pattern must be a\nvalid Go regular expression.", + "type": "string" + }, + "subject": { + "description": "Subject specifies the regex pattern to match against to verify\nthe identity subject in the Fulcio certificate. The pattern must\nbe a valid Go regular expression.", + "type": "string" + } + }, + "required": [ + "issuer", + "subject" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Artifact.", + "enum": [ + "cosign", + "notation" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "version": { + "default": "*", + "description": "Version is the chart version semver expression, ignored for charts from\nGitRepository and Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "interval", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmChartStatus records the observed state of the HelmChart.", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmChart.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedChartName": { + "description": "ObservedChartName is the last observed chart name as specified by the\nresolved chart reference.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the HelmChart\nobject.", + "format": "int64", + "type": "integer" + }, + "observedSourceArtifactRevision": { + "description": "ObservedSourceArtifactRevision is the last observed Artifact.Revision\nof the HelmChartSpec.SourceRef.", + "type": "string" + }, + "observedValuesFiles": { + "description": "ObservedValuesFiles are the observed value files of the last successful\nreconciliation.\nIt matches the chart in the last successfully reconciled artifact.", + "items": { + "type": "string" + }, + "type": "array" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nBucketStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "helm.toolkit.fluxcd.io.v2.HelmRelease": { + "description": "HelmRelease is the Schema for the helmreleases API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "helm.toolkit.fluxcd.io/v2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmRelease" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmReleaseSpec defines the desired state of a Helm release.", + "properties": { + "chart": { + "description": "Chart defines the template of the v1.HelmChart that should be created\nfor this HelmRelease.", + "properties": { + "metadata": { + "description": "ObjectMeta holds the template for metadata like labels and annotations.", + "properties": { + "annotations": { + "additionalProperties": { + "type": "string" + }, + "description": "Annotations is an unstructured key value map stored with a resource that may be\nset by external tools to store and retrieve arbitrary metadata. They are not\nqueryable and should be preserved when modifying objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", + "type": "object" + }, + "labels": { + "additionalProperties": { + "type": "string" + }, + "description": "Map of string keys and values that can be used to organize and categorize\n(scope and select) objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "spec": { + "description": "Spec holds the template for the v1.HelmChartSpec for this HelmRelease.", + "properties": { + "chart": { + "description": "The name or path the Helm chart is available at in the SourceRef.", + "maxLength": 2048, + "minLength": 1, + "type": "string" + }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values files rather than failing.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which to check the v1.Source for updates. Defaults to\n'HelmReleaseSpec.Interval'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "The name and namespace of the v1.Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "valuesFiles": { + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported for OCI sources.\nChart dependencies, which are not bundled in the umbrella chart artifact,\nare not verified.", + "properties": { + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Helm chart.", + "enum": [ + "cosign", + "notation" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "version": { + "default": "*", + "description": "Version semver expression, ignored for charts from v1.GitRepository and\nv1beta2.Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "spec" + ], + "type": "object", + "additionalProperties": false + }, + "chartRef": { + "description": "ChartRef holds a reference to a source controller resource containing the\nHelm chart artifact.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "HelmChart" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "dependsOn": { + "description": "DependsOn may contain a meta.NamespacedObjectReference slice with\nreferences to HelmRelease resources that must be ready before this HelmRelease\ncan be reconciled.", + "items": { + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "driftDetection": { + "description": "DriftDetection holds the configuration for detecting and handling\ndifferences between the manifest in the Helm storage and the resources\ncurrently existing in the cluster.", + "properties": { + "ignore": { + "description": "Ignore contains a list of rules for specifying which changes to ignore\nduring diffing.", + "items": { + "description": "IgnoreRule defines a rule to selectively disregard specific changes during\nthe drift detection process.", + "properties": { + "paths": { + "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from\nconsideration in a Kubernetes object.", + "items": { + "type": "string" + }, + "type": "array" + }, + "target": { + "description": "Target is a selector for specifying Kubernetes objects to which this\nrule applies.\nIf Target is not set, the Paths will be ignored for all Kubernetes\nobjects within the manifest of the Helm release.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "paths" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "mode": { + "description": "Mode defines how differences should be handled between the Helm manifest\nand the manifest currently applied to the cluster.\nIf not explicitly set, it defaults to DiffModeDisabled.", + "enum": [ + "enabled", + "warn", + "disabled" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "install": { + "description": "Install holds the configuration for Helm install actions for this HelmRelease.", + "properties": { + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Create` and if omitted\nCRDs are installed but not updated.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are applied (installed) during Helm install action.\nWith this option users can opt in to CRD replace existing CRDs on Helm\ninstall actions, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "createNamespace": { + "description": "CreateNamespace tells the Helm install action to create the\nHelmReleaseSpec.TargetNamespace if it does not exist yet.\nOn uninstall, the namespace will not be garbage collected.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm install action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm install action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm install\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an install action but fail. Defaults to\n'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false'.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using an uninstall, is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + }, + "replace": { + "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only\nif that name is a deleted release which remains in the history.", + "type": "boolean" + }, + "skipCRDs": { + "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default,\nCRDs are installed if not already present.\n\n\nDeprecated use CRD policy (`crds`) attribute with value `Skip` instead.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm install action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "Interval at which to reconcile the Helm release.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "kubeConfig": { + "description": "KubeConfig for reconciling the HelmRelease on a remote cluster.\nWhen used in combination with HelmReleaseSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when HelmReleaseSpec.ServiceAccountName\nis empty.", + "properties": { + "secretRef": { + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", + "properties": { + "key": { + "description": "Key in the Secret, when not specified an implementation-specific default key is used.", + "type": "string" + }, + "name": { + "description": "Name of the Secret.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "secretRef" + ], + "type": "object", + "additionalProperties": false + }, + "maxHistory": { + "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease.\nUse '0' for an unlimited number of revisions; defaults to '5'.", + "type": "integer" + }, + "persistentClient": { + "description": "PersistentClient tells the controller to use a persistent Kubernetes\nclient for this release. When enabled, the client will be reused for the\nduration of the reconciliation, instead of being created and destroyed\nfor each (step of a) Helm action.\n\n\nThis can improve performance, but may cause issues with some Helm charts\nthat for example do create Custom Resource Definitions during installation\noutside Helm's CRD lifecycle hooks, which are then not observed to be\navailable by e.g. post-install hooks.\n\n\nIf not set, it defaults to true.", + "type": "boolean" + }, + "postRenderers": { + "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order\nof their definition.", + "items": { + "description": "PostRenderer contains a Helm PostRenderer specification.", + "properties": { + "kustomize": { + "description": "Kustomization to apply as PostRenderer.", + "properties": { + "images": { + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", + "items": { + "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", + "properties": { + "digest": { + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", + "type": "string" + }, + "name": { + "description": "Name is a tag-less image name.", + "type": "string" + }, + "newName": { + "description": "NewName is the value used to replace the original name.", + "type": "string" + }, + "newTag": { + "description": "NewTag is the value used to replace the original tag.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patches": { + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", + "items": { + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", + "properties": { + "patch": { + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", + "type": "string" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "releaseName": { + "description": "ReleaseName used for the Helm release. Defaults to a composition of\n'[TargetNamespace-]Name'.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "rollback": { + "description": "Rollback holds the configuration for Helm rollback actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nrollback action when it fails.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "recreate": { + "description": "Recreate performs pod restarts for the resource if applicable.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm rollback action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "serviceAccountName": { + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this HelmRelease.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace used for the Helm storage.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "suspend": { + "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease,\nit does not apply to already started reconciliations. Defaults to false.", + "type": "boolean" + }, + "targetNamespace": { + "description": "TargetNamespace to target when performing operations for the HelmRelease.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "test": { + "description": "Test holds the configuration for Helm test actions for this HelmRelease.", + "properties": { + "enable": { + "description": "Enable enables Helm test actions for this HelmRelease after an Helm install\nor upgrade action has been performed.", + "type": "boolean" + }, + "filters": { + "description": "Filters is a list of tests to run or exclude from running.", + "items": { + "description": "Filter holds the configuration for individual Helm test filters.", + "properties": { + "exclude": { + "description": "Exclude specifies whether the named test should be excluded.", + "type": "boolean" + }, + "name": { + "description": "Name is the name of the test.", + "maxLength": 253, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "ignoreFailures": { + "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests\nare run but fail. Can be overwritten for tests run after install or upgrade\nactions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation during\nthe performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs\nfor hooks) during the performance of a Helm action. Defaults to '5m0s'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "uninstall": { + "description": "Uninstall holds the configuration for Helm uninstall actions for this HelmRelease.", + "properties": { + "deletionPropagation": { + "default": "background", + "description": "DeletionPropagation specifies the deletion propagation policy when\na Helm uninstall is performed.", + "enum": [ + "background", + "foreground", + "orphan" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables waiting for all the resources to be deleted after\na Helm uninstall is performed.", + "type": "boolean" + }, + "keepHistory": { + "description": "KeepHistory tells Helm to remove all associated resources and mark the\nrelease as deleted, but retain the release history.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm uninstall action. Defaults\nto 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "upgrade": { + "description": "Upgrade holds the configuration for Helm upgrade actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nupgrade action when it fails.", + "type": "boolean" + }, + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Skip` and if omitted\nCRDs are neither installed nor upgraded.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are not applied during Helm upgrade action. With this\noption users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm upgrade action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "preserveValues": { + "description": "PreserveValues will make Helm reuse the last release's values and merge in\noverrides from 'Values'. Setting this flag makes the HelmRelease\nnon-declarative.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm upgrade\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an upgrade action but fail.\nDefaults to 'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using 'Strategy', is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + }, + "strategy": { + "description": "Strategy to use for failure remediation. Defaults to 'rollback'.", + "enum": [ + "rollback", + "uninstall" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm upgrade action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "values": { + "description": "Values holds the values for this Helm release.", + "x-kubernetes-preserve-unknown-fields": true + }, + "valuesFrom": { + "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease,\nand information about how they should be merged.", + "items": { + "description": "ValuesReference contains a reference to a resource containing Helm values,\nand optionally the key they can be found at.", + "properties": { + "kind": { + "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", + "enum": [ + "Secret", + "ConfigMap" + ], + "type": "string" + }, + "name": { + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "optional": { + "description": "Optional marks this ValuesReference as optional. When set, a not found error\nfor the values reference is ignored, but any ValuesKey, TargetPath or\ntransient error will still result in a reconciliation failure.", + "type": "boolean" + }, + "targetPath": { + "description": "TargetPath is the YAML dot notation path the value should be merged at. When\nset, the ValuesKey is expected to be a single flat value. Defaults to 'None',\nwhich results in the values getting merged at the root.", + "maxLength": 250, + "pattern": "^([a-zA-Z0-9_\\-.\\\\\\/]|\\[[0-9]{1,5}\\])+$", + "type": "string" + }, + "valuesKey": { + "description": "ValuesKey is the data key where the values.yaml or a specific value can be\nfound at. Defaults to 'values.yaml'.", + "maxLength": 253, + "pattern": "^[\\-._a-zA-Z0-9]+$", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "interval" + ], + "type": "object", + "x-kubernetes-validations": [ + { + "message": "either chart or chartRef must be set", + "rule": "(has(self.chart) && !has(self.chartRef)) || (!has(self.chart) && has(self.chartRef))" + } + ], + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmReleaseStatus defines the observed state of a HelmRelease.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the HelmRelease.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "failures": { + "description": "Failures is the reconciliation failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "helmChart": { + "description": "HelmChart is the namespaced name of the HelmChart resource created by\nthe controller for the HelmRelease.", + "type": "string" + }, + "history": { + "description": "History holds the history of Helm releases performed for this HelmRelease\nup to the last successfully completed release.", + "items": { + "description": "Snapshot captures a point-in-time copy of the status information for a Helm release,\nas managed by the controller.", + "properties": { + "apiVersion": { + "description": "APIVersion is the API version of the Snapshot.\nProvisional: when the calculation method of the Digest field is changed,\nthis field will be used to distinguish between the old and new methods.", + "type": "string" + }, + "appVersion": { + "description": "AppVersion is the chart app version of the release object in storage.", + "type": "string" + }, + "chartName": { + "description": "ChartName is the chart name of the release object in storage.", + "type": "string" + }, + "chartVersion": { + "description": "ChartVersion is the chart version of the release object in\nstorage.", + "type": "string" + }, + "configDigest": { + "description": "ConfigDigest is the checksum of the config (better known as\n\"values\") of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "deleted": { + "description": "Deleted is when the release was deleted.", + "format": "date-time", + "type": "string" + }, + "digest": { + "description": "Digest is the checksum of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "firstDeployed": { + "description": "FirstDeployed is when the release was first deployed.", + "format": "date-time", + "type": "string" + }, + "lastDeployed": { + "description": "LastDeployed is when the release was last deployed.", + "format": "date-time", + "type": "string" + }, + "name": { + "description": "Name is the name of the release.", + "type": "string" + }, + "namespace": { + "description": "Namespace is the namespace the release is deployed to.", + "type": "string" + }, + "ociDigest": { + "description": "OCIDigest is the digest of the OCI artifact associated with the release.", + "type": "string" + }, + "status": { + "description": "Status is the current state of the release.", + "type": "string" + }, + "testHooks": { + "additionalProperties": { + "description": "TestHookStatus holds the status information for a test hook as observed\nto be run by the controller.", + "properties": { + "lastCompleted": { + "description": "LastCompleted is the time the test hook last completed.", + "format": "date-time", + "type": "string" + }, + "lastStarted": { + "description": "LastStarted is the time the test hook was last started.", + "format": "date-time", + "type": "string" + }, + "phase": { + "description": "Phase the test hook was observed to be in.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "description": "TestHooks is the list of test hooks for the release as observed to be\nrun by the controller.", + "type": "object" + }, + "version": { + "description": "Version is the version of the release object in storage.", + "type": "integer" + } + }, + "required": [ + "chartName", + "chartVersion", + "configDigest", + "digest", + "firstDeployed", + "lastDeployed", + "name", + "namespace", + "status", + "version" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "installFailures": { + "description": "InstallFailures is the install failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "lastAttemptedConfigDigest": { + "description": "LastAttemptedConfigDigest is the digest for the config (better known as\n\"values\") of the last reconciliation attempt.", + "type": "string" + }, + "lastAttemptedGeneration": { + "description": "LastAttemptedGeneration is the last generation the controller attempted\nto reconcile.", + "format": "int64", + "type": "integer" + }, + "lastAttemptedReleaseAction": { + "description": "LastAttemptedReleaseAction is the last release action performed for this\nHelmRelease. It is used to determine the active remediation strategy.", + "enum": [ + "install", + "upgrade" + ], + "type": "string" + }, + "lastAttemptedRevision": { + "description": "LastAttemptedRevision is the Source revision of the last reconciliation\nattempt. For OCIRepository sources, the 12 first characters of the digest are\nappended to the chart version e.g. \"1.2.3+1234567890ab\".", + "type": "string" + }, + "lastAttemptedRevisionDigest": { + "description": "LastAttemptedRevisionDigest is the digest of the last reconciliation attempt.\nThis is only set for OCIRepository sources.", + "type": "string" + }, + "lastAttemptedValuesChecksum": { + "description": "LastAttemptedValuesChecksum is the SHA1 checksum for the values of the last\nreconciliation attempt.\nDeprecated: Use LastAttemptedConfigDigest instead.", + "type": "string" + }, + "lastHandledForceAt": { + "description": "LastHandledForceAt holds the value of the most recent force request\nvalue, so a change of the annotation value can be detected.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastHandledResetAt": { + "description": "LastHandledResetAt holds the value of the most recent reset request\nvalue, so a change of the annotation value can be detected.", + "type": "string" + }, + "lastReleaseRevision": { + "description": "LastReleaseRevision is the revision of the last successful Helm release.\nDeprecated: Use History instead.", + "type": "integer" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "observedPostRenderersDigest": { + "description": "ObservedPostRenderersDigest is the digest for the post-renderers of\nthe last successful reconciliation attempt.", + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace is the namespace of the Helm release storage for the\ncurrent release.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "upgradeFailures": { + "description": "UpgradeFailures is the upgrade failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "helm.toolkit.fluxcd.io.v2beta1.HelmRelease": { + "description": "HelmRelease is the Schema for the helmreleases API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "helm.toolkit.fluxcd.io/v2beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmRelease" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmReleaseSpec defines the desired state of a Helm release.", + "properties": { + "chart": { + "description": "Chart defines the template of the v1beta2.HelmChart that should be created\nfor this HelmRelease.", + "properties": { + "metadata": { + "description": "ObjectMeta holds the template for metadata like labels and annotations.", + "properties": { + "annotations": { + "additionalProperties": { + "type": "string" + }, + "description": "Annotations is an unstructured key value map stored with a resource that may be\nset by external tools to store and retrieve arbitrary metadata. They are not\nqueryable and should be preserved when modifying objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", + "type": "object" + }, + "labels": { + "additionalProperties": { + "type": "string" + }, + "description": "Map of string keys and values that can be used to organize and categorize\n(scope and select) objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "spec": { + "description": "Spec holds the template for the v1beta2.HelmChartSpec for this HelmRelease.", + "properties": { + "chart": { + "description": "The name or path the Helm chart is available at in the SourceRef.", + "type": "string" + }, + "interval": { + "description": "Interval at which to check the v1beta2.Source for updates. Defaults to\n'HelmReleaseSpec.Interval'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "The name and namespace of the v1beta2.Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "valuesFile": { + "description": "Alternative values file to use as the default chart values, expected to\nbe a relative path in the SourceRef. Deprecated in favor of ValuesFiles,\nfor backwards compatibility the file defined here is merged before the\nValuesFiles items. Ignored when omitted.", + "type": "string" + }, + "valuesFiles": { + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported for OCI sources.\nChart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", + "properties": { + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Helm chart.", + "enum": [ + "cosign" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "version": { + "default": "*", + "description": "Version semver expression, ignored for charts from v1beta2.GitRepository and\nv1beta2.Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "spec" + ], + "type": "object", + "additionalProperties": false + }, + "chartRef": { + "description": "ChartRef holds a reference to a source controller resource containing the\nHelm chart artifact.\n\n\nNote: this field is provisional to the v2 API, and not actively used\nby v2beta1 HelmReleases.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "HelmChart" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "dependsOn": { + "description": "DependsOn may contain a meta.NamespacedObjectReference slice with\nreferences to HelmRelease resources that must be ready before this HelmRelease\ncan be reconciled.", + "items": { + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "driftDetection": { + "description": "DriftDetection holds the configuration for detecting and handling\ndifferences between the manifest in the Helm storage and the resources\ncurrently existing in the cluster.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "properties": { + "ignore": { + "description": "Ignore contains a list of rules for specifying which changes to ignore\nduring diffing.", + "items": { + "description": "IgnoreRule defines a rule to selectively disregard specific changes during\nthe drift detection process.", + "properties": { + "paths": { + "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from\nconsideration in a Kubernetes object.", + "items": { + "type": "string" + }, + "type": "array" + }, + "target": { + "description": "Target is a selector for specifying Kubernetes objects to which this\nrule applies.\nIf Target is not set, the Paths will be ignored for all Kubernetes\nobjects within the manifest of the Helm release.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "paths" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "mode": { + "description": "Mode defines how differences should be handled between the Helm manifest\nand the manifest currently applied to the cluster.\nIf not explicitly set, it defaults to DiffModeDisabled.", + "enum": [ + "enabled", + "warn", + "disabled" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "install": { + "description": "Install holds the configuration for Helm install actions for this HelmRelease.", + "properties": { + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Create` and if omitted\nCRDs are installed but not updated.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are applied (installed) during Helm install action.\nWith this option users can opt-in to CRD replace existing CRDs on Helm\ninstall actions, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "createNamespace": { + "description": "CreateNamespace tells the Helm install action to create the\nHelmReleaseSpec.TargetNamespace if it does not exist yet.\nOn uninstall, the namespace will not be garbage collected.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm install action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm install action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm install\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an install action but fail. Defaults to\n'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false'.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using an uninstall, is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + }, + "replace": { + "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only\nif that name is a deleted release which remains in the history.", + "type": "boolean" + }, + "skipCRDs": { + "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default,\nCRDs are installed if not already present.\n\n\nDeprecated use CRD policy (`crds`) attribute with value `Skip` instead.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm install action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "Interval at which to reconcile the Helm release.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "kubeConfig": { + "description": "KubeConfig for reconciling the HelmRelease on a remote cluster.\nWhen used in combination with HelmReleaseSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when HelmReleaseSpec.ServiceAccountName\nis empty.", + "properties": { + "secretRef": { + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", + "properties": { + "key": { + "description": "Key in the Secret, when not specified an implementation-specific default key is used.", + "type": "string" + }, + "name": { + "description": "Name of the Secret.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "secretRef" + ], + "type": "object", + "additionalProperties": false + }, + "maxHistory": { + "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease.\nUse '0' for an unlimited number of revisions; defaults to '10'.", + "type": "integer" + }, + "persistentClient": { + "description": "PersistentClient tells the controller to use a persistent Kubernetes\nclient for this release. When enabled, the client will be reused for the\nduration of the reconciliation, instead of being created and destroyed\nfor each (step of a) Helm action.\n\n\nThis can improve performance, but may cause issues with some Helm charts\nthat for example do create Custom Resource Definitions during installation\noutside Helm's CRD lifecycle hooks, which are then not observed to be\navailable by e.g. post-install hooks.\n\n\nIf not set, it defaults to true.", + "type": "boolean" + }, + "postRenderers": { + "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order\nof their definition.", + "items": { + "description": "PostRenderer contains a Helm PostRenderer specification.", + "properties": { + "kustomize": { + "description": "Kustomization to apply as PostRenderer.", + "properties": { + "images": { + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", + "items": { + "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", + "properties": { + "digest": { + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", + "type": "string" + }, + "name": { + "description": "Name is a tag-less image name.", + "type": "string" + }, + "newName": { + "description": "NewName is the value used to replace the original name.", + "type": "string" + }, + "newTag": { + "description": "NewTag is the value used to replace the original tag.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patches": { + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", + "items": { + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", + "properties": { + "patch": { + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", + "type": "string" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesJson6902": { + "description": "JSON 6902 patches, defined as inline YAML objects.", + "items": { + "description": "JSON6902Patch contains a JSON6902 patch and the target the patch should be applied to.", + "properties": { + "patch": { + "description": "Patch contains the JSON6902 patch document with an array of operation objects.", + "items": { + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "properties": { + "from": { + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "type": "string" + }, + "op": { + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "enum": [ + "test", + "remove", + "add", + "replace", + "move", + "copy" + ], + "type": "string" + }, + "path": { + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", + "type": "string" + }, + "value": { + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", + "x-kubernetes-preserve-unknown-fields": true + } + }, + "required": [ + "op", + "path" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch", + "target" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesStrategicMerge": { + "description": "Strategic merge patches, defined as inline YAML objects.", + "items": { + "x-kubernetes-preserve-unknown-fields": true + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "releaseName": { + "description": "ReleaseName used for the Helm release. Defaults to a composition of\n'[TargetNamespace-]Name'.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "rollback": { + "description": "Rollback holds the configuration for Helm rollback actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nrollback action when it fails.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "recreate": { + "description": "Recreate performs pod restarts for the resource if applicable.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm rollback action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "serviceAccountName": { + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this HelmRelease.", + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace used for the Helm storage.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "suspend": { + "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease,\nit does not apply to already started reconciliations. Defaults to false.", + "type": "boolean" + }, + "targetNamespace": { + "description": "TargetNamespace to target when performing operations for the HelmRelease.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "test": { + "description": "Test holds the configuration for Helm test actions for this HelmRelease.", + "properties": { + "enable": { + "description": "Enable enables Helm test actions for this HelmRelease after an Helm install\nor upgrade action has been performed.", + "type": "boolean" + }, + "ignoreFailures": { + "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests\nare run but fail. Can be overwritten for tests run after install or upgrade\nactions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation during\nthe performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs\nfor hooks) during the performance of a Helm action. Defaults to '5m0s'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "uninstall": { + "description": "Uninstall holds the configuration for Helm uninstall actions for this HelmRelease.", + "properties": { + "deletionPropagation": { + "default": "background", + "description": "DeletionPropagation specifies the deletion propagation policy when\na Helm uninstall is performed.", + "enum": [ + "background", + "foreground", + "orphan" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables waiting for all the resources to be deleted after\na Helm uninstall is performed.", + "type": "boolean" + }, + "keepHistory": { + "description": "KeepHistory tells Helm to remove all associated resources and mark the\nrelease as deleted, but retain the release history.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm uninstall action. Defaults\nto 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "upgrade": { + "description": "Upgrade holds the configuration for Helm upgrade actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nupgrade action when it fails.", + "type": "boolean" + }, + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Skip` and if omitted\nCRDs are neither installed nor upgraded.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are not applied during Helm upgrade action. With this\noption users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm upgrade action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "preserveValues": { + "description": "PreserveValues will make Helm reuse the last release's values and merge in\noverrides from 'Values'. Setting this flag makes the HelmRelease\nnon-declarative.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm upgrade\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an upgrade action but fail.\nDefaults to 'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using 'Strategy', is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + }, + "strategy": { + "description": "Strategy to use for failure remediation. Defaults to 'rollback'.", + "enum": [ + "rollback", + "uninstall" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm upgrade action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "values": { + "description": "Values holds the values for this Helm release.", + "x-kubernetes-preserve-unknown-fields": true + }, + "valuesFrom": { + "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease,\nand information about how they should be merged.", + "items": { + "description": "ValuesReference contains a reference to a resource containing Helm values,\nand optionally the key they can be found at.", + "properties": { + "kind": { + "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", + "enum": [ + "Secret", + "ConfigMap" + ], + "type": "string" + }, + "name": { + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "optional": { + "description": "Optional marks this ValuesReference as optional. When set, a not found error\nfor the values reference is ignored, but any ValuesKey, TargetPath or\ntransient error will still result in a reconciliation failure.", + "type": "boolean" + }, + "targetPath": { + "description": "TargetPath is the YAML dot notation path the value should be merged at. When\nset, the ValuesKey is expected to be a single flat value. Defaults to 'None',\nwhich results in the values getting merged at the root.", + "maxLength": 250, + "pattern": "^([a-zA-Z0-9_\\-.\\\\\\/]|\\[[0-9]{1,5}\\])+$", + "type": "string" + }, + "valuesKey": { + "description": "ValuesKey is the data key where the values.yaml or a specific value can be\nfound at. Defaults to 'values.yaml'.\nWhen set, must be a valid Data Key, consisting of alphanumeric characters,\n'-', '_' or '.'.", + "maxLength": 253, + "pattern": "^[\\-._a-zA-Z0-9]+$", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "interval" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmReleaseStatus defines the observed state of a HelmRelease.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the HelmRelease.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "failures": { + "description": "Failures is the reconciliation failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "helmChart": { + "description": "HelmChart is the namespaced name of the HelmChart resource created by\nthe controller for the HelmRelease.", + "type": "string" + }, + "history": { + "description": "History holds the history of Helm releases performed for this HelmRelease\nup to the last successfully completed release.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "items": { + "description": "Snapshot captures a point-in-time copy of the status information for a Helm release,\nas managed by the controller.", + "properties": { + "apiVersion": { + "description": "APIVersion is the API version of the Snapshot.\nProvisional: when the calculation method of the Digest field is changed,\nthis field will be used to distinguish between the old and new methods.", + "type": "string" + }, + "appVersion": { + "description": "AppVersion is the chart app version of the release object in storage.", + "type": "string" + }, + "chartName": { + "description": "ChartName is the chart name of the release object in storage.", + "type": "string" + }, + "chartVersion": { + "description": "ChartVersion is the chart version of the release object in\nstorage.", + "type": "string" + }, + "configDigest": { + "description": "ConfigDigest is the checksum of the config (better known as\n\"values\") of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "deleted": { + "description": "Deleted is when the release was deleted.", + "format": "date-time", + "type": "string" + }, + "digest": { + "description": "Digest is the checksum of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "firstDeployed": { + "description": "FirstDeployed is when the release was first deployed.", + "format": "date-time", + "type": "string" + }, + "lastDeployed": { + "description": "LastDeployed is when the release was last deployed.", + "format": "date-time", + "type": "string" + }, + "name": { + "description": "Name is the name of the release.", + "type": "string" + }, + "namespace": { + "description": "Namespace is the namespace the release is deployed to.", + "type": "string" + }, + "ociDigest": { + "description": "OCIDigest is the digest of the OCI artifact associated with the release.", + "type": "string" + }, + "status": { + "description": "Status is the current state of the release.", + "type": "string" + }, + "testHooks": { + "additionalProperties": { + "description": "TestHookStatus holds the status information for a test hook as observed\nto be run by the controller.", + "properties": { + "lastCompleted": { + "description": "LastCompleted is the time the test hook last completed.", + "format": "date-time", + "type": "string" + }, + "lastStarted": { + "description": "LastStarted is the time the test hook was last started.", + "format": "date-time", + "type": "string" + }, + "phase": { + "description": "Phase the test hook was observed to be in.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "description": "TestHooks is the list of test hooks for the release as observed to be\nrun by the controller.", + "type": "object" + }, + "version": { + "description": "Version is the version of the release object in storage.", + "type": "integer" + } + }, + "required": [ + "chartName", + "chartVersion", + "configDigest", + "digest", + "firstDeployed", + "lastDeployed", + "name", + "namespace", + "status", + "version" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "installFailures": { + "description": "InstallFailures is the install failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "lastAppliedRevision": { + "description": "LastAppliedRevision is the revision of the last successfully applied source.", + "type": "string" + }, + "lastAttemptedConfigDigest": { + "description": "LastAttemptedConfigDigest is the digest for the config (better known as\n\"values\") of the last reconciliation attempt.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "type": "string" + }, + "lastAttemptedGeneration": { + "description": "LastAttemptedGeneration is the last generation the controller attempted\nto reconcile.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "format": "int64", + "type": "integer" + }, + "lastAttemptedReleaseAction": { + "description": "LastAttemptedReleaseAction is the last release action performed for this\nHelmRelease. It is used to determine the active remediation strategy.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "type": "string" + }, + "lastAttemptedRevision": { + "description": "LastAttemptedRevision is the revision of the last reconciliation attempt.", + "type": "string" + }, + "lastAttemptedValuesChecksum": { + "description": "LastAttemptedValuesChecksum is the SHA1 checksum of the values of the last\nreconciliation attempt.", + "type": "string" + }, + "lastHandledForceAt": { + "description": "LastHandledForceAt holds the value of the most recent force request\nvalue, so a change of the annotation value can be detected.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastHandledResetAt": { + "description": "LastHandledResetAt holds the value of the most recent reset request\nvalue, so a change of the annotation value can be detected.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "type": "string" + }, + "lastReleaseRevision": { + "description": "LastReleaseRevision is the revision of the last successful Helm release.", + "type": "integer" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "observedPostRenderersDigest": { + "description": "ObservedPostRenderersDigest is the digest for the post-renderers of\nthe last successful reconciliation attempt.", + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace is the namespace of the Helm release storage for the\ncurrent release.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", + "type": "string" + }, + "upgradeFailures": { + "description": "UpgradeFailures is the upgrade failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "helm.toolkit.fluxcd.io.v2beta2.HelmRelease": { + "description": "HelmRelease is the Schema for the helmreleases API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "helm.toolkit.fluxcd.io/v2beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmRelease" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmReleaseSpec defines the desired state of a Helm release.", + "properties": { + "chart": { + "description": "Chart defines the template of the v1beta2.HelmChart that should be created\nfor this HelmRelease.", + "properties": { + "metadata": { + "description": "ObjectMeta holds the template for metadata like labels and annotations.", + "properties": { + "annotations": { + "additionalProperties": { + "type": "string" + }, + "description": "Annotations is an unstructured key value map stored with a resource that may be\nset by external tools to store and retrieve arbitrary metadata. They are not\nqueryable and should be preserved when modifying objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", + "type": "object" + }, + "labels": { + "additionalProperties": { + "type": "string" + }, + "description": "Map of string keys and values that can be used to organize and categorize\n(scope and select) objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "spec": { + "description": "Spec holds the template for the v1beta2.HelmChartSpec for this HelmRelease.", + "properties": { + "chart": { + "description": "The name or path the Helm chart is available at in the SourceRef.", + "maxLength": 2048, + "minLength": 1, + "type": "string" + }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values files rather than failing.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which to check the v1.Source for updates. Defaults to\n'HelmReleaseSpec.Interval'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "The name and namespace of the v1.Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "valuesFile": { + "description": "Alternative values file to use as the default chart values, expected to\nbe a relative path in the SourceRef. Deprecated in favor of ValuesFiles,\nfor backwards compatibility the file defined here is merged before the\nValuesFiles items. Ignored when omitted.", + "type": "string" + }, + "valuesFiles": { + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported for OCI sources.\nChart dependencies, which are not bundled in the umbrella chart artifact,\nare not verified.", + "properties": { + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Helm chart.", + "enum": [ + "cosign", + "notation" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "version": { + "default": "*", + "description": "Version semver expression, ignored for charts from v1beta2.GitRepository and\nv1beta2.Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "spec" + ], + "type": "object", + "additionalProperties": false + }, + "chartRef": { + "description": "ChartRef holds a reference to a source controller resource containing the\nHelm chart artifact.\n\n\nNote: this field is provisional to the v2 API, and not actively used\nby v2beta2 HelmReleases.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "HelmChart" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "dependsOn": { + "description": "DependsOn may contain a meta.NamespacedObjectReference slice with\nreferences to HelmRelease resources that must be ready before this HelmRelease\ncan be reconciled.", + "items": { + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "driftDetection": { + "description": "DriftDetection holds the configuration for detecting and handling\ndifferences between the manifest in the Helm storage and the resources\ncurrently existing in the cluster.", + "properties": { + "ignore": { + "description": "Ignore contains a list of rules for specifying which changes to ignore\nduring diffing.", + "items": { + "description": "IgnoreRule defines a rule to selectively disregard specific changes during\nthe drift detection process.", + "properties": { + "paths": { + "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from\nconsideration in a Kubernetes object.", + "items": { + "type": "string" + }, + "type": "array" + }, + "target": { + "description": "Target is a selector for specifying Kubernetes objects to which this\nrule applies.\nIf Target is not set, the Paths will be ignored for all Kubernetes\nobjects within the manifest of the Helm release.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "paths" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "mode": { + "description": "Mode defines how differences should be handled between the Helm manifest\nand the manifest currently applied to the cluster.\nIf not explicitly set, it defaults to DiffModeDisabled.", + "enum": [ + "enabled", + "warn", + "disabled" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "install": { + "description": "Install holds the configuration for Helm install actions for this HelmRelease.", + "properties": { + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Create` and if omitted\nCRDs are installed but not updated.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are applied (installed) during Helm install action.\nWith this option users can opt in to CRD replace existing CRDs on Helm\ninstall actions, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "createNamespace": { + "description": "CreateNamespace tells the Helm install action to create the\nHelmReleaseSpec.TargetNamespace if it does not exist yet.\nOn uninstall, the namespace will not be garbage collected.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm install action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm install action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm install\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an install action but fail. Defaults to\n'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false'.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using an uninstall, is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + }, + "replace": { + "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only\nif that name is a deleted release which remains in the history.", + "type": "boolean" + }, + "skipCRDs": { + "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default,\nCRDs are installed if not already present.\n\n\nDeprecated use CRD policy (`crds`) attribute with value `Skip` instead.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm install action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "Interval at which to reconcile the Helm release.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "kubeConfig": { + "description": "KubeConfig for reconciling the HelmRelease on a remote cluster.\nWhen used in combination with HelmReleaseSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when HelmReleaseSpec.ServiceAccountName\nis empty.", + "properties": { + "secretRef": { + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", + "properties": { + "key": { + "description": "Key in the Secret, when not specified an implementation-specific default key is used.", + "type": "string" + }, + "name": { + "description": "Name of the Secret.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "secretRef" + ], + "type": "object", + "additionalProperties": false + }, + "maxHistory": { + "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease.\nUse '0' for an unlimited number of revisions; defaults to '5'.", + "type": "integer" + }, + "persistentClient": { + "description": "PersistentClient tells the controller to use a persistent Kubernetes\nclient for this release. When enabled, the client will be reused for the\nduration of the reconciliation, instead of being created and destroyed\nfor each (step of a) Helm action.\n\n\nThis can improve performance, but may cause issues with some Helm charts\nthat for example do create Custom Resource Definitions during installation\noutside Helm's CRD lifecycle hooks, which are then not observed to be\navailable by e.g. post-install hooks.\n\n\nIf not set, it defaults to true.", + "type": "boolean" + }, + "postRenderers": { + "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order\nof their definition.", + "items": { + "description": "PostRenderer contains a Helm PostRenderer specification.", + "properties": { + "kustomize": { + "description": "Kustomization to apply as PostRenderer.", + "properties": { + "images": { + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", + "items": { + "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", + "properties": { + "digest": { + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", + "type": "string" + }, + "name": { + "description": "Name is a tag-less image name.", + "type": "string" + }, + "newName": { + "description": "NewName is the value used to replace the original name.", + "type": "string" + }, + "newTag": { + "description": "NewTag is the value used to replace the original tag.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patches": { + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", + "items": { + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", + "properties": { + "patch": { + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", + "type": "string" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesJson6902": { + "description": "JSON 6902 patches, defined as inline YAML objects.\nDeprecated: use Patches instead.", + "items": { + "description": "JSON6902Patch contains a JSON6902 patch and the target the patch should be applied to.", + "properties": { + "patch": { + "description": "Patch contains the JSON6902 patch document with an array of operation objects.", + "items": { + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "properties": { + "from": { + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "type": "string" + }, + "op": { + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "enum": [ + "test", + "remove", + "add", + "replace", + "move", + "copy" + ], + "type": "string" + }, + "path": { + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", + "type": "string" + }, + "value": { + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", + "x-kubernetes-preserve-unknown-fields": true + } + }, + "required": [ + "op", + "path" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch", + "target" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesStrategicMerge": { + "description": "Strategic merge patches, defined as inline YAML objects.\nDeprecated: use Patches instead.", + "items": { + "x-kubernetes-preserve-unknown-fields": true + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "releaseName": { + "description": "ReleaseName used for the Helm release. Defaults to a composition of\n'[TargetNamespace-]Name'.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "rollback": { + "description": "Rollback holds the configuration for Helm rollback actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nrollback action when it fails.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "recreate": { + "description": "Recreate performs pod restarts for the resource if applicable.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm rollback action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "serviceAccountName": { + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this HelmRelease.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace used for the Helm storage.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "suspend": { + "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease,\nit does not apply to already started reconciliations. Defaults to false.", + "type": "boolean" + }, + "targetNamespace": { + "description": "TargetNamespace to target when performing operations for the HelmRelease.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "test": { + "description": "Test holds the configuration for Helm test actions for this HelmRelease.", + "properties": { + "enable": { + "description": "Enable enables Helm test actions for this HelmRelease after an Helm install\nor upgrade action has been performed.", + "type": "boolean" + }, + "filters": { + "description": "Filters is a list of tests to run or exclude from running.", + "items": { + "description": "Filter holds the configuration for individual Helm test filters.", + "properties": { + "exclude": { + "description": "Exclude specifies whether the named test should be excluded.", + "type": "boolean" + }, + "name": { + "description": "Name is the name of the test.", + "maxLength": 253, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "ignoreFailures": { + "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests\nare run but fail. Can be overwritten for tests run after install or upgrade\nactions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation during\nthe performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs\nfor hooks) during the performance of a Helm action. Defaults to '5m0s'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "uninstall": { + "description": "Uninstall holds the configuration for Helm uninstall actions for this HelmRelease.", + "properties": { + "deletionPropagation": { + "default": "background", + "description": "DeletionPropagation specifies the deletion propagation policy when\na Helm uninstall is performed.", + "enum": [ + "background", + "foreground", + "orphan" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables waiting for all the resources to be deleted after\na Helm uninstall is performed.", + "type": "boolean" + }, + "keepHistory": { + "description": "KeepHistory tells Helm to remove all associated resources and mark the\nrelease as deleted, but retain the release history.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm uninstall action. Defaults\nto 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "upgrade": { + "description": "Upgrade holds the configuration for Helm upgrade actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nupgrade action when it fails.", + "type": "boolean" + }, + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Skip` and if omitted\nCRDs are neither installed nor upgraded.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are not applied during Helm upgrade action. With this\noption users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm upgrade action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "preserveValues": { + "description": "PreserveValues will make Helm reuse the last release's values and merge in\noverrides from 'Values'. Setting this flag makes the HelmRelease\nnon-declarative.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm upgrade\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an upgrade action but fail.\nDefaults to 'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using 'Strategy', is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + }, + "strategy": { + "description": "Strategy to use for failure remediation. Defaults to 'rollback'.", + "enum": [ + "rollback", + "uninstall" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm upgrade action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "values": { + "description": "Values holds the values for this Helm release.", + "x-kubernetes-preserve-unknown-fields": true + }, + "valuesFrom": { + "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease,\nand information about how they should be merged.", + "items": { + "description": "ValuesReference contains a reference to a resource containing Helm values,\nand optionally the key they can be found at.", + "properties": { + "kind": { + "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", + "enum": [ + "Secret", + "ConfigMap" + ], + "type": "string" + }, + "name": { + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "optional": { + "description": "Optional marks this ValuesReference as optional. When set, a not found error\nfor the values reference is ignored, but any ValuesKey, TargetPath or\ntransient error will still result in a reconciliation failure.", + "type": "boolean" + }, + "targetPath": { + "description": "TargetPath is the YAML dot notation path the value should be merged at. When\nset, the ValuesKey is expected to be a single flat value. Defaults to 'None',\nwhich results in the values getting merged at the root.", + "maxLength": 250, + "pattern": "^([a-zA-Z0-9_\\-.\\\\\\/]|\\[[0-9]{1,5}\\])+$", + "type": "string" + }, + "valuesKey": { + "description": "ValuesKey is the data key where the values.yaml or a specific value can be\nfound at. Defaults to 'values.yaml'.", + "maxLength": 253, + "pattern": "^[\\-._a-zA-Z0-9]+$", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "interval" + ], + "type": "object", + "x-kubernetes-validations": [ + { + "message": "either chart or chartRef must be set", + "rule": "(has(self.chart) && !has(self.chartRef)) || (!has(self.chart) && has(self.chartRef))" + } + ], + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmReleaseStatus defines the observed state of a HelmRelease.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the HelmRelease.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "failures": { + "description": "Failures is the reconciliation failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "helmChart": { + "description": "HelmChart is the namespaced name of the HelmChart resource created by\nthe controller for the HelmRelease.", + "type": "string" + }, + "history": { + "description": "History holds the history of Helm releases performed for this HelmRelease\nup to the last successfully completed release.", + "items": { + "description": "Snapshot captures a point-in-time copy of the status information for a Helm release,\nas managed by the controller.", + "properties": { + "apiVersion": { + "description": "APIVersion is the API version of the Snapshot.\nProvisional: when the calculation method of the Digest field is changed,\nthis field will be used to distinguish between the old and new methods.", + "type": "string" + }, + "appVersion": { + "description": "AppVersion is the chart app version of the release object in storage.", + "type": "string" + }, + "chartName": { + "description": "ChartName is the chart name of the release object in storage.", + "type": "string" + }, + "chartVersion": { + "description": "ChartVersion is the chart version of the release object in\nstorage.", + "type": "string" + }, + "configDigest": { + "description": "ConfigDigest is the checksum of the config (better known as\n\"values\") of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "deleted": { + "description": "Deleted is when the release was deleted.", + "format": "date-time", + "type": "string" + }, + "digest": { + "description": "Digest is the checksum of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "firstDeployed": { + "description": "FirstDeployed is when the release was first deployed.", + "format": "date-time", + "type": "string" + }, + "lastDeployed": { + "description": "LastDeployed is when the release was last deployed.", + "format": "date-time", + "type": "string" + }, + "name": { + "description": "Name is the name of the release.", + "type": "string" + }, + "namespace": { + "description": "Namespace is the namespace the release is deployed to.", + "type": "string" + }, + "ociDigest": { + "description": "OCIDigest is the digest of the OCI artifact associated with the release.", + "type": "string" + }, + "status": { + "description": "Status is the current state of the release.", + "type": "string" + }, + "testHooks": { + "additionalProperties": { + "description": "TestHookStatus holds the status information for a test hook as observed\nto be run by the controller.", + "properties": { + "lastCompleted": { + "description": "LastCompleted is the time the test hook last completed.", + "format": "date-time", + "type": "string" + }, + "lastStarted": { + "description": "LastStarted is the time the test hook was last started.", + "format": "date-time", + "type": "string" + }, + "phase": { + "description": "Phase the test hook was observed to be in.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "description": "TestHooks is the list of test hooks for the release as observed to be\nrun by the controller.", + "type": "object" + }, + "version": { + "description": "Version is the version of the release object in storage.", + "type": "integer" + } + }, + "required": [ + "chartName", + "chartVersion", + "configDigest", + "digest", + "firstDeployed", + "lastDeployed", + "name", + "namespace", + "status", + "version" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "installFailures": { + "description": "InstallFailures is the install failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "lastAppliedRevision": { + "description": "LastAppliedRevision is the revision of the last successfully applied\nsource.\nDeprecated: the revision can now be found in the History.", + "type": "string" + }, + "lastAttemptedConfigDigest": { + "description": "LastAttemptedConfigDigest is the digest for the config (better known as\n\"values\") of the last reconciliation attempt.", + "type": "string" + }, + "lastAttemptedGeneration": { + "description": "LastAttemptedGeneration is the last generation the controller attempted\nto reconcile.", + "format": "int64", + "type": "integer" + }, + "lastAttemptedReleaseAction": { + "description": "LastAttemptedReleaseAction is the last release action performed for this\nHelmRelease. It is used to determine the active remediation strategy.", + "enum": [ + "install", + "upgrade" + ], + "type": "string" + }, + "lastAttemptedRevision": { + "description": "LastAttemptedRevision is the Source revision of the last reconciliation\nattempt. For OCIRepository sources, the 12 first characters of the digest are\nappended to the chart version e.g. \"1.2.3+1234567890ab\".", + "type": "string" + }, + "lastAttemptedRevisionDigest": { + "description": "LastAttemptedRevisionDigest is the digest of the last reconciliation attempt.\nThis is only set for OCIRepository sources.", + "type": "string" + }, + "lastAttemptedValuesChecksum": { + "description": "LastAttemptedValuesChecksum is the SHA1 checksum for the values of the last\nreconciliation attempt.\nDeprecated: Use LastAttemptedConfigDigest instead.", + "type": "string" + }, + "lastHandledForceAt": { + "description": "LastHandledForceAt holds the value of the most recent force request\nvalue, so a change of the annotation value can be detected.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastHandledResetAt": { + "description": "LastHandledResetAt holds the value of the most recent reset request\nvalue, so a change of the annotation value can be detected.", + "type": "string" + }, + "lastReleaseRevision": { + "description": "LastReleaseRevision is the revision of the last successful Helm release.\nDeprecated: Use History instead.", + "type": "integer" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "observedPostRenderersDigest": { + "description": "ObservedPostRenderersDigest is the digest for the post-renderers of\nthe last successful reconciliation attempt.", + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace is the namespace of the Helm release storage for the\ncurrent release.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "upgradeFailures": { + "description": "UpgradeFailures is the upgrade failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1.HelmRepository": { + "description": "HelmRepository is the Schema for the helmrepositories API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmRepositorySpec specifies the required configuration to produce an\nArtifact for a Helm repository index YAML.", + "properties": { + "accessFrom": { + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "certSecretRef": { + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nIt takes precedence over the values specified in the Secret referred\nto by `.spec.secretRef`.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "insecure": { + "description": "Insecure allows connecting to a non-TLS HTTP container registry.\nThis field is only taken into account if the .spec.type field is set to 'oci'.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the HelmRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "passCredentials": { + "description": "PassCredentials allows the credentials from the SecretRef to be passed\non to a host that does not match the host as defined in URL.\nThis may be required if the host of the advertised chart URLs in the\nindex differ from the defined URL.\nEnabling this should be done with caution, as it can potentially result\nin credentials getting stolen in a MITM-attack.", + "type": "boolean" + }, + "provider": { + "default": "generic", + "description": "Provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nThis field is optional, and only taken into account if the .spec.type field is set to 'oci'.\nWhen not specified, defaults to 'generic'.", + "enum": [ + "generic", + "aws", + "azure", + "gcp" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing authentication credentials\nfor the HelmRepository.\nFor HTTP/S basic auth the secret must contain 'username' and 'password'\nfields.\nSupport for TLS auth using the 'certFile' and 'keyFile', and/or 'caFile'\nkeys is deprecated. Please use `.spec.certSecretRef` instead.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nHelmRepository.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is used for the index fetch operation for an HTTPS helm repository,\nand for remote OCI Repository operations like pulling for an OCI helm\nchart by the associated HelmChart.\nIts default value is 60s.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "type": { + "description": "Type of the HelmRepository.\nWhen this field is set to \"oci\", the URL field value must be prefixed with \"oci://\".", + "enum": [ + "default", + "oci" + ], + "type": "string" + }, + "url": { + "description": "URL of the Helm repository, a valid URL contains at least a protocol and\nhost.", + "pattern": "^(http|https|oci)://.*$", + "type": "string" + } + }, + "required": [ + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmRepositoryStatus records the observed state of the HelmRepository.", + "properties": { + "artifact": { + "description": "Artifact represents the last successful HelmRepository reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the HelmRepository\nobject.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nHelmRepositoryStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta1.HelmRepository": { + "description": "HelmRepository is the Schema for the helmrepositories API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmRepositorySpec defines the reference to a Helm repository.", + "properties": { + "accessFrom": { + "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "The interval at which to check the upstream for updates.", + "type": "string" + }, + "passCredentials": { + "description": "PassCredentials allows the credentials from the SecretRef to be passed on to\na host that does not match the host as defined in URL.\nThis may be required if the host of the advertised chart URLs in the index\ndiffer from the defined URL.\nEnabling this should be done with caution, as it can potentially result in\ncredentials getting stolen in a MITM-attack.", + "type": "boolean" + }, + "secretRef": { + "description": "The name of the secret containing authentication credentials for the Helm\nrepository.\nFor HTTP/S basic auth the secret must contain username and\npassword fields.\nFor TLS the secret must contain a certFile and keyFile, and/or\ncaFile fields.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend the reconciliation of this source.", + "type": "boolean" + }, + "timeout": { + "default": "60s", + "description": "The timeout of index downloading, defaults to 60s.", + "type": "string" + }, + "url": { + "description": "The Helm repository URL, a valid URL contains at least a protocol and host.", + "type": "string" + } + }, + "required": [ + "interval", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmRepositoryStatus defines the observed state of the HelmRepository.", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful repository sync.", + "properties": { + "checksum": { + "description": "Checksum is the SHA256 checksum of the artifact.", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", + "format": "date-time", + "type": "string" + }, + "path": { + "description": "Path is the relative file path of this artifact.", + "type": "string" + }, + "revision": { + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", + "type": "string" + }, + "url": { + "description": "URL is the HTTP address of this artifact.", + "type": "string" + } + }, + "required": [ + "path", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the download link for the last index fetched.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta2.HelmRepository": { + "description": "HelmRepository is the Schema for the helmrepositories API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "HelmRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmRepositorySpec specifies the required configuration to produce an\nArtifact for a Helm repository index YAML.", + "properties": { + "accessFrom": { + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "certSecretRef": { + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nIt takes precedence over the values specified in the Secret referred\nto by `.spec.secretRef`.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "insecure": { + "description": "Insecure allows connecting to a non-TLS HTTP container registry.\nThis field is only taken into account if the .spec.type field is set to 'oci'.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the HelmRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "passCredentials": { + "description": "PassCredentials allows the credentials from the SecretRef to be passed\non to a host that does not match the host as defined in URL.\nThis may be required if the host of the advertised chart URLs in the\nindex differ from the defined URL.\nEnabling this should be done with caution, as it can potentially result\nin credentials getting stolen in a MITM-attack.", + "type": "boolean" + }, + "provider": { + "default": "generic", + "description": "Provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nThis field is optional, and only taken into account if the .spec.type field is set to 'oci'.\nWhen not specified, defaults to 'generic'.", + "enum": [ + "generic", + "aws", + "azure", + "gcp" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing authentication credentials\nfor the HelmRepository.\nFor HTTP/S basic auth the secret must contain 'username' and 'password'\nfields.\nSupport for TLS auth using the 'certFile' and 'keyFile', and/or 'caFile'\nkeys is deprecated. Please use `.spec.certSecretRef` instead.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nHelmRepository.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is used for the index fetch operation for an HTTPS helm repository,\nand for remote OCI Repository operations like pulling for an OCI helm\nchart by the associated HelmChart.\nIts default value is 60s.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "type": { + "description": "Type of the HelmRepository.\nWhen this field is set to \"oci\", the URL field value must be prefixed with \"oci://\".", + "enum": [ + "default", + "oci" + ], + "type": "string" + }, + "url": { + "description": "URL of the Helm repository, a valid URL contains at least a protocol and\nhost.", + "pattern": "^(http|https|oci)://.*$", + "type": "string" + } + }, + "required": [ + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmRepositoryStatus records the observed state of the HelmRepository.", + "properties": { + "artifact": { + "description": "Artifact represents the last successful HelmRepository reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the HelmRepository\nobject.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nHelmRepositoryStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "image.toolkit.fluxcd.io.v1beta1.ImagePolicy": { + "description": "ImagePolicy is the Schema for the imagepolicies API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "image.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "ImagePolicy" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ImagePolicySpec defines the parameters for calculating the\nImagePolicy", + "properties": { + "filterTags": { + "description": "FilterTags enables filtering for only a subset of tags based on a set of\nrules. If no rules are provided, all the tags from the repository will be\nordered and compared.", + "properties": { + "extract": { + "description": "Extract allows a capture group to be extracted from the specified regular\nexpression pattern, useful before tag evaluation.", + "type": "string" + }, + "pattern": { + "description": "Pattern specifies a regular expression pattern used to filter for image\ntags.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "imageRepositoryRef": { + "description": "ImageRepositoryRef points at the object specifying the image\nbeing scanned", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "policy": { + "description": "Policy gives the particulars of the policy to be followed in\nselecting the most recent image", + "properties": { + "alphabetical": { + "description": "Alphabetical set of rules to use for alphabetical ordering of the tags.", + "properties": { + "order": { + "default": "asc", + "description": "Order specifies the sorting order of the tags. Given the letters of the\nalphabet as tags, ascending order would select Z, and descending order\nwould select A.", + "enum": [ + "asc", + "desc" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "numerical": { + "description": "Numerical set of rules to use for numerical ordering of the tags.", + "properties": { + "order": { + "default": "asc", + "description": "Order specifies the sorting order of the tags. Given the integer values\nfrom 0 to 9 as tags, ascending order would select 9, and descending order\nwould select 0.", + "enum": [ + "asc", + "desc" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "semver": { + "description": "SemVer gives a semantic version range to check against the tags\navailable.", + "properties": { + "range": { + "description": "Range gives a semver range for the image tag; the highest\nversion within the range that's a tag yields the latest image.", + "type": "string" + } + }, + "required": [ + "range" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "imageRepositoryRef", + "policy" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ImagePolicyStatus defines the observed state of ImagePolicy", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "latestImage": { + "description": "LatestImage gives the first in the list of images scanned by\nthe image repository, when filtered and ordered according to\nthe policy.", + "type": "string" + }, + "observedGeneration": { + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "image.toolkit.fluxcd.io.v1beta2.ImagePolicy": { + "description": "ImagePolicy is the Schema for the imagepolicies API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "image.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "ImagePolicy" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ImagePolicySpec defines the parameters for calculating the\nImagePolicy.", + "properties": { + "filterTags": { + "description": "FilterTags enables filtering for only a subset of tags based on a set of\nrules. If no rules are provided, all the tags from the repository will be\nordered and compared.", + "properties": { + "extract": { + "description": "Extract allows a capture group to be extracted from the specified regular\nexpression pattern, useful before tag evaluation.", + "type": "string" + }, + "pattern": { + "description": "Pattern specifies a regular expression pattern used to filter for image\ntags.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "imageRepositoryRef": { + "description": "ImageRepositoryRef points at the object specifying the image\nbeing scanned", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "policy": { + "description": "Policy gives the particulars of the policy to be followed in\nselecting the most recent image", + "properties": { + "alphabetical": { + "description": "Alphabetical set of rules to use for alphabetical ordering of the tags.", + "properties": { + "order": { + "default": "asc", + "description": "Order specifies the sorting order of the tags. Given the letters of the\nalphabet as tags, ascending order would select Z, and descending order\nwould select A.", + "enum": [ + "asc", + "desc" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "numerical": { + "description": "Numerical set of rules to use for numerical ordering of the tags.", + "properties": { + "order": { + "default": "asc", + "description": "Order specifies the sorting order of the tags. Given the integer values\nfrom 0 to 9 as tags, ascending order would select 9, and descending order\nwould select 0.", + "enum": [ + "asc", + "desc" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "semver": { + "description": "SemVer gives a semantic version range to check against the tags\navailable.", + "properties": { + "range": { + "description": "Range gives a semver range for the image tag; the highest\nversion within the range that's a tag yields the latest image.", + "type": "string" + } + }, + "required": [ + "range" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "imageRepositoryRef", + "policy" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ImagePolicyStatus defines the observed state of ImagePolicy", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "latestImage": { + "description": "LatestImage gives the first in the list of images scanned by\nthe image repository, when filtered and ordered according to\nthe policy.", + "type": "string" + }, + "observedGeneration": { + "format": "int64", + "type": "integer" + }, + "observedPreviousImage": { + "description": "ObservedPreviousImage is the observed previous LatestImage. It is used\nto keep track of the previous and current images.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "image.toolkit.fluxcd.io.v1beta1.ImageRepository": { + "description": "ImageRepository is the Schema for the imagerepositories API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "image.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "ImageRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ImageRepositorySpec defines the parameters for scanning an image\nrepository, e.g., `fluxcd/flux`.", + "properties": { + "accessFrom": { + "description": "AccessFrom defines an ACL for allowing cross-namespace references\nto the ImageRepository object based on the caller's namespace labels.", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "certSecretRef": { + "description": "CertSecretRef can be given the name of a secret containing\neither or both of\n\n\n - a PEM-encoded client certificate (`certFile`) and private\n key (`keyFile`);\n - a PEM-encoded CA certificate (`caFile`)\n\n\n and whichever are supplied, will be used for connecting to the\n registry. The client cert and key are useful if you are\n authenticating with a certificate; the CA cert is useful if\n you are using a self-signed server certificate.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "exclusionList": { + "description": "ExclusionList is a list of regex strings used to exclude certain tags\nfrom being stored in the database.", + "items": { + "type": "string" + }, + "type": "array" + }, + "image": { + "description": "Image is the name of the image repository", + "type": "string" + }, + "interval": { + "description": "Interval is the length of time to wait between\nscans of the image repository.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "secretRef": { + "description": "SecretRef can be given the name of a secret containing\ncredentials to use for the image registry. The secret should be\ncreated with `kubectl create secret docker-registry`, or the\nequivalent.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "serviceAccountName": { + "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate\nthe image pull if the service account has attached pull secrets.", + "maxLength": 253, + "type": "string" + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent image scans.\nIt does not apply to already started scans. Defaults to false.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout for image scanning.\nDefaults to 'Interval' duration.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ImageRepositoryStatus defines the observed state of ImageRepository", + "properties": { + "canonicalImageName": { + "description": "CanonicalName is the name of the image repository with all the\nimplied bits made explicit; e.g., `docker.io/library/alpine`\nrather than `alpine`.", + "type": "string" + }, + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastScanResult": { + "description": "LastScanResult contains the number of fetched tags.", + "properties": { + "scanTime": { + "format": "date-time", + "type": "string" + }, + "tagCount": { + "type": "integer" + } + }, + "required": [ + "tagCount" + ], + "type": "object", + "additionalProperties": false + }, + "observedGeneration": { + "description": "ObservedGeneration is the last reconciled generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "image.toolkit.fluxcd.io.v1beta2.ImageRepository": { + "description": "ImageRepository is the Schema for the imagerepositories API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "image.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "ImageRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ImageRepositorySpec defines the parameters for scanning an image\nrepository, e.g., `fluxcd/flux`.", + "properties": { + "accessFrom": { + "description": "AccessFrom defines an ACL for allowing cross-namespace references\nto the ImageRepository object based on the caller's namespace labels.", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "certSecretRef": { + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nNote: Support for the `caFile`, `certFile` and `keyFile` keys has\nbeen deprecated.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "exclusionList": { + "default": [ + "^.*\\.sig$" + ], + "description": "ExclusionList is a list of regex strings used to exclude certain tags\nfrom being stored in the database.", + "items": { + "type": "string" + }, + "maxItems": 25, + "type": "array" + }, + "image": { + "description": "Image is the name of the image repository", + "type": "string" + }, + "insecure": { + "description": "Insecure allows connecting to a non-TLS HTTP container registry.", + "type": "boolean" + }, + "interval": { + "description": "Interval is the length of time to wait between\nscans of the image repository.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "provider": { + "default": "generic", + "description": "The provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nWhen not specified, defaults to 'generic'.", + "enum": [ + "generic", + "aws", + "azure", + "gcp" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef can be given the name of a secret containing\ncredentials to use for the image registry. The secret should be\ncreated with `kubectl create secret docker-registry`, or the\nequivalent.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "serviceAccountName": { + "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate\nthe image pull if the service account has attached pull secrets.", + "maxLength": 253, + "type": "string" + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent image scans.\nIt does not apply to already started scans. Defaults to false.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout for image scanning.\nDefaults to 'Interval' duration.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ImageRepositoryStatus defines the observed state of ImageRepository", + "properties": { + "canonicalImageName": { + "description": "CanonicalName is the name of the image repository with all the\nimplied bits made explicit; e.g., `docker.io/library/alpine`\nrather than `alpine`.", + "type": "string" + }, + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastScanResult": { + "description": "LastScanResult contains the number of fetched tags.", + "properties": { + "latestTags": { + "items": { + "type": "string" + }, + "type": "array" + }, + "scanTime": { + "format": "date-time", + "type": "string" + }, + "tagCount": { + "type": "integer" + } + }, + "required": [ + "tagCount" + ], + "type": "object", + "additionalProperties": false + }, + "observedExclusionList": { + "description": "ObservedExclusionList is a list of observed exclusion list. It reflects\nthe exclusion rules used for the observed scan result in\nspec.lastScanResult.", + "items": { + "type": "string" + }, + "type": "array" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last reconciled generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "image.toolkit.fluxcd.io.v1beta1.ImageUpdateAutomation": { + "description": "ImageUpdateAutomation is the Schema for the imageupdateautomations API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "image.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "ImageUpdateAutomation" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ImageUpdateAutomationSpec defines the desired state of ImageUpdateAutomation", + "properties": { + "git": { + "description": "GitSpec contains all the git-specific definitions. This is\ntechnically optional, but in practice mandatory until there are\nother kinds of source allowed.", + "properties": { + "checkout": { + "description": "Checkout gives the parameters for cloning the git repository,\nready to make changes. If not present, the `spec.ref` field from the\nreferenced `GitRepository` or its default will be used.", + "properties": { + "ref": { + "description": "Reference gives a branch, tag or commit to clone from the Git\nrepository.", + "properties": { + "branch": { + "description": "Branch to check out, defaults to 'master' if no other field is defined.", + "type": "string" + }, + "commit": { + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", + "type": "string" + }, + "name": { + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "type": "string" + }, + "semver": { + "description": "SemVer tag expression to check out, takes precedence over Tag.", + "type": "string" + }, + "tag": { + "description": "Tag to check out, takes precedence over Branch.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "ref" + ], + "type": "object", + "additionalProperties": false + }, + "commit": { + "description": "Commit specifies how to commit to the git repository.", + "properties": { + "author": { + "description": "Author gives the email and optionally the name to use as the\nauthor of commits.", + "properties": { + "email": { + "description": "Email gives the email to provide when making a commit.", + "type": "string" + }, + "name": { + "description": "Name gives the name to provide when making a commit.", + "type": "string" + } + }, + "required": [ + "email" + ], + "type": "object", + "additionalProperties": false + }, + "messageTemplate": { + "description": "MessageTemplate provides a template for the commit message,\ninto which will be interpolated the details of the change made.", + "type": "string" + }, + "signingKey": { + "description": "SigningKey provides the option to sign commits with a GPG key", + "properties": { + "secretRef": { + "description": "SecretRef holds the name to a secret that contains a 'git.asc' key\ncorresponding to the ASCII Armored file containing the GPG signing\nkeypair as the value. It must be in the same namespace as the\nImageUpdateAutomation.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "author" + ], + "type": "object", + "additionalProperties": false + }, + "push": { + "description": "Push specifies how and where to push commits made by the\nautomation. If missing, commits are pushed (back) to\n`.spec.checkout.branch` or its default.", + "properties": { + "branch": { + "description": "Branch specifies that commits should be pushed to the branch\nnamed. The branch is created using `.spec.checkout.branch` as the\nstarting point, if it doesn't already exist.", + "type": "string" + }, + "options": { + "additionalProperties": { + "type": "string" + }, + "description": "Options specifies the push options that are sent to the Git\nserver when performing a push operation. For details, see:\nhttps://git-scm.com/docs/git-push#Documentation/git-push.txt---push-optionltoptiongt", + "type": "object" + }, + "refspec": { + "description": "Refspec specifies the Git Refspec to use for a push operation.\nIf both Branch and Refspec are provided, then the commit is pushed\nto the branch and also using the specified refspec.\nFor more details about Git Refspecs, see:\nhttps://git-scm.com/book/en/v2/Git-Internals-The-Refspec", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "commit" + ], + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "Interval gives an lower bound for how often the automation\nrun should be attempted.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "sourceRef": { + "description": "SourceRef refers to the resource giving access details\nto a git repository.", + "properties": { + "apiVersion": { + "description": "API version of the referent.", + "type": "string" + }, + "kind": { + "default": "GitRepository", + "description": "Kind of the referent.", + "enum": [ + "GitRepository" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes resource object that contains the reference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to not run this automation, until\nit is unset (or set to false). Defaults to false.", + "type": "boolean" + }, + "update": { + "default": { + "strategy": "Setters" + }, + "description": "Update gives the specification for how to update the files in\nthe repository. This can be left empty, to use the default\nvalue.", + "properties": { + "path": { + "description": "Path to the directory containing the manifests to be updated.\nDefaults to 'None', which translates to the root path\nof the GitRepositoryRef.", + "type": "string" + }, + "strategy": { + "default": "Setters", + "description": "Strategy names the strategy to be used.", + "enum": [ + "Setters" + ], + "type": "string" + } + }, + "required": [ + "strategy" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "interval", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ImageUpdateAutomationStatus defines the observed state of ImageUpdateAutomation", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastAutomationRunTime": { + "description": "LastAutomationRunTime records the last time the controller ran\nthis automation through to completion (even if no updates were\nmade).", + "format": "date-time", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastPushCommit": { + "description": "LastPushCommit records the SHA1 of the last commit made by the\ncontroller, for this automation object", + "type": "string" + }, + "lastPushTime": { + "description": "LastPushTime records the time of the last pushed change.", + "format": "date-time", + "type": "string" + }, + "observedGeneration": { + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "image.toolkit.fluxcd.io.v1beta2.ImageUpdateAutomation": { + "description": "ImageUpdateAutomation is the Schema for the imageupdateautomations API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "image.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "ImageUpdateAutomation" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ImageUpdateAutomationSpec defines the desired state of ImageUpdateAutomation", + "properties": { + "git": { + "description": "GitSpec contains all the git-specific definitions. This is\ntechnically optional, but in practice mandatory until there are\nother kinds of source allowed.", + "properties": { + "checkout": { + "description": "Checkout gives the parameters for cloning the git repository,\nready to make changes. If not present, the `spec.ref` field from the\nreferenced `GitRepository` or its default will be used.", + "properties": { + "ref": { + "description": "Reference gives a branch, tag or commit to clone from the Git\nrepository.", + "properties": { + "branch": { + "description": "Branch to check out, defaults to 'master' if no other field is defined.", + "type": "string" + }, + "commit": { + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", + "type": "string" + }, + "name": { + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "type": "string" + }, + "semver": { + "description": "SemVer tag expression to check out, takes precedence over Tag.", + "type": "string" + }, + "tag": { + "description": "Tag to check out, takes precedence over Branch.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "ref" + ], + "type": "object", + "additionalProperties": false + }, + "commit": { + "description": "Commit specifies how to commit to the git repository.", + "properties": { + "author": { + "description": "Author gives the email and optionally the name to use as the\nauthor of commits.", + "properties": { + "email": { + "description": "Email gives the email to provide when making a commit.", + "type": "string" + }, + "name": { + "description": "Name gives the name to provide when making a commit.", + "type": "string" + } + }, + "required": [ + "email" + ], + "type": "object", + "additionalProperties": false + }, + "messageTemplate": { + "description": "MessageTemplate provides a template for the commit message,\ninto which will be interpolated the details of the change made.", + "type": "string" + }, + "signingKey": { + "description": "SigningKey provides the option to sign commits with a GPG key", + "properties": { + "secretRef": { + "description": "SecretRef holds the name to a secret that contains a 'git.asc' key\ncorresponding to the ASCII Armored file containing the GPG signing\nkeypair as the value. It must be in the same namespace as the\nImageUpdateAutomation.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "author" + ], + "type": "object", + "additionalProperties": false + }, + "push": { + "description": "Push specifies how and where to push commits made by the\nautomation. If missing, commits are pushed (back) to\n`.spec.checkout.branch` or its default.", + "properties": { + "branch": { + "description": "Branch specifies that commits should be pushed to the branch\nnamed. The branch is created using `.spec.checkout.branch` as the\nstarting point, if it doesn't already exist.", + "type": "string" + }, + "options": { + "additionalProperties": { + "type": "string" + }, + "description": "Options specifies the push options that are sent to the Git\nserver when performing a push operation. For details, see:\nhttps://git-scm.com/docs/git-push#Documentation/git-push.txt---push-optionltoptiongt", + "type": "object" + }, + "refspec": { + "description": "Refspec specifies the Git Refspec to use for a push operation.\nIf both Branch and Refspec are provided, then the commit is pushed\nto the branch and also using the specified refspec.\nFor more details about Git Refspecs, see:\nhttps://git-scm.com/book/en/v2/Git-Internals-The-Refspec", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "commit" + ], + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "Interval gives an lower bound for how often the automation\nrun should be attempted.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "policySelector": { + "description": "PolicySelector allows to filter applied policies based on labels.\nBy default includes all policies in namespace.", + "properties": { + "matchExpressions": { + "description": "matchExpressions is a list of label selector requirements. The requirements are ANDed.", + "items": { + "description": "A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.", + "properties": { + "key": { + "description": "key is the label key that the selector applies to.", + "type": "string" + }, + "operator": { + "description": "operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.", + "type": "string" + }, + "values": { + "description": "values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.", + "items": { + "type": "string" + }, + "type": "array", + "x-kubernetes-list-type": "atomic" + } + }, + "required": [ + "key", + "operator" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array", + "x-kubernetes-list-type": "atomic" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "x-kubernetes-map-type": "atomic", + "additionalProperties": false + }, + "sourceRef": { + "description": "SourceRef refers to the resource giving access details\nto a git repository.", + "properties": { + "apiVersion": { + "description": "API version of the referent.", + "type": "string" + }, + "kind": { + "default": "GitRepository", + "description": "Kind of the referent.", + "enum": [ + "GitRepository" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes resource object that contains the reference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to not run this automation, until\nit is unset (or set to false). Defaults to false.", + "type": "boolean" + }, + "update": { + "default": { + "strategy": "Setters" + }, + "description": "Update gives the specification for how to update the files in\nthe repository. This can be left empty, to use the default\nvalue.", + "properties": { + "path": { + "description": "Path to the directory containing the manifests to be updated.\nDefaults to 'None', which translates to the root path\nof the GitRepositoryRef.", + "type": "string" + }, + "strategy": { + "default": "Setters", + "description": "Strategy names the strategy to be used.", + "enum": [ + "Setters" + ], + "type": "string" + } + }, + "required": [ + "strategy" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "interval", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ImageUpdateAutomationStatus defines the observed state of ImageUpdateAutomation", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastAutomationRunTime": { + "description": "LastAutomationRunTime records the last time the controller ran\nthis automation through to completion (even if no updates were\nmade).", + "format": "date-time", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastPushCommit": { + "description": "LastPushCommit records the SHA1 of the last commit made by the\ncontroller, for this automation object", + "type": "string" + }, + "lastPushTime": { + "description": "LastPushTime records the time of the last pushed change.", + "format": "date-time", + "type": "string" + }, + "observedGeneration": { + "format": "int64", + "type": "integer" + }, + "observedPolicies": { + "additionalProperties": { + "description": "ImageRef represents an image reference.", + "properties": { + "name": { + "description": "Name is the bare image's name.", + "type": "string" + }, + "tag": { + "description": "Tag is the image's tag.", + "type": "string" + } + }, + "required": [ + "name", + "tag" + ], + "type": "object", + "additionalProperties": false + }, + "description": "ObservedPolicies is the list of observed ImagePolicies that were\nconsidered by the ImageUpdateAutomation update process.", + "type": "object" + }, + "observedSourceRevision": { + "description": "ObservedPolicies []ObservedPolicy `json:\"observedPolicies,omitempty\"`\nObservedSourceRevision is the last observed source revision. This can be\nused to determine if the source has been updated since last observation.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "kustomize.toolkit.fluxcd.io.v1.Kustomization": { + "description": "Kustomization is the Schema for the kustomizations API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "kustomize.toolkit.fluxcd.io/v1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Kustomization" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "KustomizationSpec defines the configuration to calculate the desired state\nfrom a Source using Kustomize.", + "properties": { + "commonMetadata": { + "description": "CommonMetadata specifies the common labels and annotations that are\napplied to all resources. Any existing label or annotation will be\noverridden if its key matches a common one.", + "properties": { + "annotations": { + "additionalProperties": { + "type": "string" + }, + "description": "Annotations to be added to the object's metadata.", + "type": "object" + }, + "labels": { + "additionalProperties": { + "type": "string" + }, + "description": "Labels to be added to the object's metadata.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "components": { + "description": "Components specifies relative paths to specifications of other Components.", + "items": { + "type": "string" + }, + "type": "array" + }, + "decryption": { + "description": "Decrypt Kubernetes secrets before applying them on the cluster.", + "properties": { + "provider": { + "description": "Provider is the name of the decryption engine.", + "enum": [ + "sops" + ], + "type": "string" + }, + "secretRef": { + "description": "The secret name containing the private OpenPGP keys used for decryption.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "dependsOn": { + "description": "DependsOn may contain a meta.NamespacedObjectReference slice\nwith references to Kustomization resources that must be ready before this\nKustomization can be reconciled.", + "items": { + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "force": { + "default": false, + "description": "Force instructs the controller to recreate resources\nwhen patching fails due to an immutable field change.", + "type": "boolean" + }, + "healthChecks": { + "description": "A list of resources to be included in the health assessment.", + "items": { + "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object\nin any namespace.", + "properties": { + "apiVersion": { + "description": "API version of the referent, if not specified the Kubernetes preferred version will be used.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "images": { + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", + "items": { + "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", + "properties": { + "digest": { + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", + "type": "string" + }, + "name": { + "description": "Name is a tag-less image name.", + "type": "string" + }, + "newName": { + "description": "NewName is the value used to replace the original name.", + "type": "string" + }, + "newTag": { + "description": "NewTag is the value used to replace the original tag.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "interval": { + "description": "The interval at which to reconcile the Kustomization.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "kubeConfig": { + "description": "The KubeConfig for reconciling the Kustomization on a remote cluster.\nWhen used in combination with KustomizationSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when KustomizationSpec.ServiceAccountName\nis empty.", + "properties": { + "secretRef": { + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", + "properties": { + "key": { + "description": "Key in the Secret, when not specified an implementation-specific default key is used.", + "type": "string" + }, + "name": { + "description": "Name of the Secret.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "secretRef" + ], + "type": "object", + "additionalProperties": false + }, + "namePrefix": { + "description": "NamePrefix will prefix the names of all managed resources.", + "maxLength": 200, + "minLength": 1, + "type": "string" + }, + "nameSuffix": { + "description": "NameSuffix will suffix the names of all managed resources.", + "maxLength": 200, + "minLength": 1, + "type": "string" + }, + "patches": { + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", + "items": { + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", + "properties": { + "patch": { + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", + "type": "string" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "path": { + "description": "Path to the directory containing the kustomization.yaml file, or the\nset of plain YAMLs a kustomization.yaml should be generated for.\nDefaults to 'None', which translates to the root path of the SourceRef.", + "type": "string" + }, + "postBuild": { + "description": "PostBuild describes which actions to perform on the YAML manifest\ngenerated by building the kustomize overlay.", + "properties": { + "substitute": { + "additionalProperties": { + "type": "string" + }, + "description": "Substitute holds a map of key/value pairs.\nThe variables defined in your YAML manifests that match any of the keys\ndefined in the map will be substituted with the set value.\nIncludes support for bash string replacement functions\ne.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", + "type": "object" + }, + "substituteFrom": { + "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing\nthe variables and their values to be substituted in the YAML manifests.\nThe ConfigMap and the Secret data keys represent the var names, and they\nmust match the vars declared in the manifests for the substitution to\nhappen.", + "items": { + "description": "SubstituteReference contains a reference to a resource containing\nthe variables name and value.", + "properties": { + "kind": { + "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", + "enum": [ + "Secret", + "ConfigMap" + ], + "type": "string" + }, + "name": { + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "optional": { + "default": false, + "description": "Optional indicates whether the referenced resource must exist, or whether to\ntolerate its absence. If true and the referenced resource is absent, proceed\nas if the resource was present but empty, without any variables defined.", + "type": "boolean" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + }, + "prune": { + "description": "Prune enables garbage collection.", + "type": "boolean" + }, + "retryInterval": { + "description": "The interval at which to retry a previously failed reconciliation.\nWhen not specified, the controller uses the KustomizationSpec.Interval\nvalue to retry failures.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "serviceAccountName": { + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this Kustomization.", + "type": "string" + }, + "sourceRef": { + "description": "Reference of the source where the kustomization file is.", + "properties": { + "apiVersion": { + "description": "API version of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent kustomize executions,\nit does not apply to already started executions. Defaults to false.", + "type": "boolean" + }, + "targetNamespace": { + "description": "TargetNamespace sets or overrides the namespace in the\nkustomization.yaml file.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "timeout": { + "description": "Timeout for validation, apply and health checking operations.\nDefaults to 'Interval' duration.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "wait": { + "description": "Wait instructs the controller to check the health of all the reconciled\nresources. When enabled, the HealthChecks are ignored. Defaults to false.", + "type": "boolean" + } + }, + "required": [ + "interval", + "prune", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "KustomizationStatus defines the observed state of a kustomization.", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "inventory": { + "description": "Inventory contains the list of Kubernetes resource object references that\nhave been successfully applied.", + "properties": { + "entries": { + "description": "Entries of Kubernetes resource object references.", + "items": { + "description": "ResourceRef contains the information necessary to locate a resource within a cluster.", + "properties": { + "id": { + "description": "ID is the string representation of the Kubernetes resource object's metadata,\nin the format '___'.", + "type": "string" + }, + "v": { + "description": "Version is the API version of the Kubernetes resource object's kind.", + "type": "string" + } + }, + "required": [ + "id", + "v" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "entries" + ], + "type": "object", + "additionalProperties": false + }, + "lastAppliedRevision": { + "description": "The last successfully applied revision.\nEquals the Revision of the applied Artifact from the referenced Source.", + "type": "string" + }, + "lastAttemptedRevision": { + "description": "LastAttemptedRevision is the revision of the last reconciliation attempt.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last reconciled generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "kustomize.toolkit.fluxcd.io.v1beta1.Kustomization": { + "description": "Kustomization is the Schema for the kustomizations API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "kustomize.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Kustomization" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "KustomizationSpec defines the desired state of a kustomization.", + "properties": { + "decryption": { + "description": "Decrypt Kubernetes secrets before applying them on the cluster.", + "properties": { + "provider": { + "description": "Provider is the name of the decryption engine.", + "enum": [ + "sops" + ], + "type": "string" + }, + "secretRef": { + "description": "The secret name containing the private OpenPGP keys used for decryption.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "dependsOn": { + "description": "DependsOn may contain a meta.NamespacedObjectReference slice\nwith references to Kustomization resources that must be ready before this\nKustomization can be reconciled.", + "items": { + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "force": { + "default": false, + "description": "Force instructs the controller to recreate resources\nwhen patching fails due to an immutable field change.", + "type": "boolean" + }, + "healthChecks": { + "description": "A list of resources to be included in the health assessment.", + "items": { + "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object\nin any namespace.", + "properties": { + "apiVersion": { + "description": "API version of the referent, if not specified the Kubernetes preferred version will be used.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "images": { + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", + "items": { + "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", + "properties": { + "digest": { + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", + "type": "string" + }, + "name": { + "description": "Name is a tag-less image name.", + "type": "string" + }, + "newName": { + "description": "NewName is the value used to replace the original name.", + "type": "string" + }, + "newTag": { + "description": "NewTag is the value used to replace the original tag.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "interval": { + "description": "The interval at which to reconcile the Kustomization.", + "type": "string" + }, + "kubeConfig": { + "description": "The KubeConfig for reconciling the Kustomization on a remote cluster.\nWhen specified, KubeConfig takes precedence over ServiceAccountName.", + "properties": { + "secretRef": { + "description": "SecretRef holds the name to a secret that contains a 'value' key with\nthe kubeconfig file as the value. It must be in the same namespace as\nthe Kustomization.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nthe Kustomization.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + }, + "patches": { + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", + "items": { + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", + "properties": { + "patch": { + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", + "type": "string" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesJson6902": { + "description": "JSON 6902 patches, defined as inline YAML objects.", + "items": { + "description": "JSON6902Patch contains a JSON6902 patch and the target the patch should be applied to.", + "properties": { + "patch": { + "description": "Patch contains the JSON6902 patch document with an array of operation objects.", + "items": { + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "properties": { + "from": { + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "type": "string" + }, + "op": { + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "enum": [ + "test", + "remove", + "add", + "replace", + "move", + "copy" + ], + "type": "string" + }, + "path": { + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", + "type": "string" + }, + "value": { + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", + "x-kubernetes-preserve-unknown-fields": true + } + }, + "required": [ + "op", + "path" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch", + "target" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesStrategicMerge": { + "description": "Strategic merge patches, defined as inline YAML objects.", + "items": { + "x-kubernetes-preserve-unknown-fields": true + }, + "type": "array" + }, + "path": { + "description": "Path to the directory containing the kustomization.yaml file, or the\nset of plain YAMLs a kustomization.yaml should be generated for.\nDefaults to 'None', which translates to the root path of the SourceRef.", + "type": "string" + }, + "postBuild": { + "description": "PostBuild describes which actions to perform on the YAML manifest\ngenerated by building the kustomize overlay.", + "properties": { + "substitute": { + "additionalProperties": { + "type": "string" + }, + "description": "Substitute holds a map of key/value pairs.\nThe variables defined in your YAML manifests\nthat match any of the keys defined in the map\nwill be substituted with the set value.\nIncludes support for bash string replacement functions\ne.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", + "type": "object" + }, + "substituteFrom": { + "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing\nthe variables and their values to be substituted in the YAML manifests.\nThe ConfigMap and the Secret data keys represent the var names and they\nmust match the vars declared in the manifests for the substitution to happen.", + "items": { + "description": "SubstituteReference contains a reference to a resource containing\nthe variables name and value.", + "properties": { + "kind": { + "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", + "enum": [ + "Secret", + "ConfigMap" + ], + "type": "string" + }, + "name": { + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", + "maxLength": 253, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + }, + "prune": { + "description": "Prune enables garbage collection.", + "type": "boolean" + }, + "retryInterval": { + "description": "The interval at which to retry a previously failed reconciliation.\nWhen not specified, the controller uses the KustomizationSpec.Interval\nvalue to retry failures.", + "type": "string" + }, + "serviceAccountName": { + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this Kustomization.", + "type": "string" + }, + "sourceRef": { + "description": "Reference of the source where the kustomization file is.", + "properties": { + "apiVersion": { + "description": "API version of the referent", + "type": "string" + }, + "kind": { + "description": "Kind of the referent", + "enum": [ + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the Kustomization namespace", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent kustomize executions,\nit does not apply to already started executions. Defaults to false.", + "type": "boolean" + }, + "targetNamespace": { + "description": "TargetNamespace sets or overrides the namespace in the\nkustomization.yaml file.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "timeout": { + "description": "Timeout for validation, apply and health checking operations.\nDefaults to 'Interval' duration.", + "type": "string" + }, + "validation": { + "description": "Validate the Kubernetes objects before applying them on the cluster.\nThe validation strategy can be 'client' (local dry-run), 'server'\n(APIServer dry-run) or 'none'.\nWhen 'Force' is 'true', validation will fallback to 'client' if set to\n'server' because server-side validation is not supported in this scenario.", + "enum": [ + "none", + "client", + "server" + ], + "type": "string" + } + }, + "required": [ + "interval", + "prune", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "KustomizationStatus defines the observed state of a kustomization.", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastAppliedRevision": { + "description": "The last successfully applied revision.\nThe revision format for Git sources is /.", + "type": "string" + }, + "lastAttemptedRevision": { + "description": "LastAttemptedRevision is the revision of the last reconciliation attempt.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last reconciled generation.", + "format": "int64", + "type": "integer" + }, + "snapshot": { + "description": "The last successfully applied revision metadata.", + "properties": { + "checksum": { + "description": "The manifests sha1 checksum.", + "type": "string" + }, + "entries": { + "description": "A list of Kubernetes kinds grouped by namespace.", + "items": { + "description": "Snapshot holds the metadata of namespaced\nKubernetes objects", + "properties": { + "kinds": { + "additionalProperties": { + "type": "string" + }, + "description": "The list of Kubernetes kinds.", + "type": "object" + }, + "namespace": { + "description": "The namespace of this entry.", + "type": "string" + } + }, + "required": [ + "kinds" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "checksum", + "entries" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "kustomize.toolkit.fluxcd.io.v1beta2.Kustomization": { + "description": "Kustomization is the Schema for the kustomizations API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "kustomize.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Kustomization" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "KustomizationSpec defines the configuration to calculate the desired state from a Source using Kustomize.", + "properties": { + "commonMetadata": { + "description": "CommonMetadata specifies the common labels and annotations that are applied to all resources.\nAny existing label or annotation will be overridden if its key matches a common one.", + "properties": { + "annotations": { + "additionalProperties": { + "type": "string" + }, + "description": "Annotations to be added to the object's metadata.", + "type": "object" + }, + "labels": { + "additionalProperties": { + "type": "string" + }, + "description": "Labels to be added to the object's metadata.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "components": { + "description": "Components specifies relative paths to specifications of other Components.", + "items": { + "type": "string" + }, + "type": "array" + }, + "decryption": { + "description": "Decrypt Kubernetes secrets before applying them on the cluster.", + "properties": { + "provider": { + "description": "Provider is the name of the decryption engine.", + "enum": [ + "sops" + ], + "type": "string" + }, + "secretRef": { + "description": "The secret name containing the private OpenPGP keys used for decryption.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "dependsOn": { + "description": "DependsOn may contain a meta.NamespacedObjectReference slice\nwith references to Kustomization resources that must be ready before this\nKustomization can be reconciled.", + "items": { + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "force": { + "default": false, + "description": "Force instructs the controller to recreate resources\nwhen patching fails due to an immutable field change.", + "type": "boolean" + }, + "healthChecks": { + "description": "A list of resources to be included in the health assessment.", + "items": { + "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object\nin any namespace.", + "properties": { + "apiVersion": { + "description": "API version of the referent, if not specified the Kubernetes preferred version will be used.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "images": { + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", + "items": { + "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", + "properties": { + "digest": { + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", + "type": "string" + }, + "name": { + "description": "Name is a tag-less image name.", + "type": "string" + }, + "newName": { + "description": "NewName is the value used to replace the original name.", + "type": "string" + }, + "newTag": { + "description": "NewTag is the value used to replace the original tag.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "interval": { + "description": "The interval at which to reconcile the Kustomization.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "kubeConfig": { + "description": "The KubeConfig for reconciling the Kustomization on a remote cluster.\nWhen used in combination with KustomizationSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when KustomizationSpec.ServiceAccountName\nis empty.", + "properties": { + "secretRef": { + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", + "properties": { + "key": { + "description": "Key in the Secret, when not specified an implementation-specific default key is used.", + "type": "string" + }, + "name": { + "description": "Name of the Secret.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "secretRef" + ], + "type": "object", + "additionalProperties": false + }, + "patches": { + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", + "items": { + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", + "properties": { + "patch": { + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", + "type": "string" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesJson6902": { + "description": "JSON 6902 patches, defined as inline YAML objects.\nDeprecated: Use Patches instead.", + "items": { + "description": "JSON6902Patch contains a JSON6902 patch and the target the patch should be applied to.", + "properties": { + "patch": { + "description": "Patch contains the JSON6902 patch document with an array of operation objects.", + "items": { + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "properties": { + "from": { + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "type": "string" + }, + "op": { + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", + "enum": [ + "test", + "remove", + "add", + "replace", + "move", + "copy" + ], + "type": "string" + }, + "path": { + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", + "type": "string" + }, + "value": { + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", + "x-kubernetes-preserve-unknown-fields": true + } + }, + "required": [ + "op", + "path" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch", + "target" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patchesStrategicMerge": { + "description": "Strategic merge patches, defined as inline YAML objects.\nDeprecated: Use Patches instead.", + "items": { + "x-kubernetes-preserve-unknown-fields": true + }, + "type": "array" + }, + "path": { + "description": "Path to the directory containing the kustomization.yaml file, or the\nset of plain YAMLs a kustomization.yaml should be generated for.\nDefaults to 'None', which translates to the root path of the SourceRef.", + "type": "string" + }, + "postBuild": { + "description": "PostBuild describes which actions to perform on the YAML manifest\ngenerated by building the kustomize overlay.", + "properties": { + "substitute": { + "additionalProperties": { + "type": "string" + }, + "description": "Substitute holds a map of key/value pairs.\nThe variables defined in your YAML manifests\nthat match any of the keys defined in the map\nwill be substituted with the set value.\nIncludes support for bash string replacement functions\ne.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", + "type": "object" + }, + "substituteFrom": { + "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing\nthe variables and their values to be substituted in the YAML manifests.\nThe ConfigMap and the Secret data keys represent the var names and they\nmust match the vars declared in the manifests for the substitution to happen.", + "items": { + "description": "SubstituteReference contains a reference to a resource containing\nthe variables name and value.", + "properties": { + "kind": { + "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", + "enum": [ + "Secret", + "ConfigMap" + ], + "type": "string" + }, + "name": { + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "optional": { + "default": false, + "description": "Optional indicates whether the referenced resource must exist, or whether to\ntolerate its absence. If true and the referenced resource is absent, proceed\nas if the resource was present but empty, without any variables defined.", + "type": "boolean" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + }, + "prune": { + "description": "Prune enables garbage collection.", + "type": "boolean" + }, + "retryInterval": { + "description": "The interval at which to retry a previously failed reconciliation.\nWhen not specified, the controller uses the KustomizationSpec.Interval\nvalue to retry failures.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "serviceAccountName": { + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this Kustomization.", + "type": "string" + }, + "sourceRef": { + "description": "Reference of the source where the kustomization file is.", + "properties": { + "apiVersion": { + "description": "API version of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes resource object that contains the reference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent kustomize executions,\nit does not apply to already started executions. Defaults to false.", + "type": "boolean" + }, + "targetNamespace": { + "description": "TargetNamespace sets or overrides the namespace in the\nkustomization.yaml file.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "timeout": { + "description": "Timeout for validation, apply and health checking operations.\nDefaults to 'Interval' duration.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "validation": { + "description": "Deprecated: Not used in v1beta2.", + "enum": [ + "none", + "client", + "server" + ], + "type": "string" + }, + "wait": { + "description": "Wait instructs the controller to check the health of all the reconciled resources.\nWhen enabled, the HealthChecks are ignored. Defaults to false.", + "type": "boolean" + } + }, + "required": [ + "interval", + "prune", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "KustomizationStatus defines the observed state of a kustomization.", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "inventory": { + "description": "Inventory contains the list of Kubernetes resource object references that have been successfully applied.", + "properties": { + "entries": { + "description": "Entries of Kubernetes resource object references.", + "items": { + "description": "ResourceRef contains the information necessary to locate a resource within a cluster.", + "properties": { + "id": { + "description": "ID is the string representation of the Kubernetes resource object's metadata,\nin the format '___'.", + "type": "string" + }, + "v": { + "description": "Version is the API version of the Kubernetes resource object's kind.", + "type": "string" + } + }, + "required": [ + "id", + "v" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "entries" + ], + "type": "object", + "additionalProperties": false + }, + "lastAppliedRevision": { + "description": "The last successfully applied revision.\nEquals the Revision of the applied Artifact from the referenced Source.", + "type": "string" + }, + "lastAttemptedRevision": { + "description": "LastAttemptedRevision is the revision of the last reconciliation attempt.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last reconciled generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "source.toolkit.fluxcd.io.v1beta2.OCIRepository": { + "description": "OCIRepository is the Schema for the ocirepositories API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "source.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "OCIRepository" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "OCIRepositorySpec defines the desired state of OCIRepository", + "properties": { + "certSecretRef": { + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nNote: Support for the `caFile`, `certFile` and `keyFile` keys have\nbeen deprecated.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "ignore": { + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", + "type": "string" + }, + "insecure": { + "description": "Insecure allows connecting to a non-TLS HTTP container registry.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the OCIRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "layerSelector": { + "description": "LayerSelector specifies which layer should be extracted from the OCI artifact.\nWhen not specified, the first layer found in the artifact is selected.", + "properties": { + "mediaType": { + "description": "MediaType specifies the OCI media type of the layer\nwhich should be extracted from the OCI Artifact. The\nfirst layer matching this type is selected.", + "type": "string" + }, + "operation": { + "description": "Operation specifies how the selected layer should be processed.\nBy default, the layer compressed content is extracted to storage.\nWhen the operation is set to 'copy', the layer compressed content\nis persisted to storage as it is.", + "enum": [ + "extract", + "copy" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "provider": { + "default": "generic", + "description": "The provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nWhen not specified, defaults to 'generic'.", + "enum": [ + "generic", + "aws", + "azure", + "gcp" + ], + "type": "string" + }, + "ref": { + "description": "The OCI reference to pull and monitor for changes,\ndefaults to the latest tag.", + "properties": { + "digest": { + "description": "Digest is the image digest to pull, takes precedence over SemVer.\nThe value should be in the format 'sha256:'.", + "type": "string" + }, + "semver": { + "description": "SemVer is the range of tags to pull selecting the latest within\nthe range, takes precedence over Tag.", + "type": "string" + }, + "semverFilter": { + "description": "SemverFilter is a regex pattern to filter the tags within the SemVer range.", + "type": "string" + }, + "tag": { + "description": "Tag is the image tag to pull, defaults to latest.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "secretRef": { + "description": "SecretRef contains the secret name containing the registry login\ncredentials to resolve image metadata.\nThe secret must be of type kubernetes.io/dockerconfigjson.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "serviceAccountName": { + "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate\nthe image pull if the service account has attached pull secrets. For more information:\nhttps://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/#add-imagepullsecrets-to-a-service-account", + "type": "string" + }, + "suspend": { + "description": "This flag tells the controller to suspend the reconciliation of this source.", + "type": "boolean" + }, + "timeout": { + "default": "60s", + "description": "The timeout for remote OCI Repository operations like pulling, defaults to 60s.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "url": { + "description": "URL is a reference to an OCI artifact repository hosted\non a remote container registry.", + "pattern": "^oci://.*$", + "type": "string" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.", + "properties": { + "matchOIDCIdentity": { + "description": "MatchOIDCIdentity specifies the identity matching criteria to use\nwhile verifying an OCI artifact which was signed using Cosign keyless\nsigning. The artifact's identity is deemed to be verified if any of the\nspecified matchers match against the identity.", + "items": { + "description": "OIDCIdentityMatch specifies options for verifying the certificate identity,\ni.e. the issuer and the subject of the certificate.", + "properties": { + "issuer": { + "description": "Issuer specifies the regex pattern to match against to verify\nthe OIDC issuer in the Fulcio certificate. The pattern must be a\nvalid Go regular expression.", + "type": "string" + }, + "subject": { + "description": "Subject specifies the regex pattern to match against to verify\nthe identity subject in the Fulcio certificate. The pattern must\nbe a valid Go regular expression.", + "type": "string" + } + }, + "required": [ + "issuer", + "subject" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Artifact.", + "enum": [ + "cosign", + "notation" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "interval", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "OCIRepositoryStatus defines the observed state of OCIRepository", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful OCI Repository sync.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the OCIRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "contentConfigChecksum": { + "description": "ContentConfigChecksum is a checksum of all the configurations related to\nthe content of the source artifact:\n - .spec.ignore\n - .spec.layerSelector\nobserved in .status.observedGeneration version of the object. This can\nbe used to determine if the content configuration has changed and the\nartifact needs to be rebuilt.\nIt has the format of `:`, for example: `sha256:`.\n\n\nDeprecated: Replaced with explicit fields for observed artifact content\nconfig in the status.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "observedIgnore": { + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", + "type": "string" + }, + "observedLayerSelector": { + "description": "ObservedLayerSelector is the observed layer selector used for constructing\nthe source artifact.", + "properties": { + "mediaType": { + "description": "MediaType specifies the OCI media type of the layer\nwhich should be extracted from the OCI Artifact. The\nfirst layer matching this type is selected.", + "type": "string" + }, + "operation": { + "description": "Operation specifies how the selected layer should be processed.\nBy default, the layer compressed content is extracted to storage.\nWhen the operation is set to 'copy', the layer compressed content\nis persisted to storage as it is.", + "enum": [ + "extract", + "copy" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "url": { + "description": "URL is the download link for the artifact output of the last OCI Repository sync.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1beta1.Provider": { + "description": "Provider is the Schema for the providers API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Provider" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ProviderSpec defines the desired state of Provider", + "properties": { + "address": { + "description": "HTTP/S webhook address of this provider", + "pattern": "^(http|https)://", + "type": "string" + }, + "certSecretRef": { + "description": "CertSecretRef can be given the name of a secret containing\na PEM-encoded CA certificate (`caFile`)", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "channel": { + "description": "Alert channel for this provider", + "type": "string" + }, + "proxy": { + "description": "HTTP/S address of the proxy", + "pattern": "^(http|https)://", + "type": "string" + }, + "secretRef": { + "description": "Secret reference containing the provider webhook URL\nusing \"address\" as data key", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent events handling.\nDefaults to false.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout for sending alerts to the provider.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "type": { + "description": "Type of provider", + "enum": [ + "slack", + "discord", + "msteams", + "rocket", + "generic", + "generic-hmac", + "github", + "gitlab", + "bitbucket", + "azuredevops", + "googlechat", + "webex", + "sentry", + "azureeventhub", + "telegram", + "lark", + "matrix", + "opsgenie", + "alertmanager", + "grafana", + "githubdispatch" + ], + "type": "string" + }, + "username": { + "description": "Bot username for this provider", + "type": "string" + } + }, + "required": [ + "type" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ProviderStatus defines the observed state of Provider", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last reconciled generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1beta2.Provider": { + "description": "Provider is the Schema for the providers API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Provider" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ProviderSpec defines the desired state of the Provider.", + "properties": { + "address": { + "description": "Address specifies the endpoint, in a generic sense, to where alerts are sent.\nWhat kind of endpoint depends on the specific Provider type being used.\nFor the generic Provider, for example, this is an HTTP/S address.\nFor other Provider types this could be a project ID or a namespace.", + "maxLength": 2048, + "type": "string" + }, + "certSecretRef": { + "description": "CertSecretRef specifies the Secret containing\na PEM-encoded CA certificate (in the `ca.crt` key).\n\n\nNote: Support for the `caFile` key has\nbeen deprecated.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "channel": { + "description": "Channel specifies the destination channel where events should be posted.", + "maxLength": 2048, + "type": "string" + }, + "interval": { + "description": "Interval at which to reconcile the Provider with its Secret references.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "proxy": { + "description": "Proxy the HTTP/S address of the proxy server.", + "maxLength": 2048, + "pattern": "^(http|https)://.*$", + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing the authentication\ncredentials for this Provider.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Provider.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout for sending alerts to the Provider.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "type": { + "description": "Type specifies which Provider implementation to use.", + "enum": [ + "slack", + "discord", + "msteams", + "rocket", + "generic", + "generic-hmac", + "github", + "gitlab", + "gitea", + "bitbucketserver", + "bitbucket", + "azuredevops", + "googlechat", + "googlepubsub", + "webex", + "sentry", + "azureeventhub", + "telegram", + "lark", + "matrix", + "opsgenie", + "alertmanager", + "grafana", + "githubdispatch", + "pagerduty", + "datadog" + ], + "type": "string" + }, + "username": { + "description": "Username specifies the name under which events are posted.", + "maxLength": 2048, + "type": "string" + } + }, + "required": [ + "type" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ProviderStatus defines the observed state of the Provider.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the Provider.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last reconciled generation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1beta3.Provider": { + "description": "Provider is the Schema for the providers API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta3" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Provider" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ProviderSpec defines the desired state of the Provider.", + "properties": { + "address": { + "description": "Address specifies the endpoint, in a generic sense, to where alerts are sent.\nWhat kind of endpoint depends on the specific Provider type being used.\nFor the generic Provider, for example, this is an HTTP/S address.\nFor other Provider types this could be a project ID or a namespace.", + "maxLength": 2048, + "type": "string" + }, + "certSecretRef": { + "description": "CertSecretRef specifies the Secret containing\na PEM-encoded CA certificate (in the `ca.crt` key).\n\n\nNote: Support for the `caFile` key has\nbeen deprecated.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "channel": { + "description": "Channel specifies the destination channel where events should be posted.", + "maxLength": 2048, + "type": "string" + }, + "interval": { + "description": "Interval at which to reconcile the Provider with its Secret references.\nDeprecated and not used in v1beta3.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "proxy": { + "description": "Proxy the HTTP/S address of the proxy server.", + "maxLength": 2048, + "pattern": "^(http|https)://.*$", + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing the authentication\ncredentials for this Provider.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Provider.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout for sending alerts to the Provider.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "type": { + "description": "Type specifies which Provider implementation to use.", + "enum": [ + "slack", + "discord", + "msteams", + "rocket", + "generic", + "generic-hmac", + "github", + "gitlab", + "gitea", + "bitbucketserver", + "bitbucket", + "azuredevops", + "googlechat", + "googlepubsub", + "webex", + "sentry", + "azureeventhub", + "telegram", + "lark", + "matrix", + "opsgenie", + "alertmanager", + "grafana", + "githubdispatch", + "pagerduty", + "datadog", + "nats" + ], + "type": "string" + }, + "username": { + "description": "Username specifies the name under which events are posted.", + "maxLength": 2048, + "type": "string" + } + }, + "required": [ + "type" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1.Receiver": { + "description": "Receiver is the Schema for the receivers API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Receiver" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ReceiverSpec defines the desired state of the Receiver.", + "properties": { + "events": { + "description": "Events specifies the list of event types to handle,\ne.g. 'push' for GitHub or 'Push Hook' for GitLab.", + "items": { + "type": "string" + }, + "type": "array" + }, + "interval": { + "default": "10m", + "description": "Interval at which to reconcile the Receiver with its Secret references.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "resources": { + "description": "A list of resources to be notified about changes.", + "items": { + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", + "properties": { + "apiVersion": { + "description": "API version of the referent", + "type": "string" + }, + "kind": { + "description": "Kind of the referent", + "enum": [ + "Bucket", + "GitRepository", + "Kustomization", + "HelmRelease", + "HelmChart", + "HelmRepository", + "ImageRepository", + "ImagePolicy", + "ImageUpdateAutomation", + "OCIRepository" + ], + "type": "string" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", + "type": "object" + }, + "name": { + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing the token used\nto validate the payload authenticity.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this receiver.", + "type": "boolean" + }, + "type": { + "description": "Type of webhook sender, used to determine\nthe validation procedure and payload deserialization.", + "enum": [ + "generic", + "generic-hmac", + "github", + "gitlab", + "bitbucket", + "harbor", + "dockerhub", + "quay", + "gcr", + "nexus", + "acr", + "cdevents" + ], + "type": "string" + } + }, + "required": [ + "resources", + "secretRef", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ReceiverStatus defines the observed state of the Receiver.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the Receiver.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the Receiver object.", + "format": "int64", + "type": "integer" + }, + "webhookPath": { + "description": "WebhookPath is the generated incoming webhook address in the format\nof '/hook/sha256sum(token+name+namespace)'.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1beta1.Receiver": { + "description": "Receiver is the Schema for the receivers API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta1" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Receiver" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ReceiverSpec defines the desired state of Receiver", + "properties": { + "events": { + "description": "A list of events to handle,\ne.g. 'push' for GitHub or 'Push Hook' for GitLab.", + "items": { + "type": "string" + }, + "type": "array" + }, + "resources": { + "description": "A list of resources to be notified about changes.", + "items": { + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", + "properties": { + "apiVersion": { + "description": "API version of the referent", + "type": "string" + }, + "kind": { + "description": "Kind of the referent", + "enum": [ + "Bucket", + "GitRepository", + "Kustomization", + "HelmRelease", + "HelmChart", + "HelmRepository", + "ImageRepository", + "ImagePolicy", + "ImageUpdateAutomation", + "OCIRepository" + ], + "type": "string" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + }, + "name": { + "description": "Name of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "secretRef": { + "description": "Secret reference containing the token used\nto validate the payload authenticity", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "This flag tells the controller to suspend subsequent events handling.\nDefaults to false.", + "type": "boolean" + }, + "type": { + "description": "Type of webhook sender, used to determine\nthe validation procedure and payload deserialization.", + "enum": [ + "generic", + "generic-hmac", + "github", + "gitlab", + "bitbucket", + "harbor", + "dockerhub", + "quay", + "gcr", + "nexus", + "acr" + ], + "type": "string" + } + }, + "required": [ + "resources", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ReceiverStatus defines the observed state of Receiver", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "Generated webhook URL in the format\nof '/hook/sha256sum(token+name+namespace)'.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + }, + "notification.toolkit.fluxcd.io.v1beta2.Receiver": { + "description": "Receiver is the Schema for the receivers API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string", + "enum": [ + "notification.toolkit.fluxcd.io/v1beta2" + ] + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string", + "enum": [ + "Receiver" + ] + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ReceiverSpec defines the desired state of the Receiver.", + "properties": { + "events": { + "description": "Events specifies the list of event types to handle,\ne.g. 'push' for GitHub or 'Push Hook' for GitLab.", + "items": { + "type": "string" + }, + "type": "array" + }, + "interval": { + "description": "Interval at which to reconcile the Receiver with its Secret references.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "resources": { + "description": "A list of resources to be notified about changes.", + "items": { + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", + "properties": { + "apiVersion": { + "description": "API version of the referent", + "type": "string" + }, + "kind": { + "description": "Kind of the referent", + "enum": [ + "Bucket", + "GitRepository", + "Kustomization", + "HelmRelease", + "HelmChart", + "HelmRepository", + "ImageRepository", + "ImagePolicy", + "ImageUpdateAutomation", + "OCIRepository" + ], + "type": "string" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", + "type": "object" + }, + "name": { + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent", + "maxLength": 53, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing the token used\nto validate the payload authenticity.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this receiver.", + "type": "boolean" + }, + "type": { + "description": "Type of webhook sender, used to determine\nthe validation procedure and payload deserialization.", + "enum": [ + "generic", + "generic-hmac", + "github", + "gitlab", + "bitbucket", + "harbor", + "dockerhub", + "quay", + "gcr", + "nexus", + "acr" + ], + "type": "string" + } + }, + "required": [ + "resources", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ReceiverStatus defines the observed state of the Receiver.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the Receiver.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the Receiver object.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the generated incoming webhook address in the format\nof '/hook/sha256sum(token+name+namespace)'.\nDeprecated: Replaced by WebhookPath.", + "type": "string" + }, + "webhookPath": { + "description": "WebhookPath is the generated incoming webhook address in the format\nof '/hook/sha256sum(token+name+namespace)'.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" + } + } +} \ No newline at end of file diff --git a/alert-notification-v1beta1.json b/alert-notification-v1beta1.json index ed31305..23f5fde 100644 --- a/alert-notification-v1beta1.json +++ b/alert-notification-v1beta1.json @@ -2,11 +2,11 @@ "description": "Alert is the Schema for the alerts API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -17,7 +17,7 @@ "properties": { "eventSeverity": { "default": "info", - "description": "Filter events based on severity, defaults to ('info'). If set to 'info' no events will be filtered.", + "description": "Filter events based on severity, defaults to ('info').\nIf set to 'info' no events will be filtered.", "enum": [ "info", "error" @@ -27,7 +27,7 @@ "eventSources": { "description": "Filter events based on the involved objects.", "items": { - "description": "CrossNamespaceObjectReference contains enough information to let you locate the typed referenced object at cluster level", + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", "properties": { "apiVersion": { "description": "API version of the referent", @@ -53,7 +53,7 @@ "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" }, "name": { @@ -103,7 +103,7 @@ "type": "string" }, "suspend": { - "description": "This flag tells the controller to suspend subsequent events dispatching. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent events dispatching.\nDefaults to false.", "type": "boolean" } }, @@ -122,26 +122,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -157,7 +157,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" diff --git a/alert-notification-v1beta2.json b/alert-notification-v1beta2.json index 73ca9ed..4339ff4 100644 --- a/alert-notification-v1beta2.json +++ b/alert-notification-v1beta2.json @@ -2,11 +2,11 @@ "description": "Alert is the Schema for the alerts API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -19,12 +19,12 @@ "additionalProperties": { "type": "string" }, - "description": "EventMetadata is an optional field for adding metadata to events dispatched by the controller. This can be used for enhancing the context of the event. If a field would override one already present on the original event as generated by the emitter, then the override doesn't happen, i.e. the original value is preserved, and an info log is printed.", + "description": "EventMetadata is an optional field for adding metadata to events dispatched by the\ncontroller. This can be used for enhancing the context of the event. If a field\nwould override one already present on the original event as generated by the emitter,\nthen the override doesn't happen, i.e. the original value is preserved, and an info\nlog is printed.", "type": "object" }, "eventSeverity": { "default": "info", - "description": "EventSeverity specifies how to filter events based on severity. If set to 'info' no events will be filtered.", + "description": "EventSeverity specifies how to filter events based on severity.\nIf set to 'info' no events will be filtered.", "enum": [ "info", "error" @@ -32,9 +32,9 @@ "type": "string" }, "eventSources": { - "description": "EventSources specifies how to filter events based on the involved object kind, name and namespace.", + "description": "EventSources specifies how to filter events based\non the involved object kind, name and namespace.", "items": { - "description": "CrossNamespaceObjectReference contains enough information to let you locate the typed referenced object at cluster level", + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", "properties": { "apiVersion": { "description": "API version of the referent", @@ -60,11 +60,11 @@ "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed. MatchLabels requires the name to be set to `*`.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", "type": "object" }, "name": { - "description": "Name of the referent If multiple resources are targeted `*` may be set.", + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", "maxLength": 53, "minLength": 1, "type": "string" @@ -86,14 +86,14 @@ "type": "array" }, "exclusionList": { - "description": "ExclusionList specifies a list of Golang regular expressions to be used for excluding messages.", + "description": "ExclusionList specifies a list of Golang regular expressions\nto be used for excluding messages.", "items": { "type": "string" }, "type": "array" }, "inclusionList": { - "description": "InclusionList specifies a list of Golang regular expressions to be used for including messages.", + "description": "InclusionList specifies a list of Golang regular expressions\nto be used for including messages.", "items": { "type": "string" }, @@ -119,7 +119,7 @@ "type": "string" }, "suspend": { - "description": "Suspend tells the controller to suspend subsequent events handling for this Alert.", + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Alert.", "type": "boolean" } }, @@ -139,26 +139,26 @@ "conditions": { "description": "Conditions holds the conditions for the Alert.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -174,7 +174,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -193,7 +193,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { diff --git a/alert-notification-v1beta3.json b/alert-notification-v1beta3.json index 470a923..aa25797 100644 --- a/alert-notification-v1beta3.json +++ b/alert-notification-v1beta3.json @@ -2,11 +2,11 @@ "description": "Alert is the Schema for the alerts API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -19,12 +19,12 @@ "additionalProperties": { "type": "string" }, - "description": "EventMetadata is an optional field for adding metadata to events dispatched by the controller. This can be used for enhancing the context of the event. If a field would override one already present on the original event as generated by the emitter, then the override doesn't happen, i.e. the original value is preserved, and an info log is printed.", + "description": "EventMetadata is an optional field for adding metadata to events dispatched by the\ncontroller. This can be used for enhancing the context of the event. If a field\nwould override one already present on the original event as generated by the emitter,\nthen the override doesn't happen, i.e. the original value is preserved, and an info\nlog is printed.", "type": "object" }, "eventSeverity": { "default": "info", - "description": "EventSeverity specifies how to filter events based on severity. If set to 'info' no events will be filtered.", + "description": "EventSeverity specifies how to filter events based on severity.\nIf set to 'info' no events will be filtered.", "enum": [ "info", "error" @@ -32,9 +32,9 @@ "type": "string" }, "eventSources": { - "description": "EventSources specifies how to filter events based on the involved object kind, name and namespace.", + "description": "EventSources specifies how to filter events based\non the involved object kind, name and namespace.", "items": { - "description": "CrossNamespaceObjectReference contains enough information to let you locate the typed referenced object at cluster level", + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", "properties": { "apiVersion": { "description": "API version of the referent", @@ -60,11 +60,11 @@ "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed. MatchLabels requires the name to be set to `*`.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", "type": "object" }, "name": { - "description": "Name of the referent If multiple resources are targeted `*` may be set.", + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", "maxLength": 53, "minLength": 1, "type": "string" @@ -86,14 +86,14 @@ "type": "array" }, "exclusionList": { - "description": "ExclusionList specifies a list of Golang regular expressions to be used for excluding messages.", + "description": "ExclusionList specifies a list of Golang regular expressions\nto be used for excluding messages.", "items": { "type": "string" }, "type": "array" }, "inclusionList": { - "description": "InclusionList specifies a list of Golang regular expressions to be used for including messages.", + "description": "InclusionList specifies a list of Golang regular expressions\nto be used for including messages.", "items": { "type": "string" }, @@ -119,7 +119,7 @@ "type": "string" }, "suspend": { - "description": "Suspend tells the controller to suspend subsequent events handling for this Alert.", + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Alert.", "type": "boolean" } }, diff --git a/all.json b/all.json new file mode 100644 index 0000000..70ddc78 --- /dev/null +++ b/all.json @@ -0,0 +1,103 @@ +{ + "oneOf": [ + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta1.Alert" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta2.Alert" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta3.Alert" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta1.Bucket" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta2.Bucket" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1.GitRepository" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta1.GitRepository" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta2.GitRepository" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1.HelmChart" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta1.HelmChart" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta2.HelmChart" + }, + { + "$ref": "_definitions.json#/definitions/helm.toolkit.fluxcd.io.v2.HelmRelease" + }, + { + "$ref": "_definitions.json#/definitions/helm.toolkit.fluxcd.io.v2beta1.HelmRelease" + }, + { + "$ref": "_definitions.json#/definitions/helm.toolkit.fluxcd.io.v2beta2.HelmRelease" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1.HelmRepository" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta1.HelmRepository" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta2.HelmRepository" + }, + { + "$ref": "_definitions.json#/definitions/image.toolkit.fluxcd.io.v1beta1.ImagePolicy" + }, + { + "$ref": "_definitions.json#/definitions/image.toolkit.fluxcd.io.v1beta2.ImagePolicy" + }, + { + "$ref": "_definitions.json#/definitions/image.toolkit.fluxcd.io.v1beta1.ImageRepository" + }, + { + "$ref": "_definitions.json#/definitions/image.toolkit.fluxcd.io.v1beta2.ImageRepository" + }, + { + "$ref": "_definitions.json#/definitions/image.toolkit.fluxcd.io.v1beta1.ImageUpdateAutomation" + }, + { + "$ref": "_definitions.json#/definitions/image.toolkit.fluxcd.io.v1beta2.ImageUpdateAutomation" + }, + { + "$ref": "_definitions.json#/definitions/kustomize.toolkit.fluxcd.io.v1.Kustomization" + }, + { + "$ref": "_definitions.json#/definitions/kustomize.toolkit.fluxcd.io.v1beta1.Kustomization" + }, + { + "$ref": "_definitions.json#/definitions/kustomize.toolkit.fluxcd.io.v1beta2.Kustomization" + }, + { + "$ref": "_definitions.json#/definitions/source.toolkit.fluxcd.io.v1beta2.OCIRepository" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta1.Provider" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta2.Provider" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta3.Provider" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1.Receiver" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta1.Receiver" + }, + { + "$ref": "_definitions.json#/definitions/notification.toolkit.fluxcd.io.v1beta2.Receiver" + } + ] +} \ No newline at end of file diff --git a/bucket-source-v1beta1.json b/bucket-source-v1beta1.json index 6f6308c..ab2d502 100644 --- a/bucket-source-v1beta1.json +++ b/bucket-source-v1beta1.json @@ -2,11 +2,11 @@ "description": "Bucket is the Schema for the buckets API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -19,15 +19,15 @@ "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -52,7 +52,7 @@ "type": "string" }, "ignore": { - "description": "Ignore overrides the set of excluded patterns in the .sourceignore format (which is the same as .gitignore). If not provided, a default will be used, consult the documentation for your version to find out what those are.", + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", "type": "string" }, "insecure": { @@ -78,7 +78,7 @@ "type": "string" }, "secretRef": { - "description": "The name of the secret containing authentication credentials for the Bucket.", + "description": "The name of the secret containing authentication credentials\nfor the Bucket.", "properties": { "name": { "description": "Name of the referent.", @@ -123,7 +123,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of this artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", "format": "date-time", "type": "string" }, @@ -132,7 +132,7 @@ "type": "string" }, "revision": { - "description": "Revision is a human readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm chart version, etc.", + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", "type": "string" }, "url": { @@ -150,26 +150,26 @@ "conditions": { "description": "Conditions holds the conditions for the Bucket.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -185,7 +185,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -204,7 +204,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { diff --git a/bucket-source-v1beta2.json b/bucket-source-v1beta2.json index 962f1e8..0d928c7 100644 --- a/bucket-source-v1beta2.json +++ b/bucket-source-v1beta2.json @@ -2,32 +2,32 @@ "description": "Bucket is the Schema for the buckets API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "BucketSpec specifies the required configuration to produce an Artifact for an object storage bucket.", + "description": "BucketSpec specifies the required configuration to produce an Artifact for\nan object storage bucket.", "properties": { "accessFrom": { - "description": "AccessFrom specifies an Access Control List for allowing cross-namespace references to this object. NOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -52,7 +52,7 @@ "type": "string" }, "ignore": { - "description": "Ignore overrides the set of excluded patterns in the .sourceignore format (which is the same as .gitignore). If not provided, a default will be used, consult the documentation for your version to find out what those are.", + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", "type": "string" }, "insecure": { @@ -60,7 +60,7 @@ "type": "boolean" }, "interval": { - "description": "Interval at which the Bucket Endpoint is checked for updates. This interval is approximate and may be subject to jitter to ensure efficient use of resources.", + "description": "Interval at which the Bucket Endpoint is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, @@ -70,7 +70,7 @@ }, "provider": { "default": "generic", - "description": "Provider of the object storage bucket. Defaults to 'generic', which expects an S3 (API) compatible object storage.", + "description": "Provider of the object storage bucket.\nDefaults to 'generic', which expects an S3 (API) compatible object\nstorage.", "enum": [ "generic", "aws", @@ -84,7 +84,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Secret containing authentication credentials for the Bucket.", + "description": "SecretRef specifies the Secret containing authentication credentials\nfor the Bucket.", "properties": { "name": { "description": "Name of the referent.", @@ -98,7 +98,7 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend the reconciliation of this Bucket.", + "description": "Suspend tells the controller to suspend the reconciliation of this\nBucket.", "type": "boolean" }, "timeout": { @@ -131,7 +131,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -143,11 +143,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -156,7 +156,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -172,26 +172,26 @@ "conditions": { "description": "Conditions holds the conditions for the Bucket.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -207,7 +207,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -226,7 +226,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { @@ -235,11 +235,11 @@ "type": "integer" }, "observedIgnore": { - "description": "ObservedIgnore is the observed exclusion patterns used for constructing the source artifact.", + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", "type": "string" }, "url": { - "description": "URL is the dynamic fetch link for the latest Artifact. It is provided on a \"best effort\" basis, and using the precise BucketStatus.Artifact data is recommended.", + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nBucketStatus.Artifact data is recommended.", "type": "string" } }, diff --git a/gitrepository-source-v1.json b/gitrepository-source-v1.json index 55fb3c2..bf50566 100644 --- a/gitrepository-source-v1.json +++ b/gitrepository-source-v1.json @@ -2,34 +2,34 @@ "description": "GitRepository is the Schema for the gitrepositories API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "GitRepositorySpec specifies the required configuration to produce an Artifact for a Git repository.", + "description": "GitRepositorySpec specifies the required configuration to produce an\nArtifact for a Git repository.", "properties": { "ignore": { - "description": "Ignore overrides the set of excluded patterns in the .sourceignore format (which is the same as .gitignore). If not provided, a default will be used, consult the documentation for your version to find out what those are.", + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", "type": "string" }, "include": { - "description": "Include specifies a list of GitRepository resources which Artifacts should be included in the Artifact produced for this GitRepository.", + "description": "Include specifies a list of GitRepository resources which Artifacts\nshould be included in the Artifact produced for this GitRepository.", "items": { - "description": "GitRepositoryInclude specifies a local reference to a GitRepository which Artifact (sub-)contents must be included, and where they should be placed.", + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", "properties": { "fromPath": { - "description": "FromPath specifies the path to copy contents from, defaults to the root of the Artifact.", + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", "type": "string" }, "repository": { - "description": "GitRepositoryRef specifies the GitRepository which Artifact contents must be included.", + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", "properties": { "name": { "description": "Name of the referent.", @@ -43,7 +43,7 @@ "additionalProperties": false }, "toPath": { - "description": "ToPath specifies the path to copy contents to, defaults to the name of the GitRepositoryRef.", + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", "type": "string" } }, @@ -56,12 +56,12 @@ "type": "array" }, "interval": { - "description": "Interval at which the GitRepository URL is checked for updates. This interval is approximate and may be subject to jitter to ensure efficient use of resources.", + "description": "Interval at which the GitRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "proxySecretRef": { - "description": "ProxySecretRef specifies the Secret containing the proxy configuration to use while communicating with the Git server.", + "description": "ProxySecretRef specifies the Secret containing the proxy configuration\nto use while communicating with the Git server.", "properties": { "name": { "description": "Name of the referent.", @@ -75,22 +75,22 @@ "additionalProperties": false }, "recurseSubmodules": { - "description": "RecurseSubmodules enables the initialization of all submodules within the GitRepository as cloned from the URL, using their default settings.", + "description": "RecurseSubmodules enables the initialization of all submodules within\nthe GitRepository as cloned from the URL, using their default settings.", "type": "boolean" }, "ref": { - "description": "Reference specifies the Git reference to resolve and monitor for changes, defaults to the 'master' branch.", + "description": "Reference specifies the Git reference to resolve and monitor for\nchanges, defaults to the 'master' branch.", "properties": { "branch": { "description": "Branch to check out, defaults to 'master' if no other field is defined.", "type": "string" }, "commit": { - "description": "Commit SHA to check out, takes precedence over all reference fields. \n This can be combined with Branch to shallow clone the branch, in which the commit is expected to exist.", + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", "type": "string" }, "name": { - "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer. \n It must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description Examples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", "type": "string" }, "semver": { @@ -106,7 +106,7 @@ "additionalProperties": false }, "secretRef": { - "description": "SecretRef specifies the Secret containing authentication credentials for the GitRepository. For HTTPS repositories the Secret must contain 'username' and 'password' fields for basic auth or 'bearerToken' field for token auth. For SSH repositories the Secret must contain 'identity' and 'known_hosts' fields.", + "description": "SecretRef specifies the Secret containing authentication credentials for\nthe GitRepository.\nFor HTTPS repositories the Secret must contain 'username' and 'password'\nfields for basic auth or 'bearerToken' field for token auth.\nFor SSH repositories the Secret must contain 'identity'\nand 'known_hosts' fields.", "properties": { "name": { "description": "Name of the referent.", @@ -120,7 +120,7 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend the reconciliation of this GitRepository.", + "description": "Suspend tells the controller to suspend the reconciliation of this\nGitRepository.", "type": "boolean" }, "timeout": { @@ -135,11 +135,11 @@ "type": "string" }, "verify": { - "description": "Verification specifies the configuration to verify the Git commit signature(s).", + "description": "Verification specifies the configuration to verify the Git commit\nsignature(s).", "properties": { "mode": { "default": "HEAD", - "description": "Mode specifies which Git object(s) should be verified. \n The variants \"head\" and \"HEAD\" both imply the same thing, i.e. verify the commit that the HEAD of the Git repository points to. The variant \"head\" solely exists to ensure backwards compatibility.", + "description": "Mode specifies which Git object(s) should be verified.\n\n\nThe variants \"head\" and \"HEAD\" both imply the same thing, i.e. verify\nthe commit that the HEAD of the Git repository points to. The variant\n\"head\" solely exists to ensure backwards compatibility.", "enum": [ "head", "HEAD", @@ -149,7 +149,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Secret containing the public keys of trusted Git authors.", + "description": "SecretRef specifies the Secret containing the public keys of trusted Git\nauthors.", "properties": { "name": { "description": "Name of the referent.", @@ -192,7 +192,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -204,11 +204,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -217,7 +217,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -233,26 +233,26 @@ "conditions": { "description": "Conditions holds the conditions for the GitRepository.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -268,7 +268,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -287,7 +287,7 @@ "type": "array" }, "includedArtifacts": { - "description": "IncludedArtifacts contains a list of the last successfully included Artifacts as instructed by GitRepositorySpec.Include.", + "description": "IncludedArtifacts contains a list of the last successfully included\nArtifacts as instructed by GitRepositorySpec.Include.", "items": { "description": "Artifact represents the output of a Source reconciliation.", "properties": { @@ -297,7 +297,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -309,11 +309,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -322,7 +322,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -338,29 +338,29 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { - "description": "ObservedGeneration is the last observed generation of the GitRepository object.", + "description": "ObservedGeneration is the last observed generation of the GitRepository\nobject.", "format": "int64", "type": "integer" }, "observedIgnore": { - "description": "ObservedIgnore is the observed exclusion patterns used for constructing the source artifact.", + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", "type": "string" }, "observedInclude": { - "description": "ObservedInclude is the observed list of GitRepository resources used to produce the current Artifact.", + "description": "ObservedInclude is the observed list of GitRepository resources used to\nproduce the current Artifact.", "items": { - "description": "GitRepositoryInclude specifies a local reference to a GitRepository which Artifact (sub-)contents must be included, and where they should be placed.", + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", "properties": { "fromPath": { - "description": "FromPath specifies the path to copy contents from, defaults to the root of the Artifact.", + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", "type": "string" }, "repository": { - "description": "GitRepositoryRef specifies the GitRepository which Artifact contents must be included.", + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", "properties": { "name": { "description": "Name of the referent.", @@ -374,7 +374,7 @@ "additionalProperties": false }, "toPath": { - "description": "ToPath specifies the path to copy contents to, defaults to the name of the GitRepositoryRef.", + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", "type": "string" } }, @@ -387,11 +387,11 @@ "type": "array" }, "observedRecurseSubmodules": { - "description": "ObservedRecurseSubmodules is the observed resource submodules configuration used to produce the current Artifact.", + "description": "ObservedRecurseSubmodules is the observed resource submodules\nconfiguration used to produce the current Artifact.", "type": "boolean" }, "sourceVerificationMode": { - "description": "SourceVerificationMode is the last used verification mode indicating which Git object(s) have been verified.", + "description": "SourceVerificationMode is the last used verification mode indicating\nwhich Git object(s) have been verified.", "type": "string" } }, diff --git a/gitrepository-source-v1beta1.json b/gitrepository-source-v1beta1.json index 55547cb..915d19d 100644 --- a/gitrepository-source-v1beta1.json +++ b/gitrepository-source-v1beta1.json @@ -2,11 +2,11 @@ "description": "GitRepository is the Schema for the gitrepositories API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -19,15 +19,15 @@ "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -45,7 +45,7 @@ }, "gitImplementation": { "default": "go-git", - "description": "Determines which git client library to use. Defaults to go-git, valid values are ('go-git', 'libgit2').", + "description": "Determines which git client library to use.\nDefaults to go-git, valid values are ('go-git', 'libgit2').", "enum": [ "go-git", "libgit2" @@ -53,7 +53,7 @@ "type": "string" }, "ignore": { - "description": "Ignore overrides the set of excluded patterns in the .sourceignore format (which is the same as .gitignore). If not provided, a default will be used, consult the documentation for your version to find out what those are.", + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", "type": "string" }, "include": { @@ -97,11 +97,11 @@ "type": "string" }, "recurseSubmodules": { - "description": "When enabled, after the clone is created, initializes all submodules within, using their default settings. This option is available only when using the 'go-git' GitImplementation.", + "description": "When enabled, after the clone is created, initializes all submodules within,\nusing their default settings.\nThis option is available only when using the 'go-git' GitImplementation.", "type": "boolean" }, "ref": { - "description": "The Git reference to checkout and monitor for changes, defaults to master branch.", + "description": "The Git reference to checkout and monitor for changes, defaults to\nmaster branch.", "properties": { "branch": { "description": "The Git branch to checkout, defaults to master.", @@ -124,7 +124,7 @@ "additionalProperties": false }, "secretRef": { - "description": "The secret name containing the Git credentials. For HTTPS repositories the secret must contain username and password fields. For SSH repositories the secret must contain identity and known_hosts fields.", + "description": "The secret name containing the Git credentials.\nFor HTTPS repositories the secret must contain username and password\nfields.\nFor SSH repositories the secret must contain identity and known_hosts\nfields.", "properties": { "name": { "description": "Name of the referent.", @@ -204,7 +204,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of this artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", "format": "date-time", "type": "string" }, @@ -213,7 +213,7 @@ "type": "string" }, "revision": { - "description": "Revision is a human readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm chart version, etc.", + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", "type": "string" }, "url": { @@ -231,26 +231,26 @@ "conditions": { "description": "Conditions holds the conditions for the GitRepository.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -266,7 +266,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -294,7 +294,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of this artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", "format": "date-time", "type": "string" }, @@ -303,7 +303,7 @@ "type": "string" }, "revision": { - "description": "Revision is a human readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm chart version, etc.", + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", "type": "string" }, "url": { @@ -321,7 +321,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { @@ -330,7 +330,7 @@ "type": "integer" }, "url": { - "description": "URL is the download link for the artifact output of the last repository sync.", + "description": "URL is the download link for the artifact output of the last repository\nsync.", "type": "string" } }, diff --git a/gitrepository-source-v1beta2.json b/gitrepository-source-v1beta2.json index e57bb05..7034e11 100644 --- a/gitrepository-source-v1beta2.json +++ b/gitrepository-source-v1beta2.json @@ -2,32 +2,32 @@ "description": "GitRepository is the Schema for the gitrepositories API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "GitRepositorySpec specifies the required configuration to produce an Artifact for a Git repository.", + "description": "GitRepositorySpec specifies the required configuration to produce an\nArtifact for a Git repository.", "properties": { "accessFrom": { - "description": "AccessFrom specifies an Access Control List for allowing cross-namespace references to this object. NOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -45,7 +45,7 @@ }, "gitImplementation": { "default": "go-git", - "description": "GitImplementation specifies which Git client library implementation to use. Defaults to 'go-git', valid values are ('go-git', 'libgit2'). Deprecated: gitImplementation is deprecated now that 'go-git' is the only supported implementation.", + "description": "GitImplementation specifies which Git client library implementation to\nuse. Defaults to 'go-git', valid values are ('go-git', 'libgit2').\nDeprecated: gitImplementation is deprecated now that 'go-git' is the\nonly supported implementation.", "enum": [ "go-git", "libgit2" @@ -53,20 +53,20 @@ "type": "string" }, "ignore": { - "description": "Ignore overrides the set of excluded patterns in the .sourceignore format (which is the same as .gitignore). If not provided, a default will be used, consult the documentation for your version to find out what those are.", + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", "type": "string" }, "include": { - "description": "Include specifies a list of GitRepository resources which Artifacts should be included in the Artifact produced for this GitRepository.", + "description": "Include specifies a list of GitRepository resources which Artifacts\nshould be included in the Artifact produced for this GitRepository.", "items": { - "description": "GitRepositoryInclude specifies a local reference to a GitRepository which Artifact (sub-)contents must be included, and where they should be placed.", + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", "properties": { "fromPath": { - "description": "FromPath specifies the path to copy contents from, defaults to the root of the Artifact.", + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", "type": "string" }, "repository": { - "description": "GitRepositoryRef specifies the GitRepository which Artifact contents must be included.", + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", "properties": { "name": { "description": "Name of the referent.", @@ -80,7 +80,7 @@ "additionalProperties": false }, "toPath": { - "description": "ToPath specifies the path to copy contents to, defaults to the name of the GitRepositoryRef.", + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", "type": "string" } }, @@ -98,22 +98,22 @@ "type": "string" }, "recurseSubmodules": { - "description": "RecurseSubmodules enables the initialization of all submodules within the GitRepository as cloned from the URL, using their default settings.", + "description": "RecurseSubmodules enables the initialization of all submodules within\nthe GitRepository as cloned from the URL, using their default settings.", "type": "boolean" }, "ref": { - "description": "Reference specifies the Git reference to resolve and monitor for changes, defaults to the 'master' branch.", + "description": "Reference specifies the Git reference to resolve and monitor for\nchanges, defaults to the 'master' branch.", "properties": { "branch": { "description": "Branch to check out, defaults to 'master' if no other field is defined.", "type": "string" }, "commit": { - "description": "Commit SHA to check out, takes precedence over all reference fields. \n This can be combined with Branch to shallow clone the branch, in which the commit is expected to exist.", + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", "type": "string" }, "name": { - "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer. \n It must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description Examples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", "type": "string" }, "semver": { @@ -129,7 +129,7 @@ "additionalProperties": false }, "secretRef": { - "description": "SecretRef specifies the Secret containing authentication credentials for the GitRepository. For HTTPS repositories the Secret must contain 'username' and 'password' fields for basic auth or 'bearerToken' field for token auth. For SSH repositories the Secret must contain 'identity' and 'known_hosts' fields.", + "description": "SecretRef specifies the Secret containing authentication credentials for\nthe GitRepository.\nFor HTTPS repositories the Secret must contain 'username' and 'password'\nfields for basic auth or 'bearerToken' field for token auth.\nFor SSH repositories the Secret must contain 'identity'\nand 'known_hosts' fields.", "properties": { "name": { "description": "Name of the referent.", @@ -143,7 +143,7 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend the reconciliation of this GitRepository.", + "description": "Suspend tells the controller to suspend the reconciliation of this\nGitRepository.", "type": "boolean" }, "timeout": { @@ -158,7 +158,7 @@ "type": "string" }, "verify": { - "description": "Verification specifies the configuration to verify the Git commit signature(s).", + "description": "Verification specifies the configuration to verify the Git commit\nsignature(s).", "properties": { "mode": { "description": "Mode specifies what Git object should be verified, currently ('head').", @@ -168,7 +168,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Secret containing the public keys of trusted Git authors.", + "description": "SecretRef specifies the Secret containing the public keys of trusted Git\nauthors.", "properties": { "name": { "description": "Name of the referent.", @@ -212,7 +212,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -224,11 +224,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -237,7 +237,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -253,26 +253,26 @@ "conditions": { "description": "Conditions holds the conditions for the GitRepository.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -288,7 +288,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -307,11 +307,11 @@ "type": "array" }, "contentConfigChecksum": { - "description": "ContentConfigChecksum is a checksum of all the configurations related to the content of the source artifact: - .spec.ignore - .spec.recurseSubmodules - .spec.included and the checksum of the included artifacts observed in .status.observedGeneration version of the object. This can be used to determine if the content of the included repository has changed. It has the format of `:`, for example: `sha256:`. \n Deprecated: Replaced with explicit fields for observed artifact content config in the status.", + "description": "ContentConfigChecksum is a checksum of all the configurations related to\nthe content of the source artifact:\n - .spec.ignore\n - .spec.recurseSubmodules\n - .spec.included and the checksum of the included artifacts\nobserved in .status.observedGeneration version of the object. This can\nbe used to determine if the content of the included repository has\nchanged.\nIt has the format of `:`, for example: `sha256:`.\n\n\nDeprecated: Replaced with explicit fields for observed artifact content\nconfig in the status.", "type": "string" }, "includedArtifacts": { - "description": "IncludedArtifacts contains a list of the last successfully included Artifacts as instructed by GitRepositorySpec.Include.", + "description": "IncludedArtifacts contains a list of the last successfully included\nArtifacts as instructed by GitRepositorySpec.Include.", "items": { "description": "Artifact represents the output of a Source reconciliation.", "properties": { @@ -321,7 +321,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -333,11 +333,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -346,7 +346,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -362,29 +362,29 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { - "description": "ObservedGeneration is the last observed generation of the GitRepository object.", + "description": "ObservedGeneration is the last observed generation of the GitRepository\nobject.", "format": "int64", "type": "integer" }, "observedIgnore": { - "description": "ObservedIgnore is the observed exclusion patterns used for constructing the source artifact.", + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", "type": "string" }, "observedInclude": { - "description": "ObservedInclude is the observed list of GitRepository resources used to to produce the current Artifact.", + "description": "ObservedInclude is the observed list of GitRepository resources used to\nto produce the current Artifact.", "items": { - "description": "GitRepositoryInclude specifies a local reference to a GitRepository which Artifact (sub-)contents must be included, and where they should be placed.", + "description": "GitRepositoryInclude specifies a local reference to a GitRepository which\nArtifact (sub-)contents must be included, and where they should be placed.", "properties": { "fromPath": { - "description": "FromPath specifies the path to copy contents from, defaults to the root of the Artifact.", + "description": "FromPath specifies the path to copy contents from, defaults to the root\nof the Artifact.", "type": "string" }, "repository": { - "description": "GitRepositoryRef specifies the GitRepository which Artifact contents must be included.", + "description": "GitRepositoryRef specifies the GitRepository which Artifact contents\nmust be included.", "properties": { "name": { "description": "Name of the referent.", @@ -398,7 +398,7 @@ "additionalProperties": false }, "toPath": { - "description": "ToPath specifies the path to copy contents to, defaults to the name of the GitRepositoryRef.", + "description": "ToPath specifies the path to copy contents to, defaults to the name of\nthe GitRepositoryRef.", "type": "string" } }, @@ -411,11 +411,11 @@ "type": "array" }, "observedRecurseSubmodules": { - "description": "ObservedRecurseSubmodules is the observed resource submodules configuration used to produce the current Artifact.", + "description": "ObservedRecurseSubmodules is the observed resource submodules\nconfiguration used to produce the current Artifact.", "type": "boolean" }, "url": { - "description": "URL is the dynamic fetch link for the latest Artifact. It is provided on a \"best effort\" basis, and using the precise GitRepositoryStatus.Artifact data is recommended.", + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nGitRepositoryStatus.Artifact data is recommended.", "type": "string" } }, diff --git a/helmchart-source-v1.json b/helmchart-source-v1.json new file mode 100644 index 0000000..4c05e1c --- /dev/null +++ b/helmchart-source-v1.json @@ -0,0 +1,292 @@ +{ + "description": "HelmChart is the Schema for the helmcharts API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string" + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string" + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmChartSpec specifies the desired state of a Helm chart.", + "properties": { + "chart": { + "description": "Chart is the name or path the Helm chart is available at in the\nSourceRef.", + "type": "string" + }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values\nfiles rather than failing.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the HelmChart SourceRef is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "ReconcileStrategy determines what enables the creation of a new artifact.\nValid values are ('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "SourceRef is the reference to the Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository',\n'Bucket').", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nsource.", + "type": "boolean" + }, + "valuesFiles": { + "description": "ValuesFiles is an alternative list of values files to use as the chart\nvalues (values.yaml is not included by default), expected to be a\nrelative path in the SourceRef.\nValues files are merged in the order of this list with the last file\noverriding the first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported when using HelmRepository source with spec.type 'oci'.\nChart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", + "properties": { + "matchOIDCIdentity": { + "description": "MatchOIDCIdentity specifies the identity matching criteria to use\nwhile verifying an OCI artifact which was signed using Cosign keyless\nsigning. The artifact's identity is deemed to be verified if any of the\nspecified matchers match against the identity.", + "items": { + "description": "OIDCIdentityMatch specifies options for verifying the certificate identity,\ni.e. the issuer and the subject of the certificate.", + "properties": { + "issuer": { + "description": "Issuer specifies the regex pattern to match against to verify\nthe OIDC issuer in the Fulcio certificate. The pattern must be a\nvalid Go regular expression.", + "type": "string" + }, + "subject": { + "description": "Subject specifies the regex pattern to match against to verify\nthe identity subject in the Fulcio certificate. The pattern must\nbe a valid Go regular expression.", + "type": "string" + } + }, + "required": [ + "issuer", + "subject" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Artifact.", + "enum": [ + "cosign", + "notation" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "version": { + "default": "*", + "description": "Version is the chart version semver expression, ignored for charts from\nGitRepository and Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "interval", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmChartStatus records the observed state of the HelmChart.", + "properties": { + "artifact": { + "description": "Artifact represents the output of the last successful reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmChart.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedChartName": { + "description": "ObservedChartName is the last observed chart name as specified by the\nresolved chart reference.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the HelmChart\nobject.", + "format": "int64", + "type": "integer" + }, + "observedSourceArtifactRevision": { + "description": "ObservedSourceArtifactRevision is the last observed Artifact.Revision\nof the HelmChartSpec.SourceRef.", + "type": "string" + }, + "observedValuesFiles": { + "description": "ObservedValuesFiles are the observed value files of the last successful\nreconciliation.\nIt matches the chart in the last successfully reconciled artifact.", + "items": { + "type": "string" + }, + "type": "array" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nBucketStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" +} \ No newline at end of file diff --git a/helmchart-source-v1beta1.json b/helmchart-source-v1beta1.json index f100d8c..baa5539 100644 --- a/helmchart-source-v1beta1.json +++ b/helmchart-source-v1beta1.json @@ -2,11 +2,11 @@ "description": "HelmChart is the Schema for the helmcharts API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -19,15 +19,15 @@ "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -53,7 +53,7 @@ }, "reconcileStrategy": { "default": "ChartVersion", - "description": "Determines what enables the creation of a new artifact. Valid values are ('ChartVersion', 'Revision'). See the documentation of the values for an explanation on their behavior. Defaults to ChartVersion when omitted.", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", "enum": [ "ChartVersion", "Revision" @@ -68,7 +68,7 @@ "type": "string" }, "kind": { - "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository', 'Bucket').", + "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository',\n'Bucket').", "enum": [ "HelmRepository", "GitRepository", @@ -93,11 +93,11 @@ "type": "boolean" }, "valuesFile": { - "description": "Alternative values file to use as the default chart values, expected to be a relative path in the SourceRef. Deprecated in favor of ValuesFiles, for backwards compatibility the file defined here is merged before the ValuesFiles items. Ignored when omitted.", + "description": "Alternative values file to use as the default chart values, expected to\nbe a relative path in the SourceRef. Deprecated in favor of ValuesFiles,\nfor backwards compatibility the file defined here is merged before the\nValuesFiles items. Ignored when omitted.", "type": "string" }, "valuesFiles": { - "description": "Alternative list of values files to use as the chart values (values.yaml is not included by default), expected to be a relative path in the SourceRef. Values files are merged in the order of this list with the last file overriding the first. Ignored when omitted.", + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", "items": { "type": "string" }, @@ -105,7 +105,7 @@ }, "version": { "default": "*", - "description": "The chart version semver expression, ignored for charts from GitRepository and Bucket sources. Defaults to latest when omitted.", + "description": "The chart version semver expression, ignored for charts from GitRepository\nand Bucket sources. Defaults to latest when omitted.", "type": "string" } }, @@ -131,7 +131,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of this artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", "format": "date-time", "type": "string" }, @@ -140,7 +140,7 @@ "type": "string" }, "revision": { - "description": "Revision is a human readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm chart version, etc.", + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", "type": "string" }, "url": { @@ -158,26 +158,26 @@ "conditions": { "description": "Conditions holds the conditions for the HelmChart.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -193,7 +193,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -212,7 +212,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { diff --git a/helmchart-source-v1beta2.json b/helmchart-source-v1beta2.json index 7315c46..4c2b567 100644 --- a/helmchart-source-v1beta2.json +++ b/helmchart-source-v1beta2.json @@ -2,11 +2,11 @@ "description": "HelmChart is the Schema for the helmcharts API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,18 +16,18 @@ "description": "HelmChartSpec specifies the desired state of a Helm chart.", "properties": { "accessFrom": { - "description": "AccessFrom specifies an Access Control List for allowing cross-namespace references to this object. NOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -44,17 +44,21 @@ "additionalProperties": false }, "chart": { - "description": "Chart is the name or path the Helm chart is available at in the SourceRef.", + "description": "Chart is the name or path the Helm chart is available at in the\nSourceRef.", "type": "string" }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values\nfiles rather than failing.", + "type": "boolean" + }, "interval": { - "description": "Interval at which the HelmChart SourceRef is checked for updates. This interval is approximate and may be subject to jitter to ensure efficient use of resources.", + "description": "Interval at which the HelmChart SourceRef is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "reconcileStrategy": { "default": "ChartVersion", - "description": "ReconcileStrategy determines what enables the creation of a new artifact. Valid values are ('ChartVersion', 'Revision'). See the documentation of the values for an explanation on their behavior. Defaults to ChartVersion when omitted.", + "description": "ReconcileStrategy determines what enables the creation of a new artifact.\nValid values are ('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", "enum": [ "ChartVersion", "Revision" @@ -69,7 +73,7 @@ "type": "string" }, "kind": { - "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository', 'Bucket').", + "description": "Kind of the referent, valid values are ('HelmRepository', 'GitRepository',\n'Bucket').", "enum": [ "HelmRepository", "GitRepository", @@ -90,34 +94,34 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend the reconciliation of this source.", + "description": "Suspend tells the controller to suspend the reconciliation of this\nsource.", "type": "boolean" }, "valuesFile": { - "description": "ValuesFile is an alternative values file to use as the default chart values, expected to be a relative path in the SourceRef. Deprecated in favor of ValuesFiles, for backwards compatibility the file specified here is merged before the ValuesFiles items. Ignored when omitted.", + "description": "ValuesFile is an alternative values file to use as the default chart\nvalues, expected to be a relative path in the SourceRef. Deprecated in\nfavor of ValuesFiles, for backwards compatibility the file specified here\nis merged before the ValuesFiles items. Ignored when omitted.", "type": "string" }, "valuesFiles": { - "description": "ValuesFiles is an alternative list of values files to use as the chart values (values.yaml is not included by default), expected to be a relative path in the SourceRef. Values files are merged in the order of this list with the last file overriding the first. Ignored when omitted.", + "description": "ValuesFiles is an alternative list of values files to use as the chart\nvalues (values.yaml is not included by default), expected to be a\nrelative path in the SourceRef.\nValues files are merged in the order of this list with the last file\noverriding the first. Ignored when omitted.", "items": { "type": "string" }, "type": "array" }, "verify": { - "description": "Verify contains the secret name containing the trusted public keys used to verify the signature and specifies which provider to use to check whether OCI image is authentic. This field is only supported when using HelmRepository source with spec.type 'oci'. Chart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported when using HelmRepository source with spec.type 'oci'.\nChart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", "properties": { "matchOIDCIdentity": { - "description": "MatchOIDCIdentity specifies the identity matching criteria to use while verifying an OCI artifact which was signed using Cosign keyless signing. The artifact's identity is deemed to be verified if any of the specified matchers match against the identity.", + "description": "MatchOIDCIdentity specifies the identity matching criteria to use\nwhile verifying an OCI artifact which was signed using Cosign keyless\nsigning. The artifact's identity is deemed to be verified if any of the\nspecified matchers match against the identity.", "items": { - "description": "OIDCIdentityMatch specifies options for verifying the certificate identity, i.e. the issuer and the subject of the certificate.", + "description": "OIDCIdentityMatch specifies options for verifying the certificate identity,\ni.e. the issuer and the subject of the certificate.", "properties": { "issuer": { - "description": "Issuer specifies the regex pattern to match against to verify the OIDC issuer in the Fulcio certificate. The pattern must be a valid Go regular expression.", + "description": "Issuer specifies the regex pattern to match against to verify\nthe OIDC issuer in the Fulcio certificate. The pattern must be a\nvalid Go regular expression.", "type": "string" }, "subject": { - "description": "Subject specifies the regex pattern to match against to verify the identity subject in the Fulcio certificate. The pattern must be a valid Go regular expression.", + "description": "Subject specifies the regex pattern to match against to verify\nthe identity subject in the Fulcio certificate. The pattern must\nbe a valid Go regular expression.", "type": "string" } }, @@ -134,12 +138,13 @@ "default": "cosign", "description": "Provider specifies the technology used to sign the OCI Artifact.", "enum": [ - "cosign" + "cosign", + "notation" ], "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Kubernetes Secret containing the trusted public keys.", + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", "properties": { "name": { "description": "Name of the referent.", @@ -161,7 +166,7 @@ }, "version": { "default": "*", - "description": "Version is the chart version semver expression, ignored for charts from GitRepository and Bucket sources. Defaults to latest when omitted.", + "description": "Version is the chart version semver expression, ignored for charts from\nGitRepository and Bucket sources. Defaults to latest when omitted.", "type": "string" } }, @@ -188,7 +193,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -200,11 +205,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -213,7 +218,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -229,26 +234,26 @@ "conditions": { "description": "Conditions holds the conditions for the HelmChart.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -264,7 +269,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -283,24 +288,31 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedChartName": { - "description": "ObservedChartName is the last observed chart name as specified by the resolved chart reference.", + "description": "ObservedChartName is the last observed chart name as specified by the\nresolved chart reference.", "type": "string" }, "observedGeneration": { - "description": "ObservedGeneration is the last observed generation of the HelmChart object.", + "description": "ObservedGeneration is the last observed generation of the HelmChart\nobject.", "format": "int64", "type": "integer" }, "observedSourceArtifactRevision": { - "description": "ObservedSourceArtifactRevision is the last observed Artifact.Revision of the HelmChartSpec.SourceRef.", + "description": "ObservedSourceArtifactRevision is the last observed Artifact.Revision\nof the HelmChartSpec.SourceRef.", "type": "string" }, + "observedValuesFiles": { + "description": "ObservedValuesFiles are the observed value files of the last successful\nreconciliation.\nIt matches the chart in the last successfully reconciled artifact.", + "items": { + "type": "string" + }, + "type": "array" + }, "url": { - "description": "URL is the dynamic fetch link for the latest Artifact. It is provided on a \"best effort\" basis, and using the precise BucketStatus.Artifact data is recommended.", + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nBucketStatus.Artifact data is recommended.", "type": "string" } }, diff --git a/helmrelease-helm-v2.json b/helmrelease-helm-v2.json new file mode 100644 index 0000000..22ee491 --- /dev/null +++ b/helmrelease-helm-v2.json @@ -0,0 +1,1042 @@ +{ + "description": "HelmRelease is the Schema for the helmreleases API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string" + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string" + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmReleaseSpec defines the desired state of a Helm release.", + "properties": { + "chart": { + "description": "Chart defines the template of the v1.HelmChart that should be created\nfor this HelmRelease.", + "properties": { + "metadata": { + "description": "ObjectMeta holds the template for metadata like labels and annotations.", + "properties": { + "annotations": { + "additionalProperties": { + "type": "string" + }, + "description": "Annotations is an unstructured key value map stored with a resource that may be\nset by external tools to store and retrieve arbitrary metadata. They are not\nqueryable and should be preserved when modifying objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", + "type": "object" + }, + "labels": { + "additionalProperties": { + "type": "string" + }, + "description": "Map of string keys and values that can be used to organize and categorize\n(scope and select) objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "spec": { + "description": "Spec holds the template for the v1.HelmChartSpec for this HelmRelease.", + "properties": { + "chart": { + "description": "The name or path the Helm chart is available at in the SourceRef.", + "maxLength": 2048, + "minLength": 1, + "type": "string" + }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values files rather than failing.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which to check the v1.Source for updates. Defaults to\n'HelmReleaseSpec.Interval'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "reconcileStrategy": { + "default": "ChartVersion", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", + "enum": [ + "ChartVersion", + "Revision" + ], + "type": "string" + }, + "sourceRef": { + "description": "The name and namespace of the v1.Source the chart is available at.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "HelmRepository", + "GitRepository", + "Bucket" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "valuesFiles": { + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", + "items": { + "type": "string" + }, + "type": "array" + }, + "verify": { + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported for OCI sources.\nChart dependencies, which are not bundled in the umbrella chart artifact,\nare not verified.", + "properties": { + "provider": { + "default": "cosign", + "description": "Provider specifies the technology used to sign the OCI Helm chart.", + "enum": [ + "cosign", + "notation" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "provider" + ], + "type": "object", + "additionalProperties": false + }, + "version": { + "default": "*", + "description": "Version semver expression, ignored for charts from v1.GitRepository and\nv1beta2.Bucket sources. Defaults to latest when omitted.", + "type": "string" + } + }, + "required": [ + "chart", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "spec" + ], + "type": "object", + "additionalProperties": false + }, + "chartRef": { + "description": "ChartRef holds a reference to a source controller resource containing the\nHelm chart artifact.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "HelmChart" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "dependsOn": { + "description": "DependsOn may contain a meta.NamespacedObjectReference slice with\nreferences to HelmRelease resources that must be ready before this HelmRelease\ncan be reconciled.", + "items": { + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, when not specified it acts as LocalObjectReference.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "driftDetection": { + "description": "DriftDetection holds the configuration for detecting and handling\ndifferences between the manifest in the Helm storage and the resources\ncurrently existing in the cluster.", + "properties": { + "ignore": { + "description": "Ignore contains a list of rules for specifying which changes to ignore\nduring diffing.", + "items": { + "description": "IgnoreRule defines a rule to selectively disregard specific changes during\nthe drift detection process.", + "properties": { + "paths": { + "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from\nconsideration in a Kubernetes object.", + "items": { + "type": "string" + }, + "type": "array" + }, + "target": { + "description": "Target is a selector for specifying Kubernetes objects to which this\nrule applies.\nIf Target is not set, the Paths will be ignored for all Kubernetes\nobjects within the manifest of the Helm release.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "paths" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "mode": { + "description": "Mode defines how differences should be handled between the Helm manifest\nand the manifest currently applied to the cluster.\nIf not explicitly set, it defaults to DiffModeDisabled.", + "enum": [ + "enabled", + "warn", + "disabled" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "install": { + "description": "Install holds the configuration for Helm install actions for this HelmRelease.", + "properties": { + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Create` and if omitted\nCRDs are installed but not updated.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are applied (installed) during Helm install action.\nWith this option users can opt in to CRD replace existing CRDs on Helm\ninstall actions, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "createNamespace": { + "description": "CreateNamespace tells the Helm install action to create the\nHelmReleaseSpec.TargetNamespace if it does not exist yet.\nOn uninstall, the namespace will not be garbage collected.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm install action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm install action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\ninstall has been performed.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm install\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an install action but fail. Defaults to\n'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false'.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using an uninstall, is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + }, + "replace": { + "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only\nif that name is a deleted release which remains in the history.", + "type": "boolean" + }, + "skipCRDs": { + "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default,\nCRDs are installed if not already present.\n\n\nDeprecated use CRD policy (`crds`) attribute with value `Skip` instead.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm install action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "Interval at which to reconcile the Helm release.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "kubeConfig": { + "description": "KubeConfig for reconciling the HelmRelease on a remote cluster.\nWhen used in combination with HelmReleaseSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when HelmReleaseSpec.ServiceAccountName\nis empty.", + "properties": { + "secretRef": { + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", + "properties": { + "key": { + "description": "Key in the Secret, when not specified an implementation-specific default key is used.", + "type": "string" + }, + "name": { + "description": "Name of the Secret.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "secretRef" + ], + "type": "object", + "additionalProperties": false + }, + "maxHistory": { + "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease.\nUse '0' for an unlimited number of revisions; defaults to '5'.", + "type": "integer" + }, + "persistentClient": { + "description": "PersistentClient tells the controller to use a persistent Kubernetes\nclient for this release. When enabled, the client will be reused for the\nduration of the reconciliation, instead of being created and destroyed\nfor each (step of a) Helm action.\n\n\nThis can improve performance, but may cause issues with some Helm charts\nthat for example do create Custom Resource Definitions during installation\noutside Helm's CRD lifecycle hooks, which are then not observed to be\navailable by e.g. post-install hooks.\n\n\nIf not set, it defaults to true.", + "type": "boolean" + }, + "postRenderers": { + "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order\nof their definition.", + "items": { + "description": "PostRenderer contains a Helm PostRenderer specification.", + "properties": { + "kustomize": { + "description": "Kustomization to apply as PostRenderer.", + "properties": { + "images": { + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", + "items": { + "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", + "properties": { + "digest": { + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", + "type": "string" + }, + "name": { + "description": "Name is a tag-less image name.", + "type": "string" + }, + "newName": { + "description": "NewName is the value used to replace the original name.", + "type": "string" + }, + "newTag": { + "description": "NewTag is the value used to replace the original tag.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "patches": { + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", + "items": { + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", + "properties": { + "patch": { + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", + "type": "string" + }, + "target": { + "description": "Target points to the resources that the patch document should be applied to.", + "properties": { + "annotationSelector": { + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", + "type": "string" + }, + "group": { + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "kind": { + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + }, + "labelSelector": { + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", + "type": "string" + }, + "name": { + "description": "Name to match resources with.", + "type": "string" + }, + "namespace": { + "description": "Namespace to select resources from.", + "type": "string" + }, + "version": { + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "patch" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "releaseName": { + "description": "ReleaseName used for the Helm release. Defaults to a composition of\n'[TargetNamespace-]Name'.", + "maxLength": 53, + "minLength": 1, + "type": "string" + }, + "rollback": { + "description": "Rollback holds the configuration for Helm rollback actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nrollback action when it fails.", + "type": "boolean" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nrollback has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "recreate": { + "description": "Recreate performs pod restarts for the resource if applicable.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm rollback action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "serviceAccountName": { + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this HelmRelease.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace used for the Helm storage.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "suspend": { + "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease,\nit does not apply to already started reconciliations. Defaults to false.", + "type": "boolean" + }, + "targetNamespace": { + "description": "TargetNamespace to target when performing operations for the HelmRelease.\nDefaults to the namespace of the HelmRelease.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "test": { + "description": "Test holds the configuration for Helm test actions for this HelmRelease.", + "properties": { + "enable": { + "description": "Enable enables Helm test actions for this HelmRelease after an Helm install\nor upgrade action has been performed.", + "type": "boolean" + }, + "filters": { + "description": "Filters is a list of tests to run or exclude from running.", + "items": { + "description": "Filter holds the configuration for individual Helm test filters.", + "properties": { + "exclude": { + "description": "Exclude specifies whether the named test should be excluded.", + "type": "boolean" + }, + "name": { + "description": "Name is the name of the test.", + "maxLength": 253, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "ignoreFailures": { + "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests\nare run but fail. Can be overwritten for tests run after install or upgrade\nactions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation during\nthe performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs\nfor hooks) during the performance of a Helm action. Defaults to '5m0s'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "uninstall": { + "description": "Uninstall holds the configuration for Helm uninstall actions for this HelmRelease.", + "properties": { + "deletionPropagation": { + "default": "background", + "description": "DeletionPropagation specifies the deletion propagation policy when\na Helm uninstall is performed.", + "enum": [ + "background", + "foreground", + "orphan" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm rollback action.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables waiting for all the resources to be deleted after\na Helm uninstall is performed.", + "type": "boolean" + }, + "keepHistory": { + "description": "KeepHistory tells Helm to remove all associated resources and mark the\nrelease as deleted, but retain the release history.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm uninstall action. Defaults\nto 'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "upgrade": { + "description": "Upgrade holds the configuration for Helm upgrade actions for this HelmRelease.", + "properties": { + "cleanupOnFail": { + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nupgrade action when it fails.", + "type": "boolean" + }, + "crds": { + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Skip` and if omitted\nCRDs are neither installed nor upgraded.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are not applied during Helm upgrade action. With this\noption users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "enum": [ + "Skip", + "Create", + "CreateReplace" + ], + "type": "string" + }, + "disableHooks": { + "description": "DisableHooks prevents hooks from running during the Helm upgrade action.", + "type": "boolean" + }, + "disableOpenAPIValidation": { + "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", + "type": "boolean" + }, + "disableWait": { + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "disableWaitForJobs": { + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nupgrade has been performed.", + "type": "boolean" + }, + "force": { + "description": "Force forces resource updates through a replacement strategy.", + "type": "boolean" + }, + "preserveValues": { + "description": "PreserveValues will make Helm reuse the last release's values and merge in\noverrides from 'Values'. Setting this flag makes the HelmRelease\nnon-declarative.", + "type": "boolean" + }, + "remediation": { + "description": "Remediation holds the remediation configuration for when the Helm upgrade\naction for the HelmRelease fails. The default is to not perform any action.", + "properties": { + "ignoreTestFailures": { + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an upgrade action but fail.\nDefaults to 'Test.IgnoreFailures'.", + "type": "boolean" + }, + "remediateLastFailure": { + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", + "type": "boolean" + }, + "retries": { + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using 'Strategy', is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", + "type": "integer" + }, + "strategy": { + "description": "Strategy to use for failure remediation. Defaults to 'rollback'.", + "enum": [ + "rollback", + "uninstall" + ], + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "timeout": { + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm upgrade action. Defaults to\n'HelmReleaseSpec.Timeout'.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "values": { + "description": "Values holds the values for this Helm release.", + "x-kubernetes-preserve-unknown-fields": true + }, + "valuesFrom": { + "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease,\nand information about how they should be merged.", + "items": { + "description": "ValuesReference contains a reference to a resource containing Helm values,\nand optionally the key they can be found at.", + "properties": { + "kind": { + "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", + "enum": [ + "Secret", + "ConfigMap" + ], + "type": "string" + }, + "name": { + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "optional": { + "description": "Optional marks this ValuesReference as optional. When set, a not found error\nfor the values reference is ignored, but any ValuesKey, TargetPath or\ntransient error will still result in a reconciliation failure.", + "type": "boolean" + }, + "targetPath": { + "description": "TargetPath is the YAML dot notation path the value should be merged at. When\nset, the ValuesKey is expected to be a single flat value. Defaults to 'None',\nwhich results in the values getting merged at the root.", + "maxLength": 250, + "pattern": "^([a-zA-Z0-9_\\-.\\\\\\/]|\\[[0-9]{1,5}\\])+$", + "type": "string" + }, + "valuesKey": { + "description": "ValuesKey is the data key where the values.yaml or a specific value can be\nfound at. Defaults to 'values.yaml'.", + "maxLength": 253, + "pattern": "^[\\-._a-zA-Z0-9]+$", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "interval" + ], + "type": "object", + "x-kubernetes-validations": [ + { + "message": "either chart or chartRef must be set", + "rule": "(has(self.chart) && !has(self.chartRef)) || (!has(self.chart) && has(self.chartRef))" + } + ], + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmReleaseStatus defines the observed state of a HelmRelease.", + "properties": { + "conditions": { + "description": "Conditions holds the conditions for the HelmRelease.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "failures": { + "description": "Failures is the reconciliation failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "helmChart": { + "description": "HelmChart is the namespaced name of the HelmChart resource created by\nthe controller for the HelmRelease.", + "type": "string" + }, + "history": { + "description": "History holds the history of Helm releases performed for this HelmRelease\nup to the last successfully completed release.", + "items": { + "description": "Snapshot captures a point-in-time copy of the status information for a Helm release,\nas managed by the controller.", + "properties": { + "apiVersion": { + "description": "APIVersion is the API version of the Snapshot.\nProvisional: when the calculation method of the Digest field is changed,\nthis field will be used to distinguish between the old and new methods.", + "type": "string" + }, + "appVersion": { + "description": "AppVersion is the chart app version of the release object in storage.", + "type": "string" + }, + "chartName": { + "description": "ChartName is the chart name of the release object in storage.", + "type": "string" + }, + "chartVersion": { + "description": "ChartVersion is the chart version of the release object in\nstorage.", + "type": "string" + }, + "configDigest": { + "description": "ConfigDigest is the checksum of the config (better known as\n\"values\") of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "deleted": { + "description": "Deleted is when the release was deleted.", + "format": "date-time", + "type": "string" + }, + "digest": { + "description": "Digest is the checksum of the release object in storage.\nIt has the format of `:`.", + "type": "string" + }, + "firstDeployed": { + "description": "FirstDeployed is when the release was first deployed.", + "format": "date-time", + "type": "string" + }, + "lastDeployed": { + "description": "LastDeployed is when the release was last deployed.", + "format": "date-time", + "type": "string" + }, + "name": { + "description": "Name is the name of the release.", + "type": "string" + }, + "namespace": { + "description": "Namespace is the namespace the release is deployed to.", + "type": "string" + }, + "ociDigest": { + "description": "OCIDigest is the digest of the OCI artifact associated with the release.", + "type": "string" + }, + "status": { + "description": "Status is the current state of the release.", + "type": "string" + }, + "testHooks": { + "additionalProperties": { + "description": "TestHookStatus holds the status information for a test hook as observed\nto be run by the controller.", + "properties": { + "lastCompleted": { + "description": "LastCompleted is the time the test hook last completed.", + "format": "date-time", + "type": "string" + }, + "lastStarted": { + "description": "LastStarted is the time the test hook was last started.", + "format": "date-time", + "type": "string" + }, + "phase": { + "description": "Phase the test hook was observed to be in.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + }, + "description": "TestHooks is the list of test hooks for the release as observed to be\nrun by the controller.", + "type": "object" + }, + "version": { + "description": "Version is the version of the release object in storage.", + "type": "integer" + } + }, + "required": [ + "chartName", + "chartVersion", + "configDigest", + "digest", + "firstDeployed", + "lastDeployed", + "name", + "namespace", + "status", + "version" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "installFailures": { + "description": "InstallFailures is the install failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + }, + "lastAttemptedConfigDigest": { + "description": "LastAttemptedConfigDigest is the digest for the config (better known as\n\"values\") of the last reconciliation attempt.", + "type": "string" + }, + "lastAttemptedGeneration": { + "description": "LastAttemptedGeneration is the last generation the controller attempted\nto reconcile.", + "format": "int64", + "type": "integer" + }, + "lastAttemptedReleaseAction": { + "description": "LastAttemptedReleaseAction is the last release action performed for this\nHelmRelease. It is used to determine the active remediation strategy.", + "enum": [ + "install", + "upgrade" + ], + "type": "string" + }, + "lastAttemptedRevision": { + "description": "LastAttemptedRevision is the Source revision of the last reconciliation\nattempt. For OCIRepository sources, the 12 first characters of the digest are\nappended to the chart version e.g. \"1.2.3+1234567890ab\".", + "type": "string" + }, + "lastAttemptedRevisionDigest": { + "description": "LastAttemptedRevisionDigest is the digest of the last reconciliation attempt.\nThis is only set for OCIRepository sources.", + "type": "string" + }, + "lastAttemptedValuesChecksum": { + "description": "LastAttemptedValuesChecksum is the SHA1 checksum for the values of the last\nreconciliation attempt.\nDeprecated: Use LastAttemptedConfigDigest instead.", + "type": "string" + }, + "lastHandledForceAt": { + "description": "LastHandledForceAt holds the value of the most recent force request\nvalue, so a change of the annotation value can be detected.", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastHandledResetAt": { + "description": "LastHandledResetAt holds the value of the most recent reset request\nvalue, so a change of the annotation value can be detected.", + "type": "string" + }, + "lastReleaseRevision": { + "description": "LastReleaseRevision is the revision of the last successful Helm release.\nDeprecated: Use History instead.", + "type": "integer" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation.", + "format": "int64", + "type": "integer" + }, + "observedPostRenderersDigest": { + "description": "ObservedPostRenderersDigest is the digest for the post-renderers of\nthe last successful reconciliation attempt.", + "type": "string" + }, + "storageNamespace": { + "description": "StorageNamespace is the namespace of the Helm release storage for the\ncurrent release.", + "maxLength": 63, + "minLength": 1, + "type": "string" + }, + "upgradeFailures": { + "description": "UpgradeFailures is the upgrade failure count against the latest desired\nstate. It is reset after a successful reconciliation.", + "format": "int64", + "type": "integer" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" +} \ No newline at end of file diff --git a/helmrelease-helm-v2beta1.json b/helmrelease-helm-v2beta1.json index c031b8b..29e3ca9 100644 --- a/helmrelease-helm-v2beta1.json +++ b/helmrelease-helm-v2beta1.json @@ -2,11 +2,11 @@ "description": "HelmRelease is the Schema for the helmreleases API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,7 +16,7 @@ "description": "HelmReleaseSpec defines the desired state of a Helm release.", "properties": { "chart": { - "description": "Chart defines the template of the v1beta2.HelmChart that should be created for this HelmRelease.", + "description": "Chart defines the template of the v1beta2.HelmChart that should be created\nfor this HelmRelease.", "properties": { "metadata": { "description": "ObjectMeta holds the template for metadata like labels and annotations.", @@ -25,14 +25,14 @@ "additionalProperties": { "type": "string" }, - "description": "Annotations is an unstructured key value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata. They are not queryable and should be preserved when modifying objects. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", + "description": "Annotations is an unstructured key value map stored with a resource that may be\nset by external tools to store and retrieve arbitrary metadata. They are not\nqueryable and should be preserved when modifying objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", "type": "object" }, "labels": { "additionalProperties": { "type": "string" }, - "description": "Map of string keys and values that can be used to organize and categorize (scope and select) objects. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", + "description": "Map of string keys and values that can be used to organize and categorize\n(scope and select) objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", "type": "object" } }, @@ -47,13 +47,13 @@ "type": "string" }, "interval": { - "description": "Interval at which to check the v1beta2.Source for updates. Defaults to 'HelmReleaseSpec.Interval'.", + "description": "Interval at which to check the v1beta2.Source for updates. Defaults to\n'HelmReleaseSpec.Interval'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "reconcileStrategy": { "default": "ChartVersion", - "description": "Determines what enables the creation of a new artifact. Valid values are ('ChartVersion', 'Revision'). See the documentation of the values for an explanation on their behavior. Defaults to ChartVersion when omitted.", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", "enum": [ "ChartVersion", "Revision" @@ -96,18 +96,18 @@ "additionalProperties": false }, "valuesFile": { - "description": "Alternative values file to use as the default chart values, expected to be a relative path in the SourceRef. Deprecated in favor of ValuesFiles, for backwards compatibility the file defined here is merged before the ValuesFiles items. Ignored when omitted.", + "description": "Alternative values file to use as the default chart values, expected to\nbe a relative path in the SourceRef. Deprecated in favor of ValuesFiles,\nfor backwards compatibility the file defined here is merged before the\nValuesFiles items. Ignored when omitted.", "type": "string" }, "valuesFiles": { - "description": "Alternative list of values files to use as the chart values (values.yaml is not included by default), expected to be a relative path in the SourceRef. Values files are merged in the order of this list with the last file overriding the first. Ignored when omitted.", + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", "items": { "type": "string" }, "type": "array" }, "verify": { - "description": "Verify contains the secret name containing the trusted public keys used to verify the signature and specifies which provider to use to check whether OCI image is authentic. This field is only supported for OCI sources. Chart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported for OCI sources.\nChart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", "properties": { "provider": { "default": "cosign", @@ -118,7 +118,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Kubernetes Secret containing the trusted public keys.", + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", "properties": { "name": { "description": "Name of the referent.", @@ -140,7 +140,7 @@ }, "version": { "default": "*", - "description": "Version semver expression, ignored for charts from v1beta2.GitRepository and v1beta2.Bucket sources. Defaults to latest when omitted.", + "description": "Version semver expression, ignored for charts from v1beta2.GitRepository and\nv1beta2.Bucket sources. Defaults to latest when omitted.", "type": "string" } }, @@ -158,10 +158,45 @@ "type": "object", "additionalProperties": false }, + "chartRef": { + "description": "ChartRef holds a reference to a source controller resource containing the\nHelm chart artifact.\n\n\nNote: this field is provisional to the v2 API, and not actively used\nby v2beta1 HelmReleases.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "HelmChart" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, "dependsOn": { - "description": "DependsOn may contain a meta.NamespacedObjectReference slice with references to HelmRelease resources that must be ready before this HelmRelease can be reconciled.", + "description": "DependsOn may contain a meta.NamespacedObjectReference slice with\nreferences to HelmRelease resources that must be ready before this HelmRelease\ncan be reconciled.", "items": { - "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", "properties": { "name": { "description": "Name of the referent.", @@ -181,37 +216,37 @@ "type": "array" }, "driftDetection": { - "description": "DriftDetection holds the configuration for detecting and handling differences between the manifest in the Helm storage and the resources currently existing in the cluster. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "DriftDetection holds the configuration for detecting and handling\ndifferences between the manifest in the Helm storage and the resources\ncurrently existing in the cluster.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "properties": { "ignore": { - "description": "Ignore contains a list of rules for specifying which changes to ignore during diffing.", + "description": "Ignore contains a list of rules for specifying which changes to ignore\nduring diffing.", "items": { - "description": "IgnoreRule defines a rule to selectively disregard specific changes during the drift detection process.", + "description": "IgnoreRule defines a rule to selectively disregard specific changes during\nthe drift detection process.", "properties": { "paths": { - "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from consideration in a Kubernetes object.", + "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from\nconsideration in a Kubernetes object.", "items": { "type": "string" }, "type": "array" }, "target": { - "description": "Target is a selector for specifying Kubernetes objects to which this rule applies. If Target is not set, the Paths will be ignored for all Kubernetes objects within the manifest of the Helm release.", + "description": "Target is a selector for specifying Kubernetes objects to which this\nrule applies.\nIf Target is not set, the Paths will be ignored for all Kubernetes\nobjects within the manifest of the Helm release.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -223,7 +258,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -240,7 +275,7 @@ "type": "array" }, "mode": { - "description": "Mode defines how differences should be handled between the Helm manifest and the manifest currently applied to the cluster. If not explicitly set, it defaults to DiffModeDisabled.", + "description": "Mode defines how differences should be handled between the Helm manifest\nand the manifest currently applied to the cluster.\nIf not explicitly set, it defaults to DiffModeDisabled.", "enum": [ "enabled", "warn", @@ -256,7 +291,7 @@ "description": "Install holds the configuration for Helm install actions for this HelmRelease.", "properties": { "crds": { - "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according to the CRD upgrade policy provided here. Valid values are `Skip`, `Create` or `CreateReplace`. Default is `Create` and if omitted CRDs are installed but not updated. \n Skip: do neither install nor replace (update) any CRDs. \n Create: new CRDs are created, existing CRDs are neither updated nor deleted. \n CreateReplace: new CRDs are created, existing CRDs are updated (replaced) but not deleted. \n By default, CRDs are applied (installed) during Helm install action. With this option users can opt-in to CRD replace existing CRDs on Helm install actions, which is not (yet) natively supported by Helm. https://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Create` and if omitted\nCRDs are installed but not updated.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are applied (installed) during Helm install action.\nWith this option users can opt-in to CRD replace existing CRDs on Helm\ninstall actions, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", "enum": [ "Skip", "Create", @@ -265,7 +300,7 @@ "type": "string" }, "createNamespace": { - "description": "CreateNamespace tells the Helm install action to create the HelmReleaseSpec.TargetNamespace if it does not exist yet. On uninstall, the namespace will not be garbage collected.", + "description": "CreateNamespace tells the Helm install action to create the\nHelmReleaseSpec.TargetNamespace if it does not exist yet.\nOn uninstall, the namespace will not be garbage collected.", "type": "boolean" }, "disableHooks": { @@ -273,30 +308,30 @@ "type": "boolean" }, "disableOpenAPIValidation": { - "description": "DisableOpenAPIValidation prevents the Helm install action from validating rendered templates against the Kubernetes OpenAPI Schema.", + "description": "DisableOpenAPIValidation prevents the Helm install action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", "type": "boolean" }, "disableWait": { - "description": "DisableWait disables the waiting for resources to be ready after a Helm install has been performed.", + "description": "DisableWait disables the waiting for resources to be ready after a Helm\ninstall has been performed.", "type": "boolean" }, "disableWaitForJobs": { - "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm install has been performed.", + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\ninstall has been performed.", "type": "boolean" }, "remediation": { - "description": "Remediation holds the remediation configuration for when the Helm install action for the HelmRelease fails. The default is to not perform any action.", + "description": "Remediation holds the remediation configuration for when the Helm install\naction for the HelmRelease fails. The default is to not perform any action.", "properties": { "ignoreTestFailures": { - "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm tests are run after an install action but fail. Defaults to 'Test.IgnoreFailures'.", + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an install action but fail. Defaults to\n'Test.IgnoreFailures'.", "type": "boolean" }, "remediateLastFailure": { - "description": "RemediateLastFailure tells the controller to remediate the last failure, when no retries remain. Defaults to 'false'.", + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false'.", "type": "boolean" }, "retries": { - "description": "Retries is the number of retries that should be attempted on failures before bailing. Remediation, using an uninstall, is performed between each attempt. Defaults to '0', a negative integer equals to unlimited retries.", + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using an uninstall, is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", "type": "integer" } }, @@ -304,15 +339,15 @@ "additionalProperties": false }, "replace": { - "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only if that name is a deleted release which remains in the history.", + "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only\nif that name is a deleted release which remains in the history.", "type": "boolean" }, "skipCRDs": { - "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default, CRDs are installed if not already present. \n Deprecated use CRD policy (`crds`) attribute with value `Skip` instead.", + "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default,\nCRDs are installed if not already present.\n\n\nDeprecated use CRD policy (`crds`) attribute with value `Skip` instead.", "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm install action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm install action. Defaults to\n'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -321,15 +356,15 @@ "additionalProperties": false }, "interval": { - "description": "Interval at which to reconcile the Helm release. This interval is approximate and may be subject to jitter to ensure efficient use of resources.", + "description": "Interval at which to reconcile the Helm release.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "kubeConfig": { - "description": "KubeConfig for reconciling the HelmRelease on a remote cluster. When used in combination with HelmReleaseSpec.ServiceAccountName, forces the controller to act on behalf of that Service Account at the target cluster. If the --default-service-account flag is set, its value will be used as a controller level fallback for when HelmReleaseSpec.ServiceAccountName is empty.", + "description": "KubeConfig for reconciling the HelmRelease on a remote cluster.\nWhen used in combination with HelmReleaseSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when HelmReleaseSpec.ServiceAccountName\nis empty.", "properties": { "secretRef": { - "description": "SecretRef holds the name of a secret that contains a key with the kubeconfig file as the value. If no key is set, the key will default to 'value'. It is recommended that the kubeconfig is self-contained, and the secret is regularly updated if credentials such as a cloud-access-token expire. Cloud specific `cmd-path` auth helpers will not function without adding binaries and credentials to the Pod that is responsible for reconciling Kubernetes resources.", + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", "properties": { "key": { "description": "Key in the Secret, when not specified an implementation-specific default key is used.", @@ -354,15 +389,15 @@ "additionalProperties": false }, "maxHistory": { - "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease. Use '0' for an unlimited number of revisions; defaults to '10'.", + "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease.\nUse '0' for an unlimited number of revisions; defaults to '10'.", "type": "integer" }, "persistentClient": { - "description": "PersistentClient tells the controller to use a persistent Kubernetes client for this release. When enabled, the client will be reused for the duration of the reconciliation, instead of being created and destroyed for each (step of a) Helm action. \n This can improve performance, but may cause issues with some Helm charts that for example do create Custom Resource Definitions during installation outside Helm's CRD lifecycle hooks, which are then not observed to be available by e.g. post-install hooks. \n If not set, it defaults to true.", + "description": "PersistentClient tells the controller to use a persistent Kubernetes\nclient for this release. When enabled, the client will be reused for the\nduration of the reconciliation, instead of being created and destroyed\nfor each (step of a) Helm action.\n\n\nThis can improve performance, but may cause issues with some Helm charts\nthat for example do create Custom Resource Definitions during installation\noutside Helm's CRD lifecycle hooks, which are then not observed to be\navailable by e.g. post-install hooks.\n\n\nIf not set, it defaults to true.", "type": "boolean" }, "postRenderers": { - "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order of their definition.", + "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order\nof their definition.", "items": { "description": "PostRenderer contains a Helm PostRenderer specification.", "properties": { @@ -370,12 +405,12 @@ "description": "Kustomization to apply as PostRenderer.", "properties": { "images": { - "description": "Images is a list of (image name, new name, new tag or digest) for changing image names, tags or digests. This can also be achieved with a patch, but this operator is simpler to specify.", + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", "items": { "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", "properties": { "digest": { - "description": "Digest is the value used to replace the original image tag. If digest is present NewTag value is ignored.", + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", "type": "string" }, "name": { @@ -400,31 +435,31 @@ "type": "array" }, "patches": { - "description": "Strategic merge and JSON patches, defined as inline YAML objects, capable of targeting objects based on kind, label and annotation selectors.", + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", "items": { - "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should be applied to.", + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", "properties": { "patch": { - "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with an array of operation objects.", + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", "type": "string" }, "target": { "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -436,7 +471,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -460,14 +495,14 @@ "patch": { "description": "Patch contains the JSON6902 patch document with an array of operation objects.", "items": { - "description": "JSON6902 is a JSON6902 operation object. https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "properties": { "from": { - "description": "From contains a JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", "type": "string" }, "op": { - "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or \"test\". https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "enum": [ "test", "remove", @@ -479,11 +514,11 @@ "type": "string" }, "path": { - "description": "Path contains the JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op.", + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", "type": "string" }, "value": { - "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", "x-kubernetes-preserve-unknown-fields": true } }, @@ -500,19 +535,19 @@ "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -524,7 +559,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -559,7 +594,7 @@ "type": "array" }, "releaseName": { - "description": "ReleaseName used for the Helm release. Defaults to a composition of '[TargetNamespace-]Name'.", + "description": "ReleaseName used for the Helm release. Defaults to a composition of\n'[TargetNamespace-]Name'.", "maxLength": 53, "minLength": 1, "type": "string" @@ -568,7 +603,7 @@ "description": "Rollback holds the configuration for Helm rollback actions for this HelmRelease.", "properties": { "cleanupOnFail": { - "description": "CleanupOnFail allows deletion of new resources created during the Helm rollback action when it fails.", + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nrollback action when it fails.", "type": "boolean" }, "disableHooks": { @@ -576,11 +611,11 @@ "type": "boolean" }, "disableWait": { - "description": "DisableWait disables the waiting for resources to be ready after a Helm rollback has been performed.", + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nrollback has been performed.", "type": "boolean" }, "disableWaitForJobs": { - "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm rollback has been performed.", + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nrollback has been performed.", "type": "boolean" }, "force": { @@ -592,7 +627,7 @@ "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm rollback action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm rollback action. Defaults to\n'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -601,21 +636,21 @@ "additionalProperties": false }, "serviceAccountName": { - "description": "The name of the Kubernetes service account to impersonate when reconciling this HelmRelease.", + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this HelmRelease.", "type": "string" }, "storageNamespace": { - "description": "StorageNamespace used for the Helm storage. Defaults to the namespace of the HelmRelease.", + "description": "StorageNamespace used for the Helm storage.\nDefaults to the namespace of the HelmRelease.", "maxLength": 63, "minLength": 1, "type": "string" }, "suspend": { - "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease, it does not apply to already started reconciliations. Defaults to false.", + "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease,\nit does not apply to already started reconciliations. Defaults to false.", "type": "boolean" }, "targetNamespace": { - "description": "TargetNamespace to target when performing operations for the HelmRelease. Defaults to the namespace of the HelmRelease.", + "description": "TargetNamespace to target when performing operations for the HelmRelease.\nDefaults to the namespace of the HelmRelease.", "maxLength": 63, "minLength": 1, "type": "string" @@ -624,15 +659,15 @@ "description": "Test holds the configuration for Helm test actions for this HelmRelease.", "properties": { "enable": { - "description": "Enable enables Helm test actions for this HelmRelease after an Helm install or upgrade action has been performed.", + "description": "Enable enables Helm test actions for this HelmRelease after an Helm install\nor upgrade action has been performed.", "type": "boolean" }, "ignoreFailures": { - "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests are run but fail. Can be overwritten for tests run after install or upgrade actions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", + "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests\nare run but fail. Can be overwritten for tests run after install or upgrade\nactions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation during the performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation during\nthe performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -641,7 +676,7 @@ "additionalProperties": false }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm action. Defaults to '5m0s'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs\nfor hooks) during the performance of a Helm action. Defaults to '5m0s'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, @@ -650,7 +685,7 @@ "properties": { "deletionPropagation": { "default": "background", - "description": "DeletionPropagation specifies the deletion propagation policy when a Helm uninstall is performed.", + "description": "DeletionPropagation specifies the deletion propagation policy when\na Helm uninstall is performed.", "enum": [ "background", "foreground", @@ -663,15 +698,15 @@ "type": "boolean" }, "disableWait": { - "description": "DisableWait disables waiting for all the resources to be deleted after a Helm uninstall is performed.", + "description": "DisableWait disables waiting for all the resources to be deleted after\na Helm uninstall is performed.", "type": "boolean" }, "keepHistory": { - "description": "KeepHistory tells Helm to remove all associated resources and mark the release as deleted, but retain the release history.", + "description": "KeepHistory tells Helm to remove all associated resources and mark the\nrelease as deleted, but retain the release history.", "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm uninstall action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm uninstall action. Defaults\nto 'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -683,11 +718,11 @@ "description": "Upgrade holds the configuration for Helm upgrade actions for this HelmRelease.", "properties": { "cleanupOnFail": { - "description": "CleanupOnFail allows deletion of new resources created during the Helm upgrade action when it fails.", + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nupgrade action when it fails.", "type": "boolean" }, "crds": { - "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according to the CRD upgrade policy provided here. Valid values are `Skip`, `Create` or `CreateReplace`. Default is `Skip` and if omitted CRDs are neither installed nor upgraded. \n Skip: do neither install nor replace (update) any CRDs. \n Create: new CRDs are created, existing CRDs are neither updated nor deleted. \n CreateReplace: new CRDs are created, existing CRDs are updated (replaced) but not deleted. \n By default, CRDs are not applied during Helm upgrade action. With this option users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm. https://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Skip` and if omitted\nCRDs are neither installed nor upgraded.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are not applied during Helm upgrade action. With this\noption users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", "enum": [ "Skip", "Create", @@ -700,15 +735,15 @@ "type": "boolean" }, "disableOpenAPIValidation": { - "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating rendered templates against the Kubernetes OpenAPI Schema.", + "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", "type": "boolean" }, "disableWait": { - "description": "DisableWait disables the waiting for resources to be ready after a Helm upgrade has been performed.", + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nupgrade has been performed.", "type": "boolean" }, "disableWaitForJobs": { - "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm upgrade has been performed.", + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nupgrade has been performed.", "type": "boolean" }, "force": { @@ -716,22 +751,22 @@ "type": "boolean" }, "preserveValues": { - "description": "PreserveValues will make Helm reuse the last release's values and merge in overrides from 'Values'. Setting this flag makes the HelmRelease non-declarative.", + "description": "PreserveValues will make Helm reuse the last release's values and merge in\noverrides from 'Values'. Setting this flag makes the HelmRelease\nnon-declarative.", "type": "boolean" }, "remediation": { - "description": "Remediation holds the remediation configuration for when the Helm upgrade action for the HelmRelease fails. The default is to not perform any action.", + "description": "Remediation holds the remediation configuration for when the Helm upgrade\naction for the HelmRelease fails. The default is to not perform any action.", "properties": { "ignoreTestFailures": { - "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm tests are run after an upgrade action but fail. Defaults to 'Test.IgnoreFailures'.", + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an upgrade action but fail.\nDefaults to 'Test.IgnoreFailures'.", "type": "boolean" }, "remediateLastFailure": { - "description": "RemediateLastFailure tells the controller to remediate the last failure, when no retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", "type": "boolean" }, "retries": { - "description": "Retries is the number of retries that should be attempted on failures before bailing. Remediation, using 'Strategy', is performed between each attempt. Defaults to '0', a negative integer equals to unlimited retries.", + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using 'Strategy', is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", "type": "integer" }, "strategy": { @@ -747,7 +782,7 @@ "additionalProperties": false }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm upgrade action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm upgrade action. Defaults to\n'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -760,9 +795,9 @@ "x-kubernetes-preserve-unknown-fields": true }, "valuesFrom": { - "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease, and information about how they should be merged.", + "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease,\nand information about how they should be merged.", "items": { - "description": "ValuesReference contains a reference to a resource containing Helm values, and optionally the key they can be found at.", + "description": "ValuesReference contains a reference to a resource containing Helm values,\nand optionally the key they can be found at.", "properties": { "kind": { "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", @@ -773,23 +808,23 @@ "type": "string" }, "name": { - "description": "Name of the values referent. Should reside in the same namespace as the referring resource.", + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", "maxLength": 253, "minLength": 1, "type": "string" }, "optional": { - "description": "Optional marks this ValuesReference as optional. When set, a not found error for the values reference is ignored, but any ValuesKey, TargetPath or transient error will still result in a reconciliation failure.", + "description": "Optional marks this ValuesReference as optional. When set, a not found error\nfor the values reference is ignored, but any ValuesKey, TargetPath or\ntransient error will still result in a reconciliation failure.", "type": "boolean" }, "targetPath": { - "description": "TargetPath is the YAML dot notation path the value should be merged at. When set, the ValuesKey is expected to be a single flat value. Defaults to 'None', which results in the values getting merged at the root.", + "description": "TargetPath is the YAML dot notation path the value should be merged at. When\nset, the ValuesKey is expected to be a single flat value. Defaults to 'None',\nwhich results in the values getting merged at the root.", "maxLength": 250, "pattern": "^([a-zA-Z0-9_\\-.\\\\\\/]|\\[[0-9]{1,5}\\])+$", "type": "string" }, "valuesKey": { - "description": "ValuesKey is the data key where the values.yaml or a specific value can be found at. Defaults to 'values.yaml'. When set, must be a valid Data Key, consisting of alphanumeric characters, '-', '_' or '.'.", + "description": "ValuesKey is the data key where the values.yaml or a specific value can be\nfound at. Defaults to 'values.yaml'.\nWhen set, must be a valid Data Key, consisting of alphanumeric characters,\n'-', '_' or '.'.", "maxLength": 253, "pattern": "^[\\-._a-zA-Z0-9]+$", "type": "string" @@ -806,7 +841,6 @@ } }, "required": [ - "chart", "interval" ], "type": "object", @@ -821,26 +855,26 @@ "conditions": { "description": "Conditions holds the conditions for the HelmRelease.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -856,7 +890,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -875,21 +909,25 @@ "type": "array" }, "failures": { - "description": "Failures is the reconciliation failure count against the latest desired state. It is reset after a successful reconciliation.", + "description": "Failures is the reconciliation failure count against the latest desired\nstate. It is reset after a successful reconciliation.", "format": "int64", "type": "integer" }, "helmChart": { - "description": "HelmChart is the namespaced name of the HelmChart resource created by the controller for the HelmRelease.", + "description": "HelmChart is the namespaced name of the HelmChart resource created by\nthe controller for the HelmRelease.", "type": "string" }, "history": { - "description": "History holds the history of Helm releases performed for this HelmRelease up to the last successfully completed release. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "History holds the history of Helm releases performed for this HelmRelease\nup to the last successfully completed release.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "items": { - "description": "Snapshot captures a point-in-time copy of the status information for a Helm release, as managed by the controller.", + "description": "Snapshot captures a point-in-time copy of the status information for a Helm release,\nas managed by the controller.", "properties": { "apiVersion": { - "description": "APIVersion is the API version of the Snapshot. Provisional: when the calculation method of the Digest field is changed, this field will be used to distinguish between the old and new methods.", + "description": "APIVersion is the API version of the Snapshot.\nProvisional: when the calculation method of the Digest field is changed,\nthis field will be used to distinguish between the old and new methods.", + "type": "string" + }, + "appVersion": { + "description": "AppVersion is the chart app version of the release object in storage.", "type": "string" }, "chartName": { @@ -897,11 +935,11 @@ "type": "string" }, "chartVersion": { - "description": "ChartVersion is the chart version of the release object in storage.", + "description": "ChartVersion is the chart version of the release object in\nstorage.", "type": "string" }, "configDigest": { - "description": "ConfigDigest is the checksum of the config (better known as \"values\") of the release object in storage. It has the format of `:`.", + "description": "ConfigDigest is the checksum of the config (better known as\n\"values\") of the release object in storage.\nIt has the format of `:`.", "type": "string" }, "deleted": { @@ -910,7 +948,7 @@ "type": "string" }, "digest": { - "description": "Digest is the checksum of the release object in storage. It has the format of `:`.", + "description": "Digest is the checksum of the release object in storage.\nIt has the format of `:`.", "type": "string" }, "firstDeployed": { @@ -931,13 +969,17 @@ "description": "Namespace is the namespace the release is deployed to.", "type": "string" }, + "ociDigest": { + "description": "OCIDigest is the digest of the OCI artifact associated with the release.", + "type": "string" + }, "status": { "description": "Status is the current state of the release.", "type": "string" }, "testHooks": { "additionalProperties": { - "description": "TestHookStatus holds the status information for a test hook as observed to be run by the controller.", + "description": "TestHookStatus holds the status information for a test hook as observed\nto be run by the controller.", "properties": { "lastCompleted": { "description": "LastCompleted is the time the test hook last completed.", @@ -957,7 +999,7 @@ "type": "object", "additionalProperties": false }, - "description": "TestHooks is the list of test hooks for the release as observed to be run by the controller.", + "description": "TestHooks is the list of test hooks for the release as observed to be\nrun by the controller.", "type": "object" }, "version": { @@ -983,7 +1025,7 @@ "type": "array" }, "installFailures": { - "description": "InstallFailures is the install failure count against the latest desired state. It is reset after a successful reconciliation.", + "description": "InstallFailures is the install failure count against the latest desired\nstate. It is reset after a successful reconciliation.", "format": "int64", "type": "integer" }, @@ -992,16 +1034,16 @@ "type": "string" }, "lastAttemptedConfigDigest": { - "description": "LastAttemptedConfigDigest is the digest for the config (better known as \"values\") of the last reconciliation attempt. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "LastAttemptedConfigDigest is the digest for the config (better known as\n\"values\") of the last reconciliation attempt.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "type": "string" }, "lastAttemptedGeneration": { - "description": "LastAttemptedGeneration is the last generation the controller attempted to reconcile. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "LastAttemptedGeneration is the last generation the controller attempted\nto reconcile.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "format": "int64", "type": "integer" }, "lastAttemptedReleaseAction": { - "description": "LastAttemptedReleaseAction is the last release action performed for this HelmRelease. It is used to determine the active remediation strategy. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "LastAttemptedReleaseAction is the last release action performed for this\nHelmRelease. It is used to determine the active remediation strategy.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "type": "string" }, "lastAttemptedRevision": { @@ -1009,19 +1051,19 @@ "type": "string" }, "lastAttemptedValuesChecksum": { - "description": "LastAttemptedValuesChecksum is the SHA1 checksum of the values of the last reconciliation attempt.", + "description": "LastAttemptedValuesChecksum is the SHA1 checksum of the values of the last\nreconciliation attempt.", "type": "string" }, "lastHandledForceAt": { - "description": "LastHandledForceAt holds the value of the most recent force request value, so a change of the annotation value can be detected. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "LastHandledForceAt holds the value of the most recent force request\nvalue, so a change of the annotation value can be detected.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "type": "string" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "lastHandledResetAt": { - "description": "LastHandledResetAt holds the value of the most recent reset request value, so a change of the annotation value can be detected. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "LastHandledResetAt holds the value of the most recent reset request\nvalue, so a change of the annotation value can be detected.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "type": "string" }, "lastReleaseRevision": { @@ -1033,12 +1075,16 @@ "format": "int64", "type": "integer" }, + "observedPostRenderersDigest": { + "description": "ObservedPostRenderersDigest is the digest for the post-renderers of\nthe last successful reconciliation attempt.", + "type": "string" + }, "storageNamespace": { - "description": "StorageNamespace is the namespace of the Helm release storage for the current release. \n Note: this field is provisional to the v2beta2 API, and not actively used by v2beta1 HelmReleases.", + "description": "StorageNamespace is the namespace of the Helm release storage for the\ncurrent release.\n\n\nNote: this field is provisional to the v2beta2 API, and not actively used\nby v2beta1 HelmReleases.", "type": "string" }, "upgradeFailures": { - "description": "UpgradeFailures is the upgrade failure count against the latest desired state. It is reset after a successful reconciliation.", + "description": "UpgradeFailures is the upgrade failure count against the latest desired\nstate. It is reset after a successful reconciliation.", "format": "int64", "type": "integer" } diff --git a/helmrelease-helm-v2beta2.json b/helmrelease-helm-v2beta2.json index 8d626e7..8839389 100644 --- a/helmrelease-helm-v2beta2.json +++ b/helmrelease-helm-v2beta2.json @@ -2,11 +2,11 @@ "description": "HelmRelease is the Schema for the helmreleases API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,7 +16,7 @@ "description": "HelmReleaseSpec defines the desired state of a Helm release.", "properties": { "chart": { - "description": "Chart defines the template of the v1beta2.HelmChart that should be created for this HelmRelease.", + "description": "Chart defines the template of the v1beta2.HelmChart that should be created\nfor this HelmRelease.", "properties": { "metadata": { "description": "ObjectMeta holds the template for metadata like labels and annotations.", @@ -25,14 +25,14 @@ "additionalProperties": { "type": "string" }, - "description": "Annotations is an unstructured key value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata. They are not queryable and should be preserved when modifying objects. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", + "description": "Annotations is an unstructured key value map stored with a resource that may be\nset by external tools to store and retrieve arbitrary metadata. They are not\nqueryable and should be preserved when modifying objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/", "type": "object" }, "labels": { "additionalProperties": { "type": "string" }, - "description": "Map of string keys and values that can be used to organize and categorize (scope and select) objects. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", + "description": "Map of string keys and values that can be used to organize and categorize\n(scope and select) objects.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/", "type": "object" } }, @@ -48,14 +48,18 @@ "minLength": 1, "type": "string" }, + "ignoreMissingValuesFiles": { + "description": "IgnoreMissingValuesFiles controls whether to silently ignore missing values files rather than failing.", + "type": "boolean" + }, "interval": { - "description": "Interval at which to check the v1.Source for updates. Defaults to 'HelmReleaseSpec.Interval'.", + "description": "Interval at which to check the v1.Source for updates. Defaults to\n'HelmReleaseSpec.Interval'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "reconcileStrategy": { "default": "ChartVersion", - "description": "Determines what enables the creation of a new artifact. Valid values are ('ChartVersion', 'Revision'). See the documentation of the values for an explanation on their behavior. Defaults to ChartVersion when omitted.", + "description": "Determines what enables the creation of a new artifact. Valid values are\n('ChartVersion', 'Revision').\nSee the documentation of the values for an explanation on their behavior.\nDefaults to ChartVersion when omitted.", "enum": [ "ChartVersion", "Revision" @@ -98,29 +102,30 @@ "additionalProperties": false }, "valuesFile": { - "description": "Alternative values file to use as the default chart values, expected to be a relative path in the SourceRef. Deprecated in favor of ValuesFiles, for backwards compatibility the file defined here is merged before the ValuesFiles items. Ignored when omitted.", + "description": "Alternative values file to use as the default chart values, expected to\nbe a relative path in the SourceRef. Deprecated in favor of ValuesFiles,\nfor backwards compatibility the file defined here is merged before the\nValuesFiles items. Ignored when omitted.", "type": "string" }, "valuesFiles": { - "description": "Alternative list of values files to use as the chart values (values.yaml is not included by default), expected to be a relative path in the SourceRef. Values files are merged in the order of this list with the last file overriding the first. Ignored when omitted.", + "description": "Alternative list of values files to use as the chart values (values.yaml\nis not included by default), expected to be a relative path in the SourceRef.\nValues files are merged in the order of this list with the last file overriding\nthe first. Ignored when omitted.", "items": { "type": "string" }, "type": "array" }, "verify": { - "description": "Verify contains the secret name containing the trusted public keys used to verify the signature and specifies which provider to use to check whether OCI image is authentic. This field is only supported for OCI sources. Chart dependencies, which are not bundled in the umbrella chart artifact, are not verified.", + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.\nThis field is only supported for OCI sources.\nChart dependencies, which are not bundled in the umbrella chart artifact,\nare not verified.", "properties": { "provider": { "default": "cosign", "description": "Provider specifies the technology used to sign the OCI Helm chart.", "enum": [ - "cosign" + "cosign", + "notation" ], "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Kubernetes Secret containing the trusted public keys.", + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", "properties": { "name": { "description": "Name of the referent.", @@ -142,7 +147,7 @@ }, "version": { "default": "*", - "description": "Version semver expression, ignored for charts from v1beta2.GitRepository and v1beta2.Bucket sources. Defaults to latest when omitted.", + "description": "Version semver expression, ignored for charts from v1beta2.GitRepository and\nv1beta2.Bucket sources. Defaults to latest when omitted.", "type": "string" } }, @@ -160,10 +165,45 @@ "type": "object", "additionalProperties": false }, + "chartRef": { + "description": "ChartRef holds a reference to a source controller resource containing the\nHelm chart artifact.\n\n\nNote: this field is provisional to the v2 API, and not actively used\nby v2beta2 HelmReleases.", + "properties": { + "apiVersion": { + "description": "APIVersion of the referent.", + "type": "string" + }, + "kind": { + "description": "Kind of the referent.", + "enum": [ + "OCIRepository", + "HelmChart" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "maxLength": 253, + "minLength": 1, + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", + "maxLength": 63, + "minLength": 1, + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, "dependsOn": { - "description": "DependsOn may contain a meta.NamespacedObjectReference slice with references to HelmRelease resources that must be ready before this HelmRelease can be reconciled.", + "description": "DependsOn may contain a meta.NamespacedObjectReference slice with\nreferences to HelmRelease resources that must be ready before this HelmRelease\ncan be reconciled.", "items": { - "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", "properties": { "name": { "description": "Name of the referent.", @@ -183,37 +223,37 @@ "type": "array" }, "driftDetection": { - "description": "DriftDetection holds the configuration for detecting and handling differences between the manifest in the Helm storage and the resources currently existing in the cluster.", + "description": "DriftDetection holds the configuration for detecting and handling\ndifferences between the manifest in the Helm storage and the resources\ncurrently existing in the cluster.", "properties": { "ignore": { - "description": "Ignore contains a list of rules for specifying which changes to ignore during diffing.", + "description": "Ignore contains a list of rules for specifying which changes to ignore\nduring diffing.", "items": { - "description": "IgnoreRule defines a rule to selectively disregard specific changes during the drift detection process.", + "description": "IgnoreRule defines a rule to selectively disregard specific changes during\nthe drift detection process.", "properties": { "paths": { - "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from consideration in a Kubernetes object.", + "description": "Paths is a list of JSON Pointer (RFC 6901) paths to be excluded from\nconsideration in a Kubernetes object.", "items": { "type": "string" }, "type": "array" }, "target": { - "description": "Target is a selector for specifying Kubernetes objects to which this rule applies. If Target is not set, the Paths will be ignored for all Kubernetes objects within the manifest of the Helm release.", + "description": "Target is a selector for specifying Kubernetes objects to which this\nrule applies.\nIf Target is not set, the Paths will be ignored for all Kubernetes\nobjects within the manifest of the Helm release.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -225,7 +265,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -242,7 +282,7 @@ "type": "array" }, "mode": { - "description": "Mode defines how differences should be handled between the Helm manifest and the manifest currently applied to the cluster. If not explicitly set, it defaults to DiffModeDisabled.", + "description": "Mode defines how differences should be handled between the Helm manifest\nand the manifest currently applied to the cluster.\nIf not explicitly set, it defaults to DiffModeDisabled.", "enum": [ "enabled", "warn", @@ -258,7 +298,7 @@ "description": "Install holds the configuration for Helm install actions for this HelmRelease.", "properties": { "crds": { - "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according to the CRD upgrade policy provided here. Valid values are `Skip`, `Create` or `CreateReplace`. Default is `Create` and if omitted CRDs are installed but not updated. \n Skip: do neither install nor replace (update) any CRDs. \n Create: new CRDs are created, existing CRDs are neither updated nor deleted. \n CreateReplace: new CRDs are created, existing CRDs are updated (replaced) but not deleted. \n By default, CRDs are applied (installed) during Helm install action. With this option users can opt in to CRD replace existing CRDs on Helm install actions, which is not (yet) natively supported by Helm. https://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Create` and if omitted\nCRDs are installed but not updated.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are applied (installed) during Helm install action.\nWith this option users can opt in to CRD replace existing CRDs on Helm\ninstall actions, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", "enum": [ "Skip", "Create", @@ -267,7 +307,7 @@ "type": "string" }, "createNamespace": { - "description": "CreateNamespace tells the Helm install action to create the HelmReleaseSpec.TargetNamespace if it does not exist yet. On uninstall, the namespace will not be garbage collected.", + "description": "CreateNamespace tells the Helm install action to create the\nHelmReleaseSpec.TargetNamespace if it does not exist yet.\nOn uninstall, the namespace will not be garbage collected.", "type": "boolean" }, "disableHooks": { @@ -275,30 +315,30 @@ "type": "boolean" }, "disableOpenAPIValidation": { - "description": "DisableOpenAPIValidation prevents the Helm install action from validating rendered templates against the Kubernetes OpenAPI Schema.", + "description": "DisableOpenAPIValidation prevents the Helm install action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", "type": "boolean" }, "disableWait": { - "description": "DisableWait disables the waiting for resources to be ready after a Helm install has been performed.", + "description": "DisableWait disables the waiting for resources to be ready after a Helm\ninstall has been performed.", "type": "boolean" }, "disableWaitForJobs": { - "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm install has been performed.", + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\ninstall has been performed.", "type": "boolean" }, "remediation": { - "description": "Remediation holds the remediation configuration for when the Helm install action for the HelmRelease fails. The default is to not perform any action.", + "description": "Remediation holds the remediation configuration for when the Helm install\naction for the HelmRelease fails. The default is to not perform any action.", "properties": { "ignoreTestFailures": { - "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm tests are run after an install action but fail. Defaults to 'Test.IgnoreFailures'.", + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an install action but fail. Defaults to\n'Test.IgnoreFailures'.", "type": "boolean" }, "remediateLastFailure": { - "description": "RemediateLastFailure tells the controller to remediate the last failure, when no retries remain. Defaults to 'false'.", + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false'.", "type": "boolean" }, "retries": { - "description": "Retries is the number of retries that should be attempted on failures before bailing. Remediation, using an uninstall, is performed between each attempt. Defaults to '0', a negative integer equals to unlimited retries.", + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using an uninstall, is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", "type": "integer" } }, @@ -306,15 +346,15 @@ "additionalProperties": false }, "replace": { - "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only if that name is a deleted release which remains in the history.", + "description": "Replace tells the Helm install action to re-use the 'ReleaseName', but only\nif that name is a deleted release which remains in the history.", "type": "boolean" }, "skipCRDs": { - "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default, CRDs are installed if not already present. \n Deprecated use CRD policy (`crds`) attribute with value `Skip` instead.", + "description": "SkipCRDs tells the Helm install action to not install any CRDs. By default,\nCRDs are installed if not already present.\n\n\nDeprecated use CRD policy (`crds`) attribute with value `Skip` instead.", "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm install action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm install action. Defaults to\n'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -328,10 +368,10 @@ "type": "string" }, "kubeConfig": { - "description": "KubeConfig for reconciling the HelmRelease on a remote cluster. When used in combination with HelmReleaseSpec.ServiceAccountName, forces the controller to act on behalf of that Service Account at the target cluster. If the --default-service-account flag is set, its value will be used as a controller level fallback for when HelmReleaseSpec.ServiceAccountName is empty.", + "description": "KubeConfig for reconciling the HelmRelease on a remote cluster.\nWhen used in combination with HelmReleaseSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when HelmReleaseSpec.ServiceAccountName\nis empty.", "properties": { "secretRef": { - "description": "SecretRef holds the name of a secret that contains a key with the kubeconfig file as the value. If no key is set, the key will default to 'value'. It is recommended that the kubeconfig is self-contained, and the secret is regularly updated if credentials such as a cloud-access-token expire. Cloud specific `cmd-path` auth helpers will not function without adding binaries and credentials to the Pod that is responsible for reconciling Kubernetes resources.", + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", "properties": { "key": { "description": "Key in the Secret, when not specified an implementation-specific default key is used.", @@ -356,15 +396,15 @@ "additionalProperties": false }, "maxHistory": { - "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease. Use '0' for an unlimited number of revisions; defaults to '5'.", + "description": "MaxHistory is the number of revisions saved by Helm for this HelmRelease.\nUse '0' for an unlimited number of revisions; defaults to '5'.", "type": "integer" }, "persistentClient": { - "description": "PersistentClient tells the controller to use a persistent Kubernetes client for this release. When enabled, the client will be reused for the duration of the reconciliation, instead of being created and destroyed for each (step of a) Helm action. \n This can improve performance, but may cause issues with some Helm charts that for example do create Custom Resource Definitions during installation outside Helm's CRD lifecycle hooks, which are then not observed to be available by e.g. post-install hooks. \n If not set, it defaults to true.", + "description": "PersistentClient tells the controller to use a persistent Kubernetes\nclient for this release. When enabled, the client will be reused for the\nduration of the reconciliation, instead of being created and destroyed\nfor each (step of a) Helm action.\n\n\nThis can improve performance, but may cause issues with some Helm charts\nthat for example do create Custom Resource Definitions during installation\noutside Helm's CRD lifecycle hooks, which are then not observed to be\navailable by e.g. post-install hooks.\n\n\nIf not set, it defaults to true.", "type": "boolean" }, "postRenderers": { - "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order of their definition.", + "description": "PostRenderers holds an array of Helm PostRenderers, which will be applied in order\nof their definition.", "items": { "description": "PostRenderer contains a Helm PostRenderer specification.", "properties": { @@ -372,12 +412,12 @@ "description": "Kustomization to apply as PostRenderer.", "properties": { "images": { - "description": "Images is a list of (image name, new name, new tag or digest) for changing image names, tags or digests. This can also be achieved with a patch, but this operator is simpler to specify.", + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", "items": { "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", "properties": { "digest": { - "description": "Digest is the value used to replace the original image tag. If digest is present NewTag value is ignored.", + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", "type": "string" }, "name": { @@ -402,31 +442,31 @@ "type": "array" }, "patches": { - "description": "Strategic merge and JSON patches, defined as inline YAML objects, capable of targeting objects based on kind, label and annotation selectors.", + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", "items": { - "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should be applied to.", + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", "properties": { "patch": { - "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with an array of operation objects.", + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", "type": "string" }, "target": { "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -438,7 +478,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -455,21 +495,21 @@ "type": "array" }, "patchesJson6902": { - "description": "JSON 6902 patches, defined as inline YAML objects. Deprecated: use Patches instead.", + "description": "JSON 6902 patches, defined as inline YAML objects.\nDeprecated: use Patches instead.", "items": { "description": "JSON6902Patch contains a JSON6902 patch and the target the patch should be applied to.", "properties": { "patch": { "description": "Patch contains the JSON6902 patch document with an array of operation objects.", "items": { - "description": "JSON6902 is a JSON6902 operation object. https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "properties": { "from": { - "description": "From contains a JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", "type": "string" }, "op": { - "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or \"test\". https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "enum": [ "test", "remove", @@ -481,11 +521,11 @@ "type": "string" }, "path": { - "description": "Path contains the JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op.", + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", "type": "string" }, "value": { - "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", "x-kubernetes-preserve-unknown-fields": true } }, @@ -502,19 +542,19 @@ "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -526,7 +566,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -544,7 +584,7 @@ "type": "array" }, "patchesStrategicMerge": { - "description": "Strategic merge patches, defined as inline YAML objects. Deprecated: use Patches instead.", + "description": "Strategic merge patches, defined as inline YAML objects.\nDeprecated: use Patches instead.", "items": { "x-kubernetes-preserve-unknown-fields": true }, @@ -561,7 +601,7 @@ "type": "array" }, "releaseName": { - "description": "ReleaseName used for the Helm release. Defaults to a composition of '[TargetNamespace-]Name'.", + "description": "ReleaseName used for the Helm release. Defaults to a composition of\n'[TargetNamespace-]Name'.", "maxLength": 53, "minLength": 1, "type": "string" @@ -570,7 +610,7 @@ "description": "Rollback holds the configuration for Helm rollback actions for this HelmRelease.", "properties": { "cleanupOnFail": { - "description": "CleanupOnFail allows deletion of new resources created during the Helm rollback action when it fails.", + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nrollback action when it fails.", "type": "boolean" }, "disableHooks": { @@ -578,11 +618,11 @@ "type": "boolean" }, "disableWait": { - "description": "DisableWait disables the waiting for resources to be ready after a Helm rollback has been performed.", + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nrollback has been performed.", "type": "boolean" }, "disableWaitForJobs": { - "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm rollback has been performed.", + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nrollback has been performed.", "type": "boolean" }, "force": { @@ -594,7 +634,7 @@ "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm rollback action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm rollback action. Defaults to\n'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -603,23 +643,23 @@ "additionalProperties": false }, "serviceAccountName": { - "description": "The name of the Kubernetes service account to impersonate when reconciling this HelmRelease.", + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this HelmRelease.", "maxLength": 253, "minLength": 1, "type": "string" }, "storageNamespace": { - "description": "StorageNamespace used for the Helm storage. Defaults to the namespace of the HelmRelease.", + "description": "StorageNamespace used for the Helm storage.\nDefaults to the namespace of the HelmRelease.", "maxLength": 63, "minLength": 1, "type": "string" }, "suspend": { - "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease, it does not apply to already started reconciliations. Defaults to false.", + "description": "Suspend tells the controller to suspend reconciliation for this HelmRelease,\nit does not apply to already started reconciliations. Defaults to false.", "type": "boolean" }, "targetNamespace": { - "description": "TargetNamespace to target when performing operations for the HelmRelease. Defaults to the namespace of the HelmRelease.", + "description": "TargetNamespace to target when performing operations for the HelmRelease.\nDefaults to the namespace of the HelmRelease.", "maxLength": 63, "minLength": 1, "type": "string" @@ -628,7 +668,7 @@ "description": "Test holds the configuration for Helm test actions for this HelmRelease.", "properties": { "enable": { - "description": "Enable enables Helm test actions for this HelmRelease after an Helm install or upgrade action has been performed.", + "description": "Enable enables Helm test actions for this HelmRelease after an Helm install\nor upgrade action has been performed.", "type": "boolean" }, "filters": { @@ -656,11 +696,11 @@ "type": "array" }, "ignoreFailures": { - "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests are run but fail. Can be overwritten for tests run after install or upgrade actions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", + "description": "IgnoreFailures tells the controller to skip remediation when the Helm tests\nare run but fail. Can be overwritten for tests run after install or upgrade\nactions in 'Install.IgnoreTestFailures' and 'Upgrade.IgnoreTestFailures'.", "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation during the performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation during\nthe performance of a Helm test action. Defaults to 'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -669,7 +709,7 @@ "additionalProperties": false }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm action. Defaults to '5m0s'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs\nfor hooks) during the performance of a Helm action. Defaults to '5m0s'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, @@ -678,7 +718,7 @@ "properties": { "deletionPropagation": { "default": "background", - "description": "DeletionPropagation specifies the deletion propagation policy when a Helm uninstall is performed.", + "description": "DeletionPropagation specifies the deletion propagation policy when\na Helm uninstall is performed.", "enum": [ "background", "foreground", @@ -691,15 +731,15 @@ "type": "boolean" }, "disableWait": { - "description": "DisableWait disables waiting for all the resources to be deleted after a Helm uninstall is performed.", + "description": "DisableWait disables waiting for all the resources to be deleted after\na Helm uninstall is performed.", "type": "boolean" }, "keepHistory": { - "description": "KeepHistory tells Helm to remove all associated resources and mark the release as deleted, but retain the release history.", + "description": "KeepHistory tells Helm to remove all associated resources and mark the\nrelease as deleted, but retain the release history.", "type": "boolean" }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm uninstall action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm uninstall action. Defaults\nto 'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -711,11 +751,11 @@ "description": "Upgrade holds the configuration for Helm upgrade actions for this HelmRelease.", "properties": { "cleanupOnFail": { - "description": "CleanupOnFail allows deletion of new resources created during the Helm upgrade action when it fails.", + "description": "CleanupOnFail allows deletion of new resources created during the Helm\nupgrade action when it fails.", "type": "boolean" }, "crds": { - "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according to the CRD upgrade policy provided here. Valid values are `Skip`, `Create` or `CreateReplace`. Default is `Skip` and if omitted CRDs are neither installed nor upgraded. \n Skip: do neither install nor replace (update) any CRDs. \n Create: new CRDs are created, existing CRDs are neither updated nor deleted. \n CreateReplace: new CRDs are created, existing CRDs are updated (replaced) but not deleted. \n By default, CRDs are not applied during Helm upgrade action. With this option users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm. https://helm.sh/docs/chart_best_practices/custom_resource_definitions.", + "description": "CRDs upgrade CRDs from the Helm Chart's crds directory according\nto the CRD upgrade policy provided here. Valid values are `Skip`,\n`Create` or `CreateReplace`. Default is `Skip` and if omitted\nCRDs are neither installed nor upgraded.\n\n\nSkip: do neither install nor replace (update) any CRDs.\n\n\nCreate: new CRDs are created, existing CRDs are neither updated nor deleted.\n\n\nCreateReplace: new CRDs are created, existing CRDs are updated (replaced)\nbut not deleted.\n\n\nBy default, CRDs are not applied during Helm upgrade action. With this\noption users can opt-in to CRD upgrade, which is not (yet) natively supported by Helm.\nhttps://helm.sh/docs/chart_best_practices/custom_resource_definitions.", "enum": [ "Skip", "Create", @@ -728,15 +768,15 @@ "type": "boolean" }, "disableOpenAPIValidation": { - "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating rendered templates against the Kubernetes OpenAPI Schema.", + "description": "DisableOpenAPIValidation prevents the Helm upgrade action from validating\nrendered templates against the Kubernetes OpenAPI Schema.", "type": "boolean" }, "disableWait": { - "description": "DisableWait disables the waiting for resources to be ready after a Helm upgrade has been performed.", + "description": "DisableWait disables the waiting for resources to be ready after a Helm\nupgrade has been performed.", "type": "boolean" }, "disableWaitForJobs": { - "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm upgrade has been performed.", + "description": "DisableWaitForJobs disables waiting for jobs to complete after a Helm\nupgrade has been performed.", "type": "boolean" }, "force": { @@ -744,22 +784,22 @@ "type": "boolean" }, "preserveValues": { - "description": "PreserveValues will make Helm reuse the last release's values and merge in overrides from 'Values'. Setting this flag makes the HelmRelease non-declarative.", + "description": "PreserveValues will make Helm reuse the last release's values and merge in\noverrides from 'Values'. Setting this flag makes the HelmRelease\nnon-declarative.", "type": "boolean" }, "remediation": { - "description": "Remediation holds the remediation configuration for when the Helm upgrade action for the HelmRelease fails. The default is to not perform any action.", + "description": "Remediation holds the remediation configuration for when the Helm upgrade\naction for the HelmRelease fails. The default is to not perform any action.", "properties": { "ignoreTestFailures": { - "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm tests are run after an upgrade action but fail. Defaults to 'Test.IgnoreFailures'.", + "description": "IgnoreTestFailures tells the controller to skip remediation when the Helm\ntests are run after an upgrade action but fail.\nDefaults to 'Test.IgnoreFailures'.", "type": "boolean" }, "remediateLastFailure": { - "description": "RemediateLastFailure tells the controller to remediate the last failure, when no retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", + "description": "RemediateLastFailure tells the controller to remediate the last failure, when\nno retries remain. Defaults to 'false' unless 'Retries' is greater than 0.", "type": "boolean" }, "retries": { - "description": "Retries is the number of retries that should be attempted on failures before bailing. Remediation, using 'Strategy', is performed between each attempt. Defaults to '0', a negative integer equals to unlimited retries.", + "description": "Retries is the number of retries that should be attempted on failures before\nbailing. Remediation, using 'Strategy', is performed between each attempt.\nDefaults to '0', a negative integer equals to unlimited retries.", "type": "integer" }, "strategy": { @@ -775,7 +815,7 @@ "additionalProperties": false }, "timeout": { - "description": "Timeout is the time to wait for any individual Kubernetes operation (like Jobs for hooks) during the performance of a Helm upgrade action. Defaults to 'HelmReleaseSpec.Timeout'.", + "description": "Timeout is the time to wait for any individual Kubernetes operation (like\nJobs for hooks) during the performance of a Helm upgrade action. Defaults to\n'HelmReleaseSpec.Timeout'.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" } @@ -788,9 +828,9 @@ "x-kubernetes-preserve-unknown-fields": true }, "valuesFrom": { - "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease, and information about how they should be merged.", + "description": "ValuesFrom holds references to resources containing Helm values for this HelmRelease,\nand information about how they should be merged.", "items": { - "description": "ValuesReference contains a reference to a resource containing Helm values, and optionally the key they can be found at.", + "description": "ValuesReference contains a reference to a resource containing Helm values,\nand optionally the key they can be found at.", "properties": { "kind": { "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", @@ -801,23 +841,23 @@ "type": "string" }, "name": { - "description": "Name of the values referent. Should reside in the same namespace as the referring resource.", + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", "maxLength": 253, "minLength": 1, "type": "string" }, "optional": { - "description": "Optional marks this ValuesReference as optional. When set, a not found error for the values reference is ignored, but any ValuesKey, TargetPath or transient error will still result in a reconciliation failure.", + "description": "Optional marks this ValuesReference as optional. When set, a not found error\nfor the values reference is ignored, but any ValuesKey, TargetPath or\ntransient error will still result in a reconciliation failure.", "type": "boolean" }, "targetPath": { - "description": "TargetPath is the YAML dot notation path the value should be merged at. When set, the ValuesKey is expected to be a single flat value. Defaults to 'None', which results in the values getting merged at the root.", + "description": "TargetPath is the YAML dot notation path the value should be merged at. When\nset, the ValuesKey is expected to be a single flat value. Defaults to 'None',\nwhich results in the values getting merged at the root.", "maxLength": 250, "pattern": "^([a-zA-Z0-9_\\-.\\\\\\/]|\\[[0-9]{1,5}\\])+$", "type": "string" }, "valuesKey": { - "description": "ValuesKey is the data key where the values.yaml or a specific value can be found at. Defaults to 'values.yaml'.", + "description": "ValuesKey is the data key where the values.yaml or a specific value can be\nfound at. Defaults to 'values.yaml'.", "maxLength": 253, "pattern": "^[\\-._a-zA-Z0-9]+$", "type": "string" @@ -834,10 +874,15 @@ } }, "required": [ - "chart", "interval" ], "type": "object", + "x-kubernetes-validations": [ + { + "message": "either chart or chartRef must be set", + "rule": "(has(self.chart) && !has(self.chartRef)) || (!has(self.chart) && has(self.chartRef))" + } + ], "additionalProperties": false }, "status": { @@ -849,26 +894,26 @@ "conditions": { "description": "Conditions holds the conditions for the HelmRelease.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -884,7 +929,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -903,21 +948,25 @@ "type": "array" }, "failures": { - "description": "Failures is the reconciliation failure count against the latest desired state. It is reset after a successful reconciliation.", + "description": "Failures is the reconciliation failure count against the latest desired\nstate. It is reset after a successful reconciliation.", "format": "int64", "type": "integer" }, "helmChart": { - "description": "HelmChart is the namespaced name of the HelmChart resource created by the controller for the HelmRelease.", + "description": "HelmChart is the namespaced name of the HelmChart resource created by\nthe controller for the HelmRelease.", "type": "string" }, "history": { - "description": "History holds the history of Helm releases performed for this HelmRelease up to the last successfully completed release.", + "description": "History holds the history of Helm releases performed for this HelmRelease\nup to the last successfully completed release.", "items": { - "description": "Snapshot captures a point-in-time copy of the status information for a Helm release, as managed by the controller.", + "description": "Snapshot captures a point-in-time copy of the status information for a Helm release,\nas managed by the controller.", "properties": { "apiVersion": { - "description": "APIVersion is the API version of the Snapshot. Provisional: when the calculation method of the Digest field is changed, this field will be used to distinguish between the old and new methods.", + "description": "APIVersion is the API version of the Snapshot.\nProvisional: when the calculation method of the Digest field is changed,\nthis field will be used to distinguish between the old and new methods.", + "type": "string" + }, + "appVersion": { + "description": "AppVersion is the chart app version of the release object in storage.", "type": "string" }, "chartName": { @@ -925,11 +974,11 @@ "type": "string" }, "chartVersion": { - "description": "ChartVersion is the chart version of the release object in storage.", + "description": "ChartVersion is the chart version of the release object in\nstorage.", "type": "string" }, "configDigest": { - "description": "ConfigDigest is the checksum of the config (better known as \"values\") of the release object in storage. It has the format of `:`.", + "description": "ConfigDigest is the checksum of the config (better known as\n\"values\") of the release object in storage.\nIt has the format of `:`.", "type": "string" }, "deleted": { @@ -938,7 +987,7 @@ "type": "string" }, "digest": { - "description": "Digest is the checksum of the release object in storage. It has the format of `:`.", + "description": "Digest is the checksum of the release object in storage.\nIt has the format of `:`.", "type": "string" }, "firstDeployed": { @@ -959,13 +1008,17 @@ "description": "Namespace is the namespace the release is deployed to.", "type": "string" }, + "ociDigest": { + "description": "OCIDigest is the digest of the OCI artifact associated with the release.", + "type": "string" + }, "status": { "description": "Status is the current state of the release.", "type": "string" }, "testHooks": { "additionalProperties": { - "description": "TestHookStatus holds the status information for a test hook as observed to be run by the controller.", + "description": "TestHookStatus holds the status information for a test hook as observed\nto be run by the controller.", "properties": { "lastCompleted": { "description": "LastCompleted is the time the test hook last completed.", @@ -985,7 +1038,7 @@ "type": "object", "additionalProperties": false }, - "description": "TestHooks is the list of test hooks for the release as observed to be run by the controller.", + "description": "TestHooks is the list of test hooks for the release as observed to be\nrun by the controller.", "type": "object" }, "version": { @@ -1011,25 +1064,25 @@ "type": "array" }, "installFailures": { - "description": "InstallFailures is the install failure count against the latest desired state. It is reset after a successful reconciliation.", + "description": "InstallFailures is the install failure count against the latest desired\nstate. It is reset after a successful reconciliation.", "format": "int64", "type": "integer" }, "lastAppliedRevision": { - "description": "LastAppliedRevision is the revision of the last successfully applied source. Deprecated: the revision can now be found in the History.", + "description": "LastAppliedRevision is the revision of the last successfully applied\nsource.\nDeprecated: the revision can now be found in the History.", "type": "string" }, "lastAttemptedConfigDigest": { - "description": "LastAttemptedConfigDigest is the digest for the config (better known as \"values\") of the last reconciliation attempt.", + "description": "LastAttemptedConfigDigest is the digest for the config (better known as\n\"values\") of the last reconciliation attempt.", "type": "string" }, "lastAttemptedGeneration": { - "description": "LastAttemptedGeneration is the last generation the controller attempted to reconcile.", + "description": "LastAttemptedGeneration is the last generation the controller attempted\nto reconcile.", "format": "int64", "type": "integer" }, "lastAttemptedReleaseAction": { - "description": "LastAttemptedReleaseAction is the last release action performed for this HelmRelease. It is used to determine the active remediation strategy.", + "description": "LastAttemptedReleaseAction is the last release action performed for this\nHelmRelease. It is used to determine the active remediation strategy.", "enum": [ "install", "upgrade" @@ -1037,27 +1090,31 @@ "type": "string" }, "lastAttemptedRevision": { - "description": "LastAttemptedRevision is the Source revision of the last reconciliation attempt.", + "description": "LastAttemptedRevision is the Source revision of the last reconciliation\nattempt. For OCIRepository sources, the 12 first characters of the digest are\nappended to the chart version e.g. \"1.2.3+1234567890ab\".", + "type": "string" + }, + "lastAttemptedRevisionDigest": { + "description": "LastAttemptedRevisionDigest is the digest of the last reconciliation attempt.\nThis is only set for OCIRepository sources.", "type": "string" }, "lastAttemptedValuesChecksum": { - "description": "LastAttemptedValuesChecksum is the SHA1 checksum for the values of the last reconciliation attempt. Deprecated: Use LastAttemptedConfigDigest instead.", + "description": "LastAttemptedValuesChecksum is the SHA1 checksum for the values of the last\nreconciliation attempt.\nDeprecated: Use LastAttemptedConfigDigest instead.", "type": "string" }, "lastHandledForceAt": { - "description": "LastHandledForceAt holds the value of the most recent force request value, so a change of the annotation value can be detected.", + "description": "LastHandledForceAt holds the value of the most recent force request\nvalue, so a change of the annotation value can be detected.", "type": "string" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "lastHandledResetAt": { - "description": "LastHandledResetAt holds the value of the most recent reset request value, so a change of the annotation value can be detected.", + "description": "LastHandledResetAt holds the value of the most recent reset request\nvalue, so a change of the annotation value can be detected.", "type": "string" }, "lastReleaseRevision": { - "description": "LastReleaseRevision is the revision of the last successful Helm release. Deprecated: Use History instead.", + "description": "LastReleaseRevision is the revision of the last successful Helm release.\nDeprecated: Use History instead.", "type": "integer" }, "observedGeneration": { @@ -1065,14 +1122,18 @@ "format": "int64", "type": "integer" }, + "observedPostRenderersDigest": { + "description": "ObservedPostRenderersDigest is the digest for the post-renderers of\nthe last successful reconciliation attempt.", + "type": "string" + }, "storageNamespace": { - "description": "StorageNamespace is the namespace of the Helm release storage for the current release.", + "description": "StorageNamespace is the namespace of the Helm release storage for the\ncurrent release.", "maxLength": 63, "minLength": 1, "type": "string" }, "upgradeFailures": { - "description": "UpgradeFailures is the upgrade failure count against the latest desired state. It is reset after a successful reconciliation.", + "description": "UpgradeFailures is the upgrade failure count against the latest desired\nstate. It is reset after a successful reconciliation.", "format": "int64", "type": "integer" } diff --git a/helmrepository-source-v1.json b/helmrepository-source-v1.json new file mode 100644 index 0000000..56313fa --- /dev/null +++ b/helmrepository-source-v1.json @@ -0,0 +1,255 @@ +{ + "description": "HelmRepository is the Schema for the helmrepositories API.", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string" + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string" + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "HelmRepositorySpec specifies the required configuration to produce an\nArtifact for a Helm repository index YAML.", + "properties": { + "accessFrom": { + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "properties": { + "namespaceSelectors": { + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", + "items": { + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", + "properties": { + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "additionalProperties": false + }, + "type": "array" + } + }, + "required": [ + "namespaceSelectors" + ], + "type": "object", + "additionalProperties": false + }, + "certSecretRef": { + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nIt takes precedence over the values specified in the Secret referred\nto by `.spec.secretRef`.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "insecure": { + "description": "Insecure allows connecting to a non-TLS HTTP container registry.\nThis field is only taken into account if the .spec.type field is set to 'oci'.", + "type": "boolean" + }, + "interval": { + "description": "Interval at which the HelmRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "passCredentials": { + "description": "PassCredentials allows the credentials from the SecretRef to be passed\non to a host that does not match the host as defined in URL.\nThis may be required if the host of the advertised chart URLs in the\nindex differ from the defined URL.\nEnabling this should be done with caution, as it can potentially result\nin credentials getting stolen in a MITM-attack.", + "type": "boolean" + }, + "provider": { + "default": "generic", + "description": "Provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nThis field is optional, and only taken into account if the .spec.type field is set to 'oci'.\nWhen not specified, defaults to 'generic'.", + "enum": [ + "generic", + "aws", + "azure", + "gcp" + ], + "type": "string" + }, + "secretRef": { + "description": "SecretRef specifies the Secret containing authentication credentials\nfor the HelmRepository.\nFor HTTP/S basic auth the secret must contain 'username' and 'password'\nfields.\nSupport for TLS auth using the 'certFile' and 'keyFile', and/or 'caFile'\nkeys is deprecated. Please use `.spec.certSecretRef` instead.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to suspend the reconciliation of this\nHelmRepository.", + "type": "boolean" + }, + "timeout": { + "description": "Timeout is used for the index fetch operation for an HTTPS helm repository,\nand for remote OCI Repository operations like pulling for an OCI helm\nchart by the associated HelmChart.\nIts default value is 60s.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", + "type": "string" + }, + "type": { + "description": "Type of the HelmRepository.\nWhen this field is set to \"oci\", the URL field value must be prefixed with \"oci://\".", + "enum": [ + "default", + "oci" + ], + "type": "string" + }, + "url": { + "description": "URL of the Helm repository, a valid URL contains at least a protocol and\nhost.", + "pattern": "^(http|https|oci)://.*$", + "type": "string" + } + }, + "required": [ + "url" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "HelmRepositoryStatus records the observed state of the HelmRepository.", + "properties": { + "artifact": { + "description": "Artifact represents the last successful HelmRepository reconciliation.", + "properties": { + "digest": { + "description": "Digest is the digest of the file in the form of ':'.", + "pattern": "^[a-z0-9]+(?:[.+_-][a-z0-9]+)*:[a-zA-Z0-9=_-]+$", + "type": "string" + }, + "lastUpdateTime": { + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", + "format": "date-time", + "type": "string" + }, + "metadata": { + "additionalProperties": { + "type": "string" + }, + "description": "Metadata holds upstream information such as OCI annotations.", + "type": "object" + }, + "path": { + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", + "type": "string" + }, + "revision": { + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "type": "string" + }, + "size": { + "description": "Size is the number of bytes in the file.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", + "type": "string" + } + }, + "required": [ + "lastUpdateTime", + "path", + "revision", + "url" + ], + "type": "object", + "additionalProperties": false + }, + "conditions": { + "description": "Conditions holds the conditions for the HelmRepository.", + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "observedGeneration": { + "description": "ObservedGeneration is the last observed generation of the HelmRepository\nobject.", + "format": "int64", + "type": "integer" + }, + "url": { + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nHelmRepositoryStatus.Artifact data is recommended.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" +} \ No newline at end of file diff --git a/helmrepository-source-v1beta1.json b/helmrepository-source-v1beta1.json index b916190..108a9b2 100644 --- a/helmrepository-source-v1beta1.json +++ b/helmrepository-source-v1beta1.json @@ -2,11 +2,11 @@ "description": "HelmRepository is the Schema for the helmrepositories API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -19,15 +19,15 @@ "description": "AccessFrom defines an Access Control List for allowing cross-namespace references to this object.", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -48,11 +48,11 @@ "type": "string" }, "passCredentials": { - "description": "PassCredentials allows the credentials from the SecretRef to be passed on to a host that does not match the host as defined in URL. This may be required if the host of the advertised chart URLs in the index differ from the defined URL. Enabling this should be done with caution, as it can potentially result in credentials getting stolen in a MITM-attack.", + "description": "PassCredentials allows the credentials from the SecretRef to be passed on to\na host that does not match the host as defined in URL.\nThis may be required if the host of the advertised chart URLs in the index\ndiffer from the defined URL.\nEnabling this should be done with caution, as it can potentially result in\ncredentials getting stolen in a MITM-attack.", "type": "boolean" }, "secretRef": { - "description": "The name of the secret containing authentication credentials for the Helm repository. For HTTP/S basic auth the secret must contain username and password fields. For TLS the secret must contain a certFile and keyFile, and/or caFile fields.", + "description": "The name of the secret containing authentication credentials for the Helm\nrepository.\nFor HTTP/S basic auth the secret must contain username and\npassword fields.\nFor TLS the secret must contain a certFile and keyFile, and/or\ncaFile fields.", "properties": { "name": { "description": "Name of the referent.", @@ -100,7 +100,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of this artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of this\nartifact.", "format": "date-time", "type": "string" }, @@ -109,7 +109,7 @@ "type": "string" }, "revision": { - "description": "Revision is a human readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm chart version, etc.", + "description": "Revision is a human readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm index timestamp, a Helm\nchart version, etc.", "type": "string" }, "url": { @@ -127,26 +127,26 @@ "conditions": { "description": "Conditions holds the conditions for the HelmRepository.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -162,7 +162,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -181,7 +181,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { diff --git a/helmrepository-source-v1beta2.json b/helmrepository-source-v1beta2.json index 6e80897..56313fa 100644 --- a/helmrepository-source-v1beta2.json +++ b/helmrepository-source-v1beta2.json @@ -2,32 +2,32 @@ "description": "HelmRepository is the Schema for the helmrepositories API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "HelmRepositorySpec specifies the required configuration to produce an Artifact for a Helm repository index YAML.", + "description": "HelmRepositorySpec specifies the required configuration to produce an\nArtifact for a Helm repository index YAML.", "properties": { "accessFrom": { - "description": "AccessFrom specifies an Access Control List for allowing cross-namespace references to this object. NOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", + "description": "AccessFrom specifies an Access Control List for allowing cross-namespace\nreferences to this object.\nNOTE: Not implemented, provisional as of https://github.com/fluxcd/flux2/pull/2092", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -44,7 +44,7 @@ "additionalProperties": false }, "certSecretRef": { - "description": "CertSecretRef can be given the name of a Secret containing either or both of \n - a PEM-encoded client certificate (`tls.crt`) and private key (`tls.key`); - a PEM-encoded CA certificate (`ca.crt`) \n and whichever are supplied, will be used for connecting to the registry. The client cert and key are useful if you are authenticating with a certificate; the CA cert is useful if you are using a self-signed server certificate. The Secret must be of type `Opaque` or `kubernetes.io/tls`. \n It takes precedence over the values specified in the Secret referred to by `.spec.secretRef`.", + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nIt takes precedence over the values specified in the Secret referred\nto by `.spec.secretRef`.", "properties": { "name": { "description": "Name of the referent.", @@ -58,21 +58,21 @@ "additionalProperties": false }, "insecure": { - "description": "Insecure allows connecting to a non-TLS HTTP container registry. This field is only taken into account if the .spec.type field is set to 'oci'.", + "description": "Insecure allows connecting to a non-TLS HTTP container registry.\nThis field is only taken into account if the .spec.type field is set to 'oci'.", "type": "boolean" }, "interval": { - "description": "Interval at which the HelmRepository URL is checked for updates. This interval is approximate and may be subject to jitter to ensure efficient use of resources.", + "description": "Interval at which the HelmRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "passCredentials": { - "description": "PassCredentials allows the credentials from the SecretRef to be passed on to a host that does not match the host as defined in URL. This may be required if the host of the advertised chart URLs in the index differ from the defined URL. Enabling this should be done with caution, as it can potentially result in credentials getting stolen in a MITM-attack.", + "description": "PassCredentials allows the credentials from the SecretRef to be passed\non to a host that does not match the host as defined in URL.\nThis may be required if the host of the advertised chart URLs in the\nindex differ from the defined URL.\nEnabling this should be done with caution, as it can potentially result\nin credentials getting stolen in a MITM-attack.", "type": "boolean" }, "provider": { "default": "generic", - "description": "Provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'. This field is optional, and only taken into account if the .spec.type field is set to 'oci'. When not specified, defaults to 'generic'.", + "description": "Provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nThis field is optional, and only taken into account if the .spec.type field is set to 'oci'.\nWhen not specified, defaults to 'generic'.", "enum": [ "generic", "aws", @@ -82,7 +82,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Secret containing authentication credentials for the HelmRepository. For HTTP/S basic auth the secret must contain 'username' and 'password' fields. Support for TLS auth using the 'certFile' and 'keyFile', and/or 'caFile' keys is deprecated. Please use `.spec.certSecretRef` instead.", + "description": "SecretRef specifies the Secret containing authentication credentials\nfor the HelmRepository.\nFor HTTP/S basic auth the secret must contain 'username' and 'password'\nfields.\nSupport for TLS auth using the 'certFile' and 'keyFile', and/or 'caFile'\nkeys is deprecated. Please use `.spec.certSecretRef` instead.", "properties": { "name": { "description": "Name of the referent.", @@ -96,16 +96,16 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend the reconciliation of this HelmRepository.", + "description": "Suspend tells the controller to suspend the reconciliation of this\nHelmRepository.", "type": "boolean" }, "timeout": { - "description": "Timeout is used for the index fetch operation for an HTTPS helm repository, and for remote OCI Repository operations like pulling for an OCI helm chart by the associated HelmChart. Its default value is 60s.", + "description": "Timeout is used for the index fetch operation for an HTTPS helm repository,\nand for remote OCI Repository operations like pulling for an OCI helm\nchart by the associated HelmChart.\nIts default value is 60s.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", "type": "string" }, "type": { - "description": "Type of the HelmRepository. When this field is set to \"oci\", the URL field value must be prefixed with \"oci://\".", + "description": "Type of the HelmRepository.\nWhen this field is set to \"oci\", the URL field value must be prefixed with \"oci://\".", "enum": [ "default", "oci" @@ -113,7 +113,7 @@ "type": "string" }, "url": { - "description": "URL of the Helm repository, a valid URL contains at least a protocol and host.", + "description": "URL of the Helm repository, a valid URL contains at least a protocol and\nhost.", "pattern": "^(http|https|oci)://.*$", "type": "string" } @@ -139,7 +139,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -151,11 +151,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -164,7 +164,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -180,26 +180,26 @@ "conditions": { "description": "Conditions holds the conditions for the HelmRepository.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -215,7 +215,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -234,16 +234,16 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { - "description": "ObservedGeneration is the last observed generation of the HelmRepository object.", + "description": "ObservedGeneration is the last observed generation of the HelmRepository\nobject.", "format": "int64", "type": "integer" }, "url": { - "description": "URL is the dynamic fetch link for the latest Artifact. It is provided on a \"best effort\" basis, and using the precise HelmRepositoryStatus.Artifact data is recommended.", + "description": "URL is the dynamic fetch link for the latest Artifact.\nIt is provided on a \"best effort\" basis, and using the precise\nHelmRepositoryStatus.Artifact data is recommended.", "type": "string" } }, diff --git a/imagepolicy-image-v1beta1.json b/imagepolicy-image-v1beta1.json index 24e1074..929ecb2 100644 --- a/imagepolicy-image-v1beta1.json +++ b/imagepolicy-image-v1beta1.json @@ -2,28 +2,28 @@ "description": "ImagePolicy is the Schema for the imagepolicies API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "ImagePolicySpec defines the parameters for calculating the ImagePolicy", + "description": "ImagePolicySpec defines the parameters for calculating the\nImagePolicy", "properties": { "filterTags": { - "description": "FilterTags enables filtering for only a subset of tags based on a set of rules. If no rules are provided, all the tags from the repository will be ordered and compared.", + "description": "FilterTags enables filtering for only a subset of tags based on a set of\nrules. If no rules are provided, all the tags from the repository will be\nordered and compared.", "properties": { "extract": { - "description": "Extract allows a capture group to be extracted from the specified regular expression pattern, useful before tag evaluation.", + "description": "Extract allows a capture group to be extracted from the specified regular\nexpression pattern, useful before tag evaluation.", "type": "string" }, "pattern": { - "description": "Pattern specifies a regular expression pattern used to filter for image tags.", + "description": "Pattern specifies a regular expression pattern used to filter for image\ntags.", "type": "string" } }, @@ -31,7 +31,7 @@ "additionalProperties": false }, "imageRepositoryRef": { - "description": "ImageRepositoryRef points at the object specifying the image being scanned", + "description": "ImageRepositoryRef points at the object specifying the image\nbeing scanned", "properties": { "name": { "description": "Name of the referent.", @@ -49,14 +49,14 @@ "additionalProperties": false }, "policy": { - "description": "Policy gives the particulars of the policy to be followed in selecting the most recent image", + "description": "Policy gives the particulars of the policy to be followed in\nselecting the most recent image", "properties": { "alphabetical": { "description": "Alphabetical set of rules to use for alphabetical ordering of the tags.", "properties": { "order": { "default": "asc", - "description": "Order specifies the sorting order of the tags. Given the letters of the alphabet as tags, ascending order would select Z, and descending order would select A.", + "description": "Order specifies the sorting order of the tags. Given the letters of the\nalphabet as tags, ascending order would select Z, and descending order\nwould select A.", "enum": [ "asc", "desc" @@ -72,7 +72,7 @@ "properties": { "order": { "default": "asc", - "description": "Order specifies the sorting order of the tags. Given the integer values from 0 to 9 as tags, ascending order would select 9, and descending order would select 0.", + "description": "Order specifies the sorting order of the tags. Given the integer values\nfrom 0 to 9 as tags, ascending order would select 9, and descending order\nwould select 0.", "enum": [ "asc", "desc" @@ -84,10 +84,10 @@ "additionalProperties": false }, "semver": { - "description": "SemVer gives a semantic version range to check against the tags available.", + "description": "SemVer gives a semantic version range to check against the tags\navailable.", "properties": { "range": { - "description": "Range gives a semver range for the image tag; the highest version within the range that's a tag yields the latest image.", + "description": "Range gives a semver range for the image tag; the highest\nversion within the range that's a tag yields the latest image.", "type": "string" } }, @@ -117,26 +117,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -152,7 +152,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -171,7 +171,7 @@ "type": "array" }, "latestImage": { - "description": "LatestImage gives the first in the list of images scanned by the image repository, when filtered and ordered according to the policy.", + "description": "LatestImage gives the first in the list of images scanned by\nthe image repository, when filtered and ordered according to\nthe policy.", "type": "string" }, "observedGeneration": { diff --git a/imagepolicy-image-v1beta2.json b/imagepolicy-image-v1beta2.json index 518de98..a19590e 100644 --- a/imagepolicy-image-v1beta2.json +++ b/imagepolicy-image-v1beta2.json @@ -2,28 +2,28 @@ "description": "ImagePolicy is the Schema for the imagepolicies API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "ImagePolicySpec defines the parameters for calculating the ImagePolicy.", + "description": "ImagePolicySpec defines the parameters for calculating the\nImagePolicy.", "properties": { "filterTags": { - "description": "FilterTags enables filtering for only a subset of tags based on a set of rules. If no rules are provided, all the tags from the repository will be ordered and compared.", + "description": "FilterTags enables filtering for only a subset of tags based on a set of\nrules. If no rules are provided, all the tags from the repository will be\nordered and compared.", "properties": { "extract": { - "description": "Extract allows a capture group to be extracted from the specified regular expression pattern, useful before tag evaluation.", + "description": "Extract allows a capture group to be extracted from the specified regular\nexpression pattern, useful before tag evaluation.", "type": "string" }, "pattern": { - "description": "Pattern specifies a regular expression pattern used to filter for image tags.", + "description": "Pattern specifies a regular expression pattern used to filter for image\ntags.", "type": "string" } }, @@ -31,7 +31,7 @@ "additionalProperties": false }, "imageRepositoryRef": { - "description": "ImageRepositoryRef points at the object specifying the image being scanned", + "description": "ImageRepositoryRef points at the object specifying the image\nbeing scanned", "properties": { "name": { "description": "Name of the referent.", @@ -49,14 +49,14 @@ "additionalProperties": false }, "policy": { - "description": "Policy gives the particulars of the policy to be followed in selecting the most recent image", + "description": "Policy gives the particulars of the policy to be followed in\nselecting the most recent image", "properties": { "alphabetical": { "description": "Alphabetical set of rules to use for alphabetical ordering of the tags.", "properties": { "order": { "default": "asc", - "description": "Order specifies the sorting order of the tags. Given the letters of the alphabet as tags, ascending order would select Z, and descending order would select A.", + "description": "Order specifies the sorting order of the tags. Given the letters of the\nalphabet as tags, ascending order would select Z, and descending order\nwould select A.", "enum": [ "asc", "desc" @@ -72,7 +72,7 @@ "properties": { "order": { "default": "asc", - "description": "Order specifies the sorting order of the tags. Given the integer values from 0 to 9 as tags, ascending order would select 9, and descending order would select 0.", + "description": "Order specifies the sorting order of the tags. Given the integer values\nfrom 0 to 9 as tags, ascending order would select 9, and descending order\nwould select 0.", "enum": [ "asc", "desc" @@ -84,10 +84,10 @@ "additionalProperties": false }, "semver": { - "description": "SemVer gives a semantic version range to check against the tags available.", + "description": "SemVer gives a semantic version range to check against the tags\navailable.", "properties": { "range": { - "description": "Range gives a semver range for the image tag; the highest version within the range that's a tag yields the latest image.", + "description": "Range gives a semver range for the image tag; the highest\nversion within the range that's a tag yields the latest image.", "type": "string" } }, @@ -117,26 +117,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -152,7 +152,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -171,7 +171,7 @@ "type": "array" }, "latestImage": { - "description": "LatestImage gives the first in the list of images scanned by the image repository, when filtered and ordered according to the policy.", + "description": "LatestImage gives the first in the list of images scanned by\nthe image repository, when filtered and ordered according to\nthe policy.", "type": "string" }, "observedGeneration": { @@ -179,7 +179,7 @@ "type": "integer" }, "observedPreviousImage": { - "description": "ObservedPreviousImage is the observed previous LatestImage. It is used to keep track of the previous and current images.", + "description": "ObservedPreviousImage is the observed previous LatestImage. It is used\nto keep track of the previous and current images.", "type": "string" } }, diff --git a/imagerepository-image-v1beta1.json b/imagerepository-image-v1beta1.json index 90d5f25..5738c26 100644 --- a/imagerepository-image-v1beta1.json +++ b/imagerepository-image-v1beta1.json @@ -2,32 +2,32 @@ "description": "ImageRepository is the Schema for the imagerepositories API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "ImageRepositorySpec defines the parameters for scanning an image repository, e.g., `fluxcd/flux`.", + "description": "ImageRepositorySpec defines the parameters for scanning an image\nrepository, e.g., `fluxcd/flux`.", "properties": { "accessFrom": { - "description": "AccessFrom defines an ACL for allowing cross-namespace references to the ImageRepository object based on the caller's namespace labels.", + "description": "AccessFrom defines an ACL for allowing cross-namespace references\nto the ImageRepository object based on the caller's namespace labels.", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -44,7 +44,7 @@ "additionalProperties": false }, "certSecretRef": { - "description": "CertSecretRef can be given the name of a secret containing either or both of \n - a PEM-encoded client certificate (`certFile`) and private key (`keyFile`); - a PEM-encoded CA certificate (`caFile`) \n and whichever are supplied, will be used for connecting to the registry. The client cert and key are useful if you are authenticating with a certificate; the CA cert is useful if you are using a self-signed server certificate.", + "description": "CertSecretRef can be given the name of a secret containing\neither or both of\n\n\n - a PEM-encoded client certificate (`certFile`) and private\n key (`keyFile`);\n - a PEM-encoded CA certificate (`caFile`)\n\n\n and whichever are supplied, will be used for connecting to the\n registry. The client cert and key are useful if you are\n authenticating with a certificate; the CA cert is useful if\n you are using a self-signed server certificate.", "properties": { "name": { "description": "Name of the referent.", @@ -58,7 +58,7 @@ "additionalProperties": false }, "exclusionList": { - "description": "ExclusionList is a list of regex strings used to exclude certain tags from being stored in the database.", + "description": "ExclusionList is a list of regex strings used to exclude certain tags\nfrom being stored in the database.", "items": { "type": "string" }, @@ -69,12 +69,12 @@ "type": "string" }, "interval": { - "description": "Interval is the length of time to wait between scans of the image repository.", + "description": "Interval is the length of time to wait between\nscans of the image repository.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "secretRef": { - "description": "SecretRef can be given the name of a secret containing credentials to use for the image registry. The secret should be created with `kubectl create secret docker-registry`, or the equivalent.", + "description": "SecretRef can be given the name of a secret containing\ncredentials to use for the image registry. The secret should be\ncreated with `kubectl create secret docker-registry`, or the\nequivalent.", "properties": { "name": { "description": "Name of the referent.", @@ -88,16 +88,16 @@ "additionalProperties": false }, "serviceAccountName": { - "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate the image pull if the service account has attached pull secrets.", + "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate\nthe image pull if the service account has attached pull secrets.", "maxLength": 253, "type": "string" }, "suspend": { - "description": "This flag tells the controller to suspend subsequent image scans. It does not apply to already started scans. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent image scans.\nIt does not apply to already started scans. Defaults to false.", "type": "boolean" }, "timeout": { - "description": "Timeout for image scanning. Defaults to 'Interval' duration.", + "description": "Timeout for image scanning.\nDefaults to 'Interval' duration.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", "type": "string" } @@ -112,31 +112,31 @@ "description": "ImageRepositoryStatus defines the observed state of ImageRepository", "properties": { "canonicalImageName": { - "description": "CanonicalName is the name of the image repository with all the implied bits made explicit; e.g., `docker.io/library/alpine` rather than `alpine`.", + "description": "CanonicalName is the name of the image repository with all the\nimplied bits made explicit; e.g., `docker.io/library/alpine`\nrather than `alpine`.", "type": "string" }, "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -152,7 +152,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -171,7 +171,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "lastScanResult": { diff --git a/imagerepository-image-v1beta2.json b/imagerepository-image-v1beta2.json index 1261897..3ae7195 100644 --- a/imagerepository-image-v1beta2.json +++ b/imagerepository-image-v1beta2.json @@ -2,32 +2,32 @@ "description": "ImageRepository is the Schema for the imagerepositories API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "ImageRepositorySpec defines the parameters for scanning an image repository, e.g., `fluxcd/flux`.", + "description": "ImageRepositorySpec defines the parameters for scanning an image\nrepository, e.g., `fluxcd/flux`.", "properties": { "accessFrom": { - "description": "AccessFrom defines an ACL for allowing cross-namespace references to the ImageRepository object based on the caller's namespace labels.", + "description": "AccessFrom defines an ACL for allowing cross-namespace references\nto the ImageRepository object based on the caller's namespace labels.", "properties": { "namespaceSelectors": { - "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies. Items in this list are evaluated using a logical OR operation.", + "description": "NamespaceSelectors is the list of namespace selectors to which this ACL applies.\nItems in this list are evaluated using a logical OR operation.", "items": { - "description": "NamespaceSelector selects the namespaces to which this ACL applies. An empty map of MatchLabels matches all namespaces in a cluster.", + "description": "NamespaceSelector selects the namespaces to which this ACL applies.\nAn empty map of MatchLabels matches all namespaces in a cluster.", "properties": { "matchLabels": { "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" } }, @@ -44,7 +44,7 @@ "additionalProperties": false }, "certSecretRef": { - "description": "CertSecretRef can be given the name of a Secret containing either or both of \n - a PEM-encoded client certificate (`tls.crt`) and private key (`tls.key`); - a PEM-encoded CA certificate (`ca.crt`) \n and whichever are supplied, will be used for connecting to the registry. The client cert and key are useful if you are authenticating with a certificate; the CA cert is useful if you are using a self-signed server certificate. The Secret must be of type `Opaque` or `kubernetes.io/tls`. \n Note: Support for the `caFile`, `certFile` and `keyFile` keys has been deprecated.", + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nNote: Support for the `caFile`, `certFile` and `keyFile` keys has\nbeen deprecated.", "properties": { "name": { "description": "Name of the referent.", @@ -61,7 +61,7 @@ "default": [ "^.*\\.sig$" ], - "description": "ExclusionList is a list of regex strings used to exclude certain tags from being stored in the database.", + "description": "ExclusionList is a list of regex strings used to exclude certain tags\nfrom being stored in the database.", "items": { "type": "string" }, @@ -77,13 +77,13 @@ "type": "boolean" }, "interval": { - "description": "Interval is the length of time to wait between scans of the image repository.", + "description": "Interval is the length of time to wait between\nscans of the image repository.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "provider": { "default": "generic", - "description": "The provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'. When not specified, defaults to 'generic'.", + "description": "The provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nWhen not specified, defaults to 'generic'.", "enum": [ "generic", "aws", @@ -93,7 +93,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef can be given the name of a secret containing credentials to use for the image registry. The secret should be created with `kubectl create secret docker-registry`, or the equivalent.", + "description": "SecretRef can be given the name of a secret containing\ncredentials to use for the image registry. The secret should be\ncreated with `kubectl create secret docker-registry`, or the\nequivalent.", "properties": { "name": { "description": "Name of the referent.", @@ -107,16 +107,16 @@ "additionalProperties": false }, "serviceAccountName": { - "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate the image pull if the service account has attached pull secrets.", + "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate\nthe image pull if the service account has attached pull secrets.", "maxLength": 253, "type": "string" }, "suspend": { - "description": "This flag tells the controller to suspend subsequent image scans. It does not apply to already started scans. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent image scans.\nIt does not apply to already started scans. Defaults to false.", "type": "boolean" }, "timeout": { - "description": "Timeout for image scanning. Defaults to 'Interval' duration.", + "description": "Timeout for image scanning.\nDefaults to 'Interval' duration.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m))+$", "type": "string" } @@ -131,31 +131,31 @@ "description": "ImageRepositoryStatus defines the observed state of ImageRepository", "properties": { "canonicalImageName": { - "description": "CanonicalName is the name of the image repository with all the implied bits made explicit; e.g., `docker.io/library/alpine` rather than `alpine`.", + "description": "CanonicalName is the name of the image repository with all the\nimplied bits made explicit; e.g., `docker.io/library/alpine`\nrather than `alpine`.", "type": "string" }, "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -171,7 +171,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -190,7 +190,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "lastScanResult": { @@ -217,7 +217,7 @@ "additionalProperties": false }, "observedExclusionList": { - "description": "ObservedExclusionList is a list of observed exclusion list. It reflects the exclusion rules used for the observed scan result in spec.lastScanResult.", + "description": "ObservedExclusionList is a list of observed exclusion list. It reflects\nthe exclusion rules used for the observed scan result in\nspec.lastScanResult.", "items": { "type": "string" }, diff --git a/imageupdateautomation-image-v1beta1.json b/imageupdateautomation-image-v1beta1.json index 26bb6eb..fdff4d6 100644 --- a/imageupdateautomation-image-v1beta1.json +++ b/imageupdateautomation-image-v1beta1.json @@ -2,11 +2,11 @@ "description": "ImageUpdateAutomation is the Schema for the imageupdateautomations API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,24 +16,24 @@ "description": "ImageUpdateAutomationSpec defines the desired state of ImageUpdateAutomation", "properties": { "git": { - "description": "GitSpec contains all the git-specific definitions. This is technically optional, but in practice mandatory until there are other kinds of source allowed.", + "description": "GitSpec contains all the git-specific definitions. This is\ntechnically optional, but in practice mandatory until there are\nother kinds of source allowed.", "properties": { "checkout": { - "description": "Checkout gives the parameters for cloning the git repository, ready to make changes. If not present, the `spec.ref` field from the referenced `GitRepository` or its default will be used.", + "description": "Checkout gives the parameters for cloning the git repository,\nready to make changes. If not present, the `spec.ref` field from the\nreferenced `GitRepository` or its default will be used.", "properties": { "ref": { - "description": "Reference gives a branch, tag or commit to clone from the Git repository.", + "description": "Reference gives a branch, tag or commit to clone from the Git\nrepository.", "properties": { "branch": { "description": "Branch to check out, defaults to 'master' if no other field is defined.", "type": "string" }, "commit": { - "description": "Commit SHA to check out, takes precedence over all reference fields. \n This can be combined with Branch to shallow clone the branch, in which the commit is expected to exist.", + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", "type": "string" }, "name": { - "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer. \n It must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description Examples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", "type": "string" }, "semver": { @@ -59,7 +59,7 @@ "description": "Commit specifies how to commit to the git repository.", "properties": { "author": { - "description": "Author gives the email and optionally the name to use as the author of commits.", + "description": "Author gives the email and optionally the name to use as the\nauthor of commits.", "properties": { "email": { "description": "Email gives the email to provide when making a commit.", @@ -77,14 +77,14 @@ "additionalProperties": false }, "messageTemplate": { - "description": "MessageTemplate provides a template for the commit message, into which will be interpolated the details of the change made.", + "description": "MessageTemplate provides a template for the commit message,\ninto which will be interpolated the details of the change made.", "type": "string" }, "signingKey": { "description": "SigningKey provides the option to sign commits with a GPG key", "properties": { "secretRef": { - "description": "SecretRef holds the name to a secret that contains a 'git.asc' key corresponding to the ASCII Armored file containing the GPG signing keypair as the value. It must be in the same namespace as the ImageUpdateAutomation.", + "description": "SecretRef holds the name to a secret that contains a 'git.asc' key\ncorresponding to the ASCII Armored file containing the GPG signing\nkeypair as the value. It must be in the same namespace as the\nImageUpdateAutomation.", "properties": { "name": { "description": "Name of the referent.", @@ -109,21 +109,21 @@ "additionalProperties": false }, "push": { - "description": "Push specifies how and where to push commits made by the automation. If missing, commits are pushed (back) to `.spec.checkout.branch` or its default.", + "description": "Push specifies how and where to push commits made by the\nautomation. If missing, commits are pushed (back) to\n`.spec.checkout.branch` or its default.", "properties": { "branch": { - "description": "Branch specifies that commits should be pushed to the branch named. The branch is created using `.spec.checkout.branch` as the starting point, if it doesn't already exist.", + "description": "Branch specifies that commits should be pushed to the branch\nnamed. The branch is created using `.spec.checkout.branch` as the\nstarting point, if it doesn't already exist.", "type": "string" }, "options": { "additionalProperties": { "type": "string" }, - "description": "Options specifies the push options that are sent to the Git server when performing a push operation. For details, see: https://git-scm.com/docs/git-push#Documentation/git-push.txt---push-optionltoptiongt", + "description": "Options specifies the push options that are sent to the Git\nserver when performing a push operation. For details, see:\nhttps://git-scm.com/docs/git-push#Documentation/git-push.txt---push-optionltoptiongt", "type": "object" }, "refspec": { - "description": "Refspec specifies the Git Refspec to use for a push operation. If both Branch and Refspec are provided, then the commit is pushed to the branch and also using the specified refspec. For more details about Git Refspecs, see: https://git-scm.com/book/en/v2/Git-Internals-The-Refspec", + "description": "Refspec specifies the Git Refspec to use for a push operation.\nIf both Branch and Refspec are provided, then the commit is pushed\nto the branch and also using the specified refspec.\nFor more details about Git Refspecs, see:\nhttps://git-scm.com/book/en/v2/Git-Internals-The-Refspec", "type": "string" } }, @@ -138,12 +138,12 @@ "additionalProperties": false }, "interval": { - "description": "Interval gives an lower bound for how often the automation run should be attempted.", + "description": "Interval gives an lower bound for how often the automation\nrun should be attempted.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "sourceRef": { - "description": "SourceRef refers to the resource giving access details to a git repository.", + "description": "SourceRef refers to the resource giving access details\nto a git repository.", "properties": { "apiVersion": { "description": "API version of the referent.", @@ -174,17 +174,17 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to not run this automation, until it is unset (or set to false). Defaults to false.", + "description": "Suspend tells the controller to not run this automation, until\nit is unset (or set to false). Defaults to false.", "type": "boolean" }, "update": { "default": { "strategy": "Setters" }, - "description": "Update gives the specification for how to update the files in the repository. This can be left empty, to use the default value.", + "description": "Update gives the specification for how to update the files in\nthe repository. This can be left empty, to use the default\nvalue.", "properties": { "path": { - "description": "Path to the directory containing the manifests to be updated. Defaults to 'None', which translates to the root path of the GitRepositoryRef.", + "description": "Path to the directory containing the manifests to be updated.\nDefaults to 'None', which translates to the root path\nof the GitRepositoryRef.", "type": "string" }, "strategy": { @@ -218,26 +218,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -253,7 +253,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -272,16 +272,16 @@ "type": "array" }, "lastAutomationRunTime": { - "description": "LastAutomationRunTime records the last time the controller ran this automation through to completion (even if no updates were made).", + "description": "LastAutomationRunTime records the last time the controller ran\nthis automation through to completion (even if no updates were\nmade).", "format": "date-time", "type": "string" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "lastPushCommit": { - "description": "LastPushCommit records the SHA1 of the last commit made by the controller, for this automation object", + "description": "LastPushCommit records the SHA1 of the last commit made by the\ncontroller, for this automation object", "type": "string" }, "lastPushTime": { diff --git a/imageupdateautomation-image-v1beta2.json b/imageupdateautomation-image-v1beta2.json new file mode 100644 index 0000000..7bdd89a --- /dev/null +++ b/imageupdateautomation-image-v1beta2.json @@ -0,0 +1,376 @@ +{ + "description": "ImageUpdateAutomation is the Schema for the imageupdateautomations API", + "properties": { + "apiVersion": { + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "type": "string" + }, + "kind": { + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "type": "string" + }, + "metadata": { + "type": "object" + }, + "spec": { + "description": "ImageUpdateAutomationSpec defines the desired state of ImageUpdateAutomation", + "properties": { + "git": { + "description": "GitSpec contains all the git-specific definitions. This is\ntechnically optional, but in practice mandatory until there are\nother kinds of source allowed.", + "properties": { + "checkout": { + "description": "Checkout gives the parameters for cloning the git repository,\nready to make changes. If not present, the `spec.ref` field from the\nreferenced `GitRepository` or its default will be used.", + "properties": { + "ref": { + "description": "Reference gives a branch, tag or commit to clone from the Git\nrepository.", + "properties": { + "branch": { + "description": "Branch to check out, defaults to 'master' if no other field is defined.", + "type": "string" + }, + "commit": { + "description": "Commit SHA to check out, takes precedence over all reference fields.\n\n\nThis can be combined with Branch to shallow clone the branch, in which\nthe commit is expected to exist.", + "type": "string" + }, + "name": { + "description": "Name of the reference to check out; takes precedence over Branch, Tag and SemVer.\n\n\nIt must be a valid Git reference: https://git-scm.com/docs/git-check-ref-format#_description\nExamples: \"refs/heads/main\", \"refs/tags/v0.1.0\", \"refs/pull/420/head\", \"refs/merge-requests/1/head\"", + "type": "string" + }, + "semver": { + "description": "SemVer tag expression to check out, takes precedence over Tag.", + "type": "string" + }, + "tag": { + "description": "Tag to check out, takes precedence over Branch.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "ref" + ], + "type": "object", + "additionalProperties": false + }, + "commit": { + "description": "Commit specifies how to commit to the git repository.", + "properties": { + "author": { + "description": "Author gives the email and optionally the name to use as the\nauthor of commits.", + "properties": { + "email": { + "description": "Email gives the email to provide when making a commit.", + "type": "string" + }, + "name": { + "description": "Name gives the name to provide when making a commit.", + "type": "string" + } + }, + "required": [ + "email" + ], + "type": "object", + "additionalProperties": false + }, + "messageTemplate": { + "description": "MessageTemplate provides a template for the commit message,\ninto which will be interpolated the details of the change made.", + "type": "string" + }, + "signingKey": { + "description": "SigningKey provides the option to sign commits with a GPG key", + "properties": { + "secretRef": { + "description": "SecretRef holds the name to a secret that contains a 'git.asc' key\ncorresponding to the ASCII Armored file containing the GPG signing\nkeypair as the value. It must be in the same namespace as the\nImageUpdateAutomation.", + "properties": { + "name": { + "description": "Name of the referent.", + "type": "string" + } + }, + "required": [ + "name" + ], + "type": "object", + "additionalProperties": false + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "author" + ], + "type": "object", + "additionalProperties": false + }, + "push": { + "description": "Push specifies how and where to push commits made by the\nautomation. If missing, commits are pushed (back) to\n`.spec.checkout.branch` or its default.", + "properties": { + "branch": { + "description": "Branch specifies that commits should be pushed to the branch\nnamed. The branch is created using `.spec.checkout.branch` as the\nstarting point, if it doesn't already exist.", + "type": "string" + }, + "options": { + "additionalProperties": { + "type": "string" + }, + "description": "Options specifies the push options that are sent to the Git\nserver when performing a push operation. For details, see:\nhttps://git-scm.com/docs/git-push#Documentation/git-push.txt---push-optionltoptiongt", + "type": "object" + }, + "refspec": { + "description": "Refspec specifies the Git Refspec to use for a push operation.\nIf both Branch and Refspec are provided, then the commit is pushed\nto the branch and also using the specified refspec.\nFor more details about Git Refspecs, see:\nhttps://git-scm.com/book/en/v2/Git-Internals-The-Refspec", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "commit" + ], + "type": "object", + "additionalProperties": false + }, + "interval": { + "description": "Interval gives an lower bound for how often the automation\nrun should be attempted.", + "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", + "type": "string" + }, + "policySelector": { + "description": "PolicySelector allows to filter applied policies based on labels.\nBy default includes all policies in namespace.", + "properties": { + "matchExpressions": { + "description": "matchExpressions is a list of label selector requirements. The requirements are ANDed.", + "items": { + "description": "A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.", + "properties": { + "key": { + "description": "key is the label key that the selector applies to.", + "type": "string" + }, + "operator": { + "description": "operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.", + "type": "string" + }, + "values": { + "description": "values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.", + "items": { + "type": "string" + }, + "type": "array", + "x-kubernetes-list-type": "atomic" + } + }, + "required": [ + "key", + "operator" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array", + "x-kubernetes-list-type": "atomic" + }, + "matchLabels": { + "additionalProperties": { + "type": "string" + }, + "description": "matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "type": "object" + } + }, + "type": "object", + "x-kubernetes-map-type": "atomic", + "additionalProperties": false + }, + "sourceRef": { + "description": "SourceRef refers to the resource giving access details\nto a git repository.", + "properties": { + "apiVersion": { + "description": "API version of the referent.", + "type": "string" + }, + "kind": { + "default": "GitRepository", + "description": "Kind of the referent.", + "enum": [ + "GitRepository" + ], + "type": "string" + }, + "name": { + "description": "Name of the referent.", + "type": "string" + }, + "namespace": { + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes resource object that contains the reference.", + "type": "string" + } + }, + "required": [ + "kind", + "name" + ], + "type": "object", + "additionalProperties": false + }, + "suspend": { + "description": "Suspend tells the controller to not run this automation, until\nit is unset (or set to false). Defaults to false.", + "type": "boolean" + }, + "update": { + "default": { + "strategy": "Setters" + }, + "description": "Update gives the specification for how to update the files in\nthe repository. This can be left empty, to use the default\nvalue.", + "properties": { + "path": { + "description": "Path to the directory containing the manifests to be updated.\nDefaults to 'None', which translates to the root path\nof the GitRepositoryRef.", + "type": "string" + }, + "strategy": { + "default": "Setters", + "description": "Strategy names the strategy to be used.", + "enum": [ + "Setters" + ], + "type": "string" + } + }, + "required": [ + "strategy" + ], + "type": "object", + "additionalProperties": false + } + }, + "required": [ + "interval", + "sourceRef" + ], + "type": "object", + "additionalProperties": false + }, + "status": { + "default": { + "observedGeneration": -1 + }, + "description": "ImageUpdateAutomationStatus defines the observed state of ImageUpdateAutomation", + "properties": { + "conditions": { + "items": { + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", + "properties": { + "lastTransitionTime": { + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "format": "date-time", + "type": "string" + }, + "message": { + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", + "maxLength": 32768, + "type": "string" + }, + "observedGeneration": { + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", + "format": "int64", + "minimum": 0, + "type": "integer" + }, + "reason": { + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", + "maxLength": 1024, + "minLength": 1, + "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", + "type": "string" + }, + "status": { + "description": "status of the condition, one of True, False, Unknown.", + "enum": [ + "True", + "False", + "Unknown" + ], + "type": "string" + }, + "type": { + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "maxLength": 316, + "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", + "type": "string" + } + }, + "required": [ + "lastTransitionTime", + "message", + "reason", + "status", + "type" + ], + "type": "object", + "additionalProperties": false + }, + "type": "array" + }, + "lastAutomationRunTime": { + "description": "LastAutomationRunTime records the last time the controller ran\nthis automation through to completion (even if no updates were\nmade).", + "format": "date-time", + "type": "string" + }, + "lastHandledReconcileAt": { + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", + "type": "string" + }, + "lastPushCommit": { + "description": "LastPushCommit records the SHA1 of the last commit made by the\ncontroller, for this automation object", + "type": "string" + }, + "lastPushTime": { + "description": "LastPushTime records the time of the last pushed change.", + "format": "date-time", + "type": "string" + }, + "observedGeneration": { + "format": "int64", + "type": "integer" + }, + "observedPolicies": { + "additionalProperties": { + "description": "ImageRef represents an image reference.", + "properties": { + "name": { + "description": "Name is the bare image's name.", + "type": "string" + }, + "tag": { + "description": "Tag is the image's tag.", + "type": "string" + } + }, + "required": [ + "name", + "tag" + ], + "type": "object", + "additionalProperties": false + }, + "description": "ObservedPolicies is the list of observed ImagePolicies that were\nconsidered by the ImageUpdateAutomation update process.", + "type": "object" + }, + "observedSourceRevision": { + "description": "ObservedPolicies []ObservedPolicy `json:\"observedPolicies,omitempty\"`\nObservedSourceRevision is the last observed source revision. This can be\nused to determine if the source has been updated since last observation.", + "type": "string" + } + }, + "type": "object", + "additionalProperties": false + } + }, + "type": "object" +} \ No newline at end of file diff --git a/kustomization-kustomize-v1.json b/kustomization-kustomize-v1.json index 584380d..6bd90a1 100644 --- a/kustomization-kustomize-v1.json +++ b/kustomization-kustomize-v1.json @@ -2,21 +2,21 @@ "description": "Kustomization is the Schema for the kustomizations API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { "type": "object" }, "spec": { - "description": "KustomizationSpec defines the configuration to calculate the desired state from a Source using Kustomize.", + "description": "KustomizationSpec defines the configuration to calculate the desired state\nfrom a Source using Kustomize.", "properties": { "commonMetadata": { - "description": "CommonMetadata specifies the common labels and annotations that are applied to all resources. Any existing label or annotation will be overridden if its key matches a common one.", + "description": "CommonMetadata specifies the common labels and annotations that are\napplied to all resources. Any existing label or annotation will be\noverridden if its key matches a common one.", "properties": { "annotations": { "additionalProperties": { @@ -75,9 +75,9 @@ "additionalProperties": false }, "dependsOn": { - "description": "DependsOn may contain a meta.NamespacedObjectReference slice with references to Kustomization resources that must be ready before this Kustomization can be reconciled.", + "description": "DependsOn may contain a meta.NamespacedObjectReference slice\nwith references to Kustomization resources that must be ready before this\nKustomization can be reconciled.", "items": { - "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", "properties": { "name": { "description": "Name of the referent.", @@ -98,13 +98,13 @@ }, "force": { "default": false, - "description": "Force instructs the controller to recreate resources when patching fails due to an immutable field change.", + "description": "Force instructs the controller to recreate resources\nwhen patching fails due to an immutable field change.", "type": "boolean" }, "healthChecks": { "description": "A list of resources to be included in the health assessment.", "items": { - "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object\nin any namespace.", "properties": { "apiVersion": { "description": "API version of the referent, if not specified the Kubernetes preferred version will be used.", @@ -133,12 +133,12 @@ "type": "array" }, "images": { - "description": "Images is a list of (image name, new name, new tag or digest) for changing image names, tags or digests. This can also be achieved with a patch, but this operator is simpler to specify.", + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", "items": { "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", "properties": { "digest": { - "description": "Digest is the value used to replace the original image tag. If digest is present NewTag value is ignored.", + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", "type": "string" }, "name": { @@ -163,15 +163,15 @@ "type": "array" }, "interval": { - "description": "The interval at which to reconcile the Kustomization. This interval is approximate and may be subject to jitter to ensure efficient use of resources.", + "description": "The interval at which to reconcile the Kustomization.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "kubeConfig": { - "description": "The KubeConfig for reconciling the Kustomization on a remote cluster. When used in combination with KustomizationSpec.ServiceAccountName, forces the controller to act on behalf of that Service Account at the target cluster. If the --default-service-account flag is set, its value will be used as a controller level fallback for when KustomizationSpec.ServiceAccountName is empty.", + "description": "The KubeConfig for reconciling the Kustomization on a remote cluster.\nWhen used in combination with KustomizationSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when KustomizationSpec.ServiceAccountName\nis empty.", "properties": { "secretRef": { - "description": "SecretRef holds the name of a secret that contains a key with the kubeconfig file as the value. If no key is set, the key will default to 'value'. It is recommended that the kubeconfig is self-contained, and the secret is regularly updated if credentials such as a cloud-access-token expire. Cloud specific `cmd-path` auth helpers will not function without adding binaries and credentials to the Pod that is responsible for reconciling Kubernetes resources.", + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", "properties": { "key": { "description": "Key in the Secret, when not specified an implementation-specific default key is used.", @@ -195,32 +195,44 @@ "type": "object", "additionalProperties": false }, + "namePrefix": { + "description": "NamePrefix will prefix the names of all managed resources.", + "maxLength": 200, + "minLength": 1, + "type": "string" + }, + "nameSuffix": { + "description": "NameSuffix will suffix the names of all managed resources.", + "maxLength": 200, + "minLength": 1, + "type": "string" + }, "patches": { - "description": "Strategic merge and JSON patches, defined as inline YAML objects, capable of targeting objects based on kind, label and annotation selectors.", + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", "items": { - "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should be applied to.", + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", "properties": { "patch": { - "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with an array of operation objects.", + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", "type": "string" }, "target": { "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -232,7 +244,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -249,23 +261,23 @@ "type": "array" }, "path": { - "description": "Path to the directory containing the kustomization.yaml file, or the set of plain YAMLs a kustomization.yaml should be generated for. Defaults to 'None', which translates to the root path of the SourceRef.", + "description": "Path to the directory containing the kustomization.yaml file, or the\nset of plain YAMLs a kustomization.yaml should be generated for.\nDefaults to 'None', which translates to the root path of the SourceRef.", "type": "string" }, "postBuild": { - "description": "PostBuild describes which actions to perform on the YAML manifest generated by building the kustomize overlay.", + "description": "PostBuild describes which actions to perform on the YAML manifest\ngenerated by building the kustomize overlay.", "properties": { "substitute": { "additionalProperties": { "type": "string" }, - "description": "Substitute holds a map of key/value pairs. The variables defined in your YAML manifests that match any of the keys defined in the map will be substituted with the set value. Includes support for bash string replacement functions e.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", + "description": "Substitute holds a map of key/value pairs.\nThe variables defined in your YAML manifests that match any of the keys\ndefined in the map will be substituted with the set value.\nIncludes support for bash string replacement functions\ne.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", "type": "object" }, "substituteFrom": { - "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing the variables and their values to be substituted in the YAML manifests. The ConfigMap and the Secret data keys represent the var names, and they must match the vars declared in the manifests for the substitution to happen.", + "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing\nthe variables and their values to be substituted in the YAML manifests.\nThe ConfigMap and the Secret data keys represent the var names, and they\nmust match the vars declared in the manifests for the substitution to\nhappen.", "items": { - "description": "SubstituteReference contains a reference to a resource containing the variables name and value.", + "description": "SubstituteReference contains a reference to a resource containing\nthe variables name and value.", "properties": { "kind": { "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", @@ -276,14 +288,14 @@ "type": "string" }, "name": { - "description": "Name of the values referent. Should reside in the same namespace as the referring resource.", + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", "maxLength": 253, "minLength": 1, "type": "string" }, "optional": { "default": false, - "description": "Optional indicates whether the referenced resource must exist, or whether to tolerate its absence. If true and the referenced resource is absent, proceed as if the resource was present but empty, without any variables defined.", + "description": "Optional indicates whether the referenced resource must exist, or whether to\ntolerate its absence. If true and the referenced resource is absent, proceed\nas if the resource was present but empty, without any variables defined.", "type": "boolean" } }, @@ -305,12 +317,12 @@ "type": "boolean" }, "retryInterval": { - "description": "The interval at which to retry a previously failed reconciliation. When not specified, the controller uses the KustomizationSpec.Interval value to retry failures.", + "description": "The interval at which to retry a previously failed reconciliation.\nWhen not specified, the controller uses the KustomizationSpec.Interval\nvalue to retry failures.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "serviceAccountName": { - "description": "The name of the Kubernetes service account to impersonate when reconciling this Kustomization.", + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this Kustomization.", "type": "string" }, "sourceRef": { @@ -334,7 +346,7 @@ "type": "string" }, "namespace": { - "description": "Namespace of the referent, defaults to the namespace of the Kubernetes resource object that contains the reference.", + "description": "Namespace of the referent, defaults to the namespace of the Kubernetes\nresource object that contains the reference.", "type": "string" } }, @@ -346,22 +358,22 @@ "additionalProperties": false }, "suspend": { - "description": "This flag tells the controller to suspend subsequent kustomize executions, it does not apply to already started executions. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent kustomize executions,\nit does not apply to already started executions. Defaults to false.", "type": "boolean" }, "targetNamespace": { - "description": "TargetNamespace sets or overrides the namespace in the kustomization.yaml file.", + "description": "TargetNamespace sets or overrides the namespace in the\nkustomization.yaml file.", "maxLength": 63, "minLength": 1, "type": "string" }, "timeout": { - "description": "Timeout for validation, apply and health checking operations. Defaults to 'Interval' duration.", + "description": "Timeout for validation, apply and health checking operations.\nDefaults to 'Interval' duration.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "wait": { - "description": "Wait instructs the controller to check the health of all the reconciled resources. When enabled, the HealthChecks are ignored. Defaults to false.", + "description": "Wait instructs the controller to check the health of all the reconciled\nresources. When enabled, the HealthChecks are ignored. Defaults to false.", "type": "boolean" } }, @@ -381,26 +393,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -416,7 +428,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -435,7 +447,7 @@ "type": "array" }, "inventory": { - "description": "Inventory contains the list of Kubernetes resource object references that have been successfully applied.", + "description": "Inventory contains the list of Kubernetes resource object references that\nhave been successfully applied.", "properties": { "entries": { "description": "Entries of Kubernetes resource object references.", @@ -443,7 +455,7 @@ "description": "ResourceRef contains the information necessary to locate a resource within a cluster.", "properties": { "id": { - "description": "ID is the string representation of the Kubernetes resource object's metadata, in the format '___'.", + "description": "ID is the string representation of the Kubernetes resource object's metadata,\nin the format '___'.", "type": "string" }, "v": { @@ -468,7 +480,7 @@ "additionalProperties": false }, "lastAppliedRevision": { - "description": "The last successfully applied revision. Equals the Revision of the applied Artifact from the referenced Source.", + "description": "The last successfully applied revision.\nEquals the Revision of the applied Artifact from the referenced Source.", "type": "string" }, "lastAttemptedRevision": { @@ -476,7 +488,7 @@ "type": "string" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { diff --git a/kustomization-kustomize-v1beta1.json b/kustomization-kustomize-v1beta1.json index acd5a9d..f9496e9 100644 --- a/kustomization-kustomize-v1beta1.json +++ b/kustomization-kustomize-v1beta1.json @@ -2,11 +2,11 @@ "description": "Kustomization is the Schema for the kustomizations API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -47,9 +47,9 @@ "additionalProperties": false }, "dependsOn": { - "description": "DependsOn may contain a meta.NamespacedObjectReference slice with references to Kustomization resources that must be ready before this Kustomization can be reconciled.", + "description": "DependsOn may contain a meta.NamespacedObjectReference slice\nwith references to Kustomization resources that must be ready before this\nKustomization can be reconciled.", "items": { - "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", "properties": { "name": { "description": "Name of the referent.", @@ -70,13 +70,13 @@ }, "force": { "default": false, - "description": "Force instructs the controller to recreate resources when patching fails due to an immutable field change.", + "description": "Force instructs the controller to recreate resources\nwhen patching fails due to an immutable field change.", "type": "boolean" }, "healthChecks": { "description": "A list of resources to be included in the health assessment.", "items": { - "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object\nin any namespace.", "properties": { "apiVersion": { "description": "API version of the referent, if not specified the Kubernetes preferred version will be used.", @@ -105,12 +105,12 @@ "type": "array" }, "images": { - "description": "Images is a list of (image name, new name, new tag or digest) for changing image names, tags or digests. This can also be achieved with a patch, but this operator is simpler to specify.", + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", "items": { "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", "properties": { "digest": { - "description": "Digest is the value used to replace the original image tag. If digest is present NewTag value is ignored.", + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", "type": "string" }, "name": { @@ -139,10 +139,10 @@ "type": "string" }, "kubeConfig": { - "description": "The KubeConfig for reconciling the Kustomization on a remote cluster. When specified, KubeConfig takes precedence over ServiceAccountName.", + "description": "The KubeConfig for reconciling the Kustomization on a remote cluster.\nWhen specified, KubeConfig takes precedence over ServiceAccountName.", "properties": { "secretRef": { - "description": "SecretRef holds the name to a secret that contains a 'value' key with the kubeconfig file as the value. It must be in the same namespace as the Kustomization. It is recommended that the kubeconfig is self-contained, and the secret is regularly updated if credentials such as a cloud-access-token expire. Cloud specific `cmd-path` auth helpers will not function without adding binaries and credentials to the Pod that is responsible for reconciling the Kustomization.", + "description": "SecretRef holds the name to a secret that contains a 'value' key with\nthe kubeconfig file as the value. It must be in the same namespace as\nthe Kustomization.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nthe Kustomization.", "properties": { "name": { "description": "Name of the referent.", @@ -160,31 +160,31 @@ "additionalProperties": false }, "patches": { - "description": "Strategic merge and JSON patches, defined as inline YAML objects, capable of targeting objects based on kind, label and annotation selectors.", + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", "items": { - "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should be applied to.", + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", "properties": { "patch": { - "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with an array of operation objects.", + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", "type": "string" }, "target": { "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -196,7 +196,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -220,14 +220,14 @@ "patch": { "description": "Patch contains the JSON6902 patch document with an array of operation objects.", "items": { - "description": "JSON6902 is a JSON6902 operation object. https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "properties": { "from": { - "description": "From contains a JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", "type": "string" }, "op": { - "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or \"test\". https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "enum": [ "test", "remove", @@ -239,11 +239,11 @@ "type": "string" }, "path": { - "description": "Path contains the JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op.", + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", "type": "string" }, "value": { - "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", "x-kubernetes-preserve-unknown-fields": true } }, @@ -260,19 +260,19 @@ "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -284,7 +284,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -309,23 +309,23 @@ "type": "array" }, "path": { - "description": "Path to the directory containing the kustomization.yaml file, or the set of plain YAMLs a kustomization.yaml should be generated for. Defaults to 'None', which translates to the root path of the SourceRef.", + "description": "Path to the directory containing the kustomization.yaml file, or the\nset of plain YAMLs a kustomization.yaml should be generated for.\nDefaults to 'None', which translates to the root path of the SourceRef.", "type": "string" }, "postBuild": { - "description": "PostBuild describes which actions to perform on the YAML manifest generated by building the kustomize overlay.", + "description": "PostBuild describes which actions to perform on the YAML manifest\ngenerated by building the kustomize overlay.", "properties": { "substitute": { "additionalProperties": { "type": "string" }, - "description": "Substitute holds a map of key/value pairs. The variables defined in your YAML manifests that match any of the keys defined in the map will be substituted with the set value. Includes support for bash string replacement functions e.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", + "description": "Substitute holds a map of key/value pairs.\nThe variables defined in your YAML manifests\nthat match any of the keys defined in the map\nwill be substituted with the set value.\nIncludes support for bash string replacement functions\ne.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", "type": "object" }, "substituteFrom": { - "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing the variables and their values to be substituted in the YAML manifests. The ConfigMap and the Secret data keys represent the var names and they must match the vars declared in the manifests for the substitution to happen.", + "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing\nthe variables and their values to be substituted in the YAML manifests.\nThe ConfigMap and the Secret data keys represent the var names and they\nmust match the vars declared in the manifests for the substitution to happen.", "items": { - "description": "SubstituteReference contains a reference to a resource containing the variables name and value.", + "description": "SubstituteReference contains a reference to a resource containing\nthe variables name and value.", "properties": { "kind": { "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", @@ -336,7 +336,7 @@ "type": "string" }, "name": { - "description": "Name of the values referent. Should reside in the same namespace as the referring resource.", + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", "maxLength": 253, "minLength": 1, "type": "string" @@ -360,11 +360,11 @@ "type": "boolean" }, "retryInterval": { - "description": "The interval at which to retry a previously failed reconciliation. When not specified, the controller uses the KustomizationSpec.Interval value to retry failures.", + "description": "The interval at which to retry a previously failed reconciliation.\nWhen not specified, the controller uses the KustomizationSpec.Interval\nvalue to retry failures.", "type": "string" }, "serviceAccountName": { - "description": "The name of the Kubernetes service account to impersonate when reconciling this Kustomization.", + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this Kustomization.", "type": "string" }, "sourceRef": { @@ -399,21 +399,21 @@ "additionalProperties": false }, "suspend": { - "description": "This flag tells the controller to suspend subsequent kustomize executions, it does not apply to already started executions. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent kustomize executions,\nit does not apply to already started executions. Defaults to false.", "type": "boolean" }, "targetNamespace": { - "description": "TargetNamespace sets or overrides the namespace in the kustomization.yaml file.", + "description": "TargetNamespace sets or overrides the namespace in the\nkustomization.yaml file.", "maxLength": 63, "minLength": 1, "type": "string" }, "timeout": { - "description": "Timeout for validation, apply and health checking operations. Defaults to 'Interval' duration.", + "description": "Timeout for validation, apply and health checking operations.\nDefaults to 'Interval' duration.", "type": "string" }, "validation": { - "description": "Validate the Kubernetes objects before applying them on the cluster. The validation strategy can be 'client' (local dry-run), 'server' (APIServer dry-run) or 'none'. When 'Force' is 'true', validation will fallback to 'client' if set to 'server' because server-side validation is not supported in this scenario.", + "description": "Validate the Kubernetes objects before applying them on the cluster.\nThe validation strategy can be 'client' (local dry-run), 'server'\n(APIServer dry-run) or 'none'.\nWhen 'Force' is 'true', validation will fallback to 'client' if set to\n'server' because server-side validation is not supported in this scenario.", "enum": [ "none", "client", @@ -438,26 +438,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -473,7 +473,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -492,7 +492,7 @@ "type": "array" }, "lastAppliedRevision": { - "description": "The last successfully applied revision. The revision format for Git sources is /.", + "description": "The last successfully applied revision.\nThe revision format for Git sources is /.", "type": "string" }, "lastAttemptedRevision": { @@ -500,7 +500,7 @@ "type": "string" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { @@ -518,7 +518,7 @@ "entries": { "description": "A list of Kubernetes kinds grouped by namespace.", "items": { - "description": "Snapshot holds the metadata of namespaced Kubernetes objects", + "description": "Snapshot holds the metadata of namespaced\nKubernetes objects", "properties": { "kinds": { "additionalProperties": { diff --git a/kustomization-kustomize-v1beta2.json b/kustomization-kustomize-v1beta2.json index d75553e..bea2ba4 100644 --- a/kustomization-kustomize-v1beta2.json +++ b/kustomization-kustomize-v1beta2.json @@ -2,11 +2,11 @@ "description": "Kustomization is the Schema for the kustomizations API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,7 +16,7 @@ "description": "KustomizationSpec defines the configuration to calculate the desired state from a Source using Kustomize.", "properties": { "commonMetadata": { - "description": "CommonMetadata specifies the common labels and annotations that are applied to all resources. Any existing label or annotation will be overridden if its key matches a common one.", + "description": "CommonMetadata specifies the common labels and annotations that are applied to all resources.\nAny existing label or annotation will be overridden if its key matches a common one.", "properties": { "annotations": { "additionalProperties": { @@ -75,9 +75,9 @@ "additionalProperties": false }, "dependsOn": { - "description": "DependsOn may contain a meta.NamespacedObjectReference slice with references to Kustomization resources that must be ready before this Kustomization can be reconciled.", + "description": "DependsOn may contain a meta.NamespacedObjectReference slice\nwith references to Kustomization resources that must be ready before this\nKustomization can be reconciled.", "items": { - "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectReference contains enough information to locate the referenced Kubernetes resource object in any\nnamespace.", "properties": { "name": { "description": "Name of the referent.", @@ -98,13 +98,13 @@ }, "force": { "default": false, - "description": "Force instructs the controller to recreate resources when patching fails due to an immutable field change.", + "description": "Force instructs the controller to recreate resources\nwhen patching fails due to an immutable field change.", "type": "boolean" }, "healthChecks": { "description": "A list of resources to be included in the health assessment.", "items": { - "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object in any namespace.", + "description": "NamespacedObjectKindReference contains enough information to locate the typed referenced Kubernetes resource object\nin any namespace.", "properties": { "apiVersion": { "description": "API version of the referent, if not specified the Kubernetes preferred version will be used.", @@ -133,12 +133,12 @@ "type": "array" }, "images": { - "description": "Images is a list of (image name, new name, new tag or digest) for changing image names, tags or digests. This can also be achieved with a patch, but this operator is simpler to specify.", + "description": "Images is a list of (image name, new name, new tag or digest)\nfor changing image names, tags or digests. This can also be achieved with a\npatch, but this operator is simpler to specify.", "items": { "description": "Image contains an image name, a new name, a new tag or digest, which will replace the original name and tag.", "properties": { "digest": { - "description": "Digest is the value used to replace the original image tag. If digest is present NewTag value is ignored.", + "description": "Digest is the value used to replace the original image tag.\nIf digest is present NewTag value is ignored.", "type": "string" }, "name": { @@ -168,10 +168,10 @@ "type": "string" }, "kubeConfig": { - "description": "The KubeConfig for reconciling the Kustomization on a remote cluster. When used in combination with KustomizationSpec.ServiceAccountName, forces the controller to act on behalf of that Service Account at the target cluster. If the --default-service-account flag is set, its value will be used as a controller level fallback for when KustomizationSpec.ServiceAccountName is empty.", + "description": "The KubeConfig for reconciling the Kustomization on a remote cluster.\nWhen used in combination with KustomizationSpec.ServiceAccountName,\nforces the controller to act on behalf of that Service Account at the\ntarget cluster.\nIf the --default-service-account flag is set, its value will be used as\na controller level fallback for when KustomizationSpec.ServiceAccountName\nis empty.", "properties": { "secretRef": { - "description": "SecretRef holds the name of a secret that contains a key with the kubeconfig file as the value. If no key is set, the key will default to 'value'. It is recommended that the kubeconfig is self-contained, and the secret is regularly updated if credentials such as a cloud-access-token expire. Cloud specific `cmd-path` auth helpers will not function without adding binaries and credentials to the Pod that is responsible for reconciling Kubernetes resources.", + "description": "SecretRef holds the name of a secret that contains a key with\nthe kubeconfig file as the value. If no key is set, the key will default\nto 'value'.\nIt is recommended that the kubeconfig is self-contained, and the secret\nis regularly updated if credentials such as a cloud-access-token expire.\nCloud specific `cmd-path` auth helpers will not function without adding\nbinaries and credentials to the Pod that is responsible for reconciling\nKubernetes resources.", "properties": { "key": { "description": "Key in the Secret, when not specified an implementation-specific default key is used.", @@ -196,31 +196,31 @@ "additionalProperties": false }, "patches": { - "description": "Strategic merge and JSON patches, defined as inline YAML objects, capable of targeting objects based on kind, label and annotation selectors.", + "description": "Strategic merge and JSON patches, defined as inline YAML objects,\ncapable of targeting objects based on kind, label and annotation selectors.", "items": { - "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should be applied to.", + "description": "Patch contains an inline StrategicMerge or JSON6902 patch, and the target the patch should\nbe applied to.", "properties": { "patch": { - "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with an array of operation objects.", + "description": "Patch contains an inline StrategicMerge patch or an inline JSON6902 patch with\nan array of operation objects.", "type": "string" }, "target": { "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -232,7 +232,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -249,21 +249,21 @@ "type": "array" }, "patchesJson6902": { - "description": "JSON 6902 patches, defined as inline YAML objects. Deprecated: Use Patches instead.", + "description": "JSON 6902 patches, defined as inline YAML objects.\nDeprecated: Use Patches instead.", "items": { "description": "JSON6902Patch contains a JSON6902 patch and the target the patch should be applied to.", "properties": { "patch": { "description": "Patch contains the JSON6902 patch document with an array of operation objects.", "items": { - "description": "JSON6902 is a JSON6902 operation object. https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "JSON6902 is a JSON6902 operation object.\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "properties": { "from": { - "description": "From contains a JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "From contains a JSON-pointer value that references a location within the target document where the operation is\nperformed. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", "type": "string" }, "op": { - "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or \"test\". https://datatracker.ietf.org/doc/html/rfc6902#section-4", + "description": "Op indicates the operation to perform. Its value MUST be one of \"add\", \"remove\", \"replace\", \"move\", \"copy\", or\n\"test\".\nhttps://datatracker.ietf.org/doc/html/rfc6902#section-4", "enum": [ "test", "remove", @@ -275,11 +275,11 @@ "type": "string" }, "path": { - "description": "Path contains the JSON-pointer value that references a location within the target document where the operation is performed. The meaning of the value depends on the value of Op.", + "description": "Path contains the JSON-pointer value that references a location within the target document where the operation\nis performed. The meaning of the value depends on the value of Op.", "type": "string" }, "value": { - "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into account by all operations.", + "description": "Value contains a valid JSON structure. The meaning of the value depends on the value of Op, and is NOT taken into\naccount by all operations.", "x-kubernetes-preserve-unknown-fields": true } }, @@ -296,19 +296,19 @@ "description": "Target points to the resources that the patch document should be applied to.", "properties": { "annotationSelector": { - "description": "AnnotationSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource annotations.", + "description": "AnnotationSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource annotations.", "type": "string" }, "group": { - "description": "Group is the API group to select resources from. Together with Version and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Group is the API group to select resources from.\nTogether with Version and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "kind": { - "description": "Kind of the API Group to select resources from. Together with Group and Version it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Kind of the API Group to select resources from.\nTogether with Group and Version it is capable of unambiguously\nidentifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" }, "labelSelector": { - "description": "LabelSelector is a string that follows the label selection expression https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api It matches with the resource labels.", + "description": "LabelSelector is a string that follows the label selection expression\nhttps://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#api\nIt matches with the resource labels.", "type": "string" }, "name": { @@ -320,7 +320,7 @@ "type": "string" }, "version": { - "description": "Version of the API Group to select resources from. Together with Group and Kind it is capable of unambiguously identifying and/or selecting resources. https://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", + "description": "Version of the API Group to select resources from.\nTogether with Group and Kind it is capable of unambiguously identifying and/or selecting resources.\nhttps://github.com/kubernetes/community/blob/master/contributors/design-proposals/api-machinery/api-group.md", "type": "string" } }, @@ -338,30 +338,30 @@ "type": "array" }, "patchesStrategicMerge": { - "description": "Strategic merge patches, defined as inline YAML objects. Deprecated: Use Patches instead.", + "description": "Strategic merge patches, defined as inline YAML objects.\nDeprecated: Use Patches instead.", "items": { "x-kubernetes-preserve-unknown-fields": true }, "type": "array" }, "path": { - "description": "Path to the directory containing the kustomization.yaml file, or the set of plain YAMLs a kustomization.yaml should be generated for. Defaults to 'None', which translates to the root path of the SourceRef.", + "description": "Path to the directory containing the kustomization.yaml file, or the\nset of plain YAMLs a kustomization.yaml should be generated for.\nDefaults to 'None', which translates to the root path of the SourceRef.", "type": "string" }, "postBuild": { - "description": "PostBuild describes which actions to perform on the YAML manifest generated by building the kustomize overlay.", + "description": "PostBuild describes which actions to perform on the YAML manifest\ngenerated by building the kustomize overlay.", "properties": { "substitute": { "additionalProperties": { "type": "string" }, - "description": "Substitute holds a map of key/value pairs. The variables defined in your YAML manifests that match any of the keys defined in the map will be substituted with the set value. Includes support for bash string replacement functions e.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", + "description": "Substitute holds a map of key/value pairs.\nThe variables defined in your YAML manifests\nthat match any of the keys defined in the map\nwill be substituted with the set value.\nIncludes support for bash string replacement functions\ne.g. ${var:=default}, ${var:position} and ${var/substring/replacement}.", "type": "object" }, "substituteFrom": { - "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing the variables and their values to be substituted in the YAML manifests. The ConfigMap and the Secret data keys represent the var names and they must match the vars declared in the manifests for the substitution to happen.", + "description": "SubstituteFrom holds references to ConfigMaps and Secrets containing\nthe variables and their values to be substituted in the YAML manifests.\nThe ConfigMap and the Secret data keys represent the var names and they\nmust match the vars declared in the manifests for the substitution to happen.", "items": { - "description": "SubstituteReference contains a reference to a resource containing the variables name and value.", + "description": "SubstituteReference contains a reference to a resource containing\nthe variables name and value.", "properties": { "kind": { "description": "Kind of the values referent, valid values are ('Secret', 'ConfigMap').", @@ -372,14 +372,14 @@ "type": "string" }, "name": { - "description": "Name of the values referent. Should reside in the same namespace as the referring resource.", + "description": "Name of the values referent. Should reside in the same namespace as the\nreferring resource.", "maxLength": 253, "minLength": 1, "type": "string" }, "optional": { "default": false, - "description": "Optional indicates whether the referenced resource must exist, or whether to tolerate its absence. If true and the referenced resource is absent, proceed as if the resource was present but empty, without any variables defined.", + "description": "Optional indicates whether the referenced resource must exist, or whether to\ntolerate its absence. If true and the referenced resource is absent, proceed\nas if the resource was present but empty, without any variables defined.", "type": "boolean" } }, @@ -401,12 +401,12 @@ "type": "boolean" }, "retryInterval": { - "description": "The interval at which to retry a previously failed reconciliation. When not specified, the controller uses the KustomizationSpec.Interval value to retry failures.", + "description": "The interval at which to retry a previously failed reconciliation.\nWhen not specified, the controller uses the KustomizationSpec.Interval\nvalue to retry failures.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "serviceAccountName": { - "description": "The name of the Kubernetes service account to impersonate when reconciling this Kustomization.", + "description": "The name of the Kubernetes service account to impersonate\nwhen reconciling this Kustomization.", "type": "string" }, "sourceRef": { @@ -442,17 +442,17 @@ "additionalProperties": false }, "suspend": { - "description": "This flag tells the controller to suspend subsequent kustomize executions, it does not apply to already started executions. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent kustomize executions,\nit does not apply to already started executions. Defaults to false.", "type": "boolean" }, "targetNamespace": { - "description": "TargetNamespace sets or overrides the namespace in the kustomization.yaml file.", + "description": "TargetNamespace sets or overrides the namespace in the\nkustomization.yaml file.", "maxLength": 63, "minLength": 1, "type": "string" }, "timeout": { - "description": "Timeout for validation, apply and health checking operations. Defaults to 'Interval' duration.", + "description": "Timeout for validation, apply and health checking operations.\nDefaults to 'Interval' duration.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, @@ -466,7 +466,7 @@ "type": "string" }, "wait": { - "description": "Wait instructs the controller to check the health of all the reconciled resources. When enabled, the HealthChecks are ignored. Defaults to false.", + "description": "Wait instructs the controller to check the health of all the reconciled resources.\nWhen enabled, the HealthChecks are ignored. Defaults to false.", "type": "boolean" } }, @@ -486,26 +486,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -521,7 +521,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -548,7 +548,7 @@ "description": "ResourceRef contains the information necessary to locate a resource within a cluster.", "properties": { "id": { - "description": "ID is the string representation of the Kubernetes resource object's metadata, in the format '___'.", + "description": "ID is the string representation of the Kubernetes resource object's metadata,\nin the format '___'.", "type": "string" }, "v": { @@ -573,7 +573,7 @@ "additionalProperties": false }, "lastAppliedRevision": { - "description": "The last successfully applied revision. Equals the Revision of the applied Artifact from the referenced Source.", + "description": "The last successfully applied revision.\nEquals the Revision of the applied Artifact from the referenced Source.", "type": "string" }, "lastAttemptedRevision": { @@ -581,7 +581,7 @@ "type": "string" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { diff --git a/ocirepository-source-v1beta2.json b/ocirepository-source-v1beta2.json index 2bbbcf0..a394a9b 100644 --- a/ocirepository-source-v1beta2.json +++ b/ocirepository-source-v1beta2.json @@ -2,11 +2,11 @@ "description": "OCIRepository is the Schema for the ocirepositories API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,7 +16,7 @@ "description": "OCIRepositorySpec defines the desired state of OCIRepository", "properties": { "certSecretRef": { - "description": "CertSecretRef can be given the name of a Secret containing either or both of \n - a PEM-encoded client certificate (`tls.crt`) and private key (`tls.key`); - a PEM-encoded CA certificate (`ca.crt`) \n and whichever are supplied, will be used for connecting to the registry. The client cert and key are useful if you are authenticating with a certificate; the CA cert is useful if you are using a self-signed server certificate. The Secret must be of type `Opaque` or `kubernetes.io/tls`. \n Note: Support for the `caFile`, `certFile` and `keyFile` keys have been deprecated.", + "description": "CertSecretRef can be given the name of a Secret containing\neither or both of\n\n\n- a PEM-encoded client certificate (`tls.crt`) and private\nkey (`tls.key`);\n- a PEM-encoded CA certificate (`ca.crt`)\n\n\nand whichever are supplied, will be used for connecting to the\nregistry. The client cert and key are useful if you are\nauthenticating with a certificate; the CA cert is useful if\nyou are using a self-signed server certificate. The Secret must\nbe of type `Opaque` or `kubernetes.io/tls`.\n\n\nNote: Support for the `caFile`, `certFile` and `keyFile` keys have\nbeen deprecated.", "properties": { "name": { "description": "Name of the referent.", @@ -30,7 +30,7 @@ "additionalProperties": false }, "ignore": { - "description": "Ignore overrides the set of excluded patterns in the .sourceignore format (which is the same as .gitignore). If not provided, a default will be used, consult the documentation for your version to find out what those are.", + "description": "Ignore overrides the set of excluded patterns in the .sourceignore format\n(which is the same as .gitignore). If not provided, a default will be used,\nconsult the documentation for your version to find out what those are.", "type": "string" }, "insecure": { @@ -38,19 +38,19 @@ "type": "boolean" }, "interval": { - "description": "Interval at which the OCIRepository URL is checked for updates. This interval is approximate and may be subject to jitter to ensure efficient use of resources.", + "description": "Interval at which the OCIRepository URL is checked for updates.\nThis interval is approximate and may be subject to jitter to ensure\nefficient use of resources.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, "layerSelector": { - "description": "LayerSelector specifies which layer should be extracted from the OCI artifact. When not specified, the first layer found in the artifact is selected.", + "description": "LayerSelector specifies which layer should be extracted from the OCI artifact.\nWhen not specified, the first layer found in the artifact is selected.", "properties": { "mediaType": { - "description": "MediaType specifies the OCI media type of the layer which should be extracted from the OCI Artifact. The first layer matching this type is selected.", + "description": "MediaType specifies the OCI media type of the layer\nwhich should be extracted from the OCI Artifact. The\nfirst layer matching this type is selected.", "type": "string" }, "operation": { - "description": "Operation specifies how the selected layer should be processed. By default, the layer compressed content is extracted to storage. When the operation is set to 'copy', the layer compressed content is persisted to storage as it is.", + "description": "Operation specifies how the selected layer should be processed.\nBy default, the layer compressed content is extracted to storage.\nWhen the operation is set to 'copy', the layer compressed content\nis persisted to storage as it is.", "enum": [ "extract", "copy" @@ -63,7 +63,7 @@ }, "provider": { "default": "generic", - "description": "The provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'. When not specified, defaults to 'generic'.", + "description": "The provider used for authentication, can be 'aws', 'azure', 'gcp' or 'generic'.\nWhen not specified, defaults to 'generic'.", "enum": [ "generic", "aws", @@ -73,14 +73,18 @@ "type": "string" }, "ref": { - "description": "The OCI reference to pull and monitor for changes, defaults to the latest tag.", + "description": "The OCI reference to pull and monitor for changes,\ndefaults to the latest tag.", "properties": { "digest": { - "description": "Digest is the image digest to pull, takes precedence over SemVer. The value should be in the format 'sha256:'.", + "description": "Digest is the image digest to pull, takes precedence over SemVer.\nThe value should be in the format 'sha256:'.", "type": "string" }, "semver": { - "description": "SemVer is the range of tags to pull selecting the latest within the range, takes precedence over Tag.", + "description": "SemVer is the range of tags to pull selecting the latest within\nthe range, takes precedence over Tag.", + "type": "string" + }, + "semverFilter": { + "description": "SemverFilter is a regex pattern to filter the tags within the SemVer range.", "type": "string" }, "tag": { @@ -92,7 +96,7 @@ "additionalProperties": false }, "secretRef": { - "description": "SecretRef contains the secret name containing the registry login credentials to resolve image metadata. The secret must be of type kubernetes.io/dockerconfigjson.", + "description": "SecretRef contains the secret name containing the registry login\ncredentials to resolve image metadata.\nThe secret must be of type kubernetes.io/dockerconfigjson.", "properties": { "name": { "description": "Name of the referent.", @@ -106,7 +110,7 @@ "additionalProperties": false }, "serviceAccountName": { - "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate the image pull if the service account has attached pull secrets. For more information: https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/#add-imagepullsecrets-to-a-service-account", + "description": "ServiceAccountName is the name of the Kubernetes ServiceAccount used to authenticate\nthe image pull if the service account has attached pull secrets. For more information:\nhttps://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/#add-imagepullsecrets-to-a-service-account", "type": "string" }, "suspend": { @@ -120,24 +124,24 @@ "type": "string" }, "url": { - "description": "URL is a reference to an OCI artifact repository hosted on a remote container registry.", + "description": "URL is a reference to an OCI artifact repository hosted\non a remote container registry.", "pattern": "^oci://.*$", "type": "string" }, "verify": { - "description": "Verify contains the secret name containing the trusted public keys used to verify the signature and specifies which provider to use to check whether OCI image is authentic.", + "description": "Verify contains the secret name containing the trusted public keys\nused to verify the signature and specifies which provider to use to check\nwhether OCI image is authentic.", "properties": { "matchOIDCIdentity": { - "description": "MatchOIDCIdentity specifies the identity matching criteria to use while verifying an OCI artifact which was signed using Cosign keyless signing. The artifact's identity is deemed to be verified if any of the specified matchers match against the identity.", + "description": "MatchOIDCIdentity specifies the identity matching criteria to use\nwhile verifying an OCI artifact which was signed using Cosign keyless\nsigning. The artifact's identity is deemed to be verified if any of the\nspecified matchers match against the identity.", "items": { - "description": "OIDCIdentityMatch specifies options for verifying the certificate identity, i.e. the issuer and the subject of the certificate.", + "description": "OIDCIdentityMatch specifies options for verifying the certificate identity,\ni.e. the issuer and the subject of the certificate.", "properties": { "issuer": { - "description": "Issuer specifies the regex pattern to match against to verify the OIDC issuer in the Fulcio certificate. The pattern must be a valid Go regular expression.", + "description": "Issuer specifies the regex pattern to match against to verify\nthe OIDC issuer in the Fulcio certificate. The pattern must be a\nvalid Go regular expression.", "type": "string" }, "subject": { - "description": "Subject specifies the regex pattern to match against to verify the identity subject in the Fulcio certificate. The pattern must be a valid Go regular expression.", + "description": "Subject specifies the regex pattern to match against to verify\nthe identity subject in the Fulcio certificate. The pattern must\nbe a valid Go regular expression.", "type": "string" } }, @@ -154,12 +158,13 @@ "default": "cosign", "description": "Provider specifies the technology used to sign the OCI Artifact.", "enum": [ - "cosign" + "cosign", + "notation" ], "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Kubernetes Secret containing the trusted public keys.", + "description": "SecretRef specifies the Kubernetes Secret containing the\ntrusted public keys.", "properties": { "name": { "description": "Name of the referent.", @@ -202,7 +207,7 @@ "type": "string" }, "lastUpdateTime": { - "description": "LastUpdateTime is the timestamp corresponding to the last update of the Artifact.", + "description": "LastUpdateTime is the timestamp corresponding to the last update of the\nArtifact.", "format": "date-time", "type": "string" }, @@ -214,11 +219,11 @@ "type": "object" }, "path": { - "description": "Path is the relative file path of the Artifact. It can be used to locate the file in the root of the Artifact storage on the local file system of the controller managing the Source.", + "description": "Path is the relative file path of the Artifact. It can be used to locate\nthe file in the root of the Artifact storage on the local file system of\nthe controller managing the Source.", "type": "string" }, "revision": { - "description": "Revision is a human-readable identifier traceable in the origin source system. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", + "description": "Revision is a human-readable identifier traceable in the origin source\nsystem. It can be a Git commit SHA, Git tag, a Helm chart version, etc.", "type": "string" }, "size": { @@ -227,7 +232,7 @@ "type": "integer" }, "url": { - "description": "URL is the HTTP address of the Artifact as exposed by the controller managing the Source. It can be used to retrieve the Artifact for consumption, e.g. by another controller applying the Artifact contents.", + "description": "URL is the HTTP address of the Artifact as exposed by the controller\nmanaging the Source. It can be used to retrieve the Artifact for\nconsumption, e.g. by another controller applying the Artifact contents.", "type": "string" } }, @@ -243,26 +248,26 @@ "conditions": { "description": "Conditions holds the conditions for the OCIRepository.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -278,7 +283,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -297,11 +302,11 @@ "type": "array" }, "contentConfigChecksum": { - "description": "ContentConfigChecksum is a checksum of all the configurations related to the content of the source artifact: - .spec.ignore - .spec.layerSelector observed in .status.observedGeneration version of the object. This can be used to determine if the content configuration has changed and the artifact needs to be rebuilt. It has the format of `:`, for example: `sha256:`. \n Deprecated: Replaced with explicit fields for observed artifact content config in the status.", + "description": "ContentConfigChecksum is a checksum of all the configurations related to\nthe content of the source artifact:\n - .spec.ignore\n - .spec.layerSelector\nobserved in .status.observedGeneration version of the object. This can\nbe used to determine if the content configuration has changed and the\nartifact needs to be rebuilt.\nIt has the format of `:`, for example: `sha256:`.\n\n\nDeprecated: Replaced with explicit fields for observed artifact content\nconfig in the status.", "type": "string" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { @@ -310,18 +315,18 @@ "type": "integer" }, "observedIgnore": { - "description": "ObservedIgnore is the observed exclusion patterns used for constructing the source artifact.", + "description": "ObservedIgnore is the observed exclusion patterns used for constructing\nthe source artifact.", "type": "string" }, "observedLayerSelector": { - "description": "ObservedLayerSelector is the observed layer selector used for constructing the source artifact.", + "description": "ObservedLayerSelector is the observed layer selector used for constructing\nthe source artifact.", "properties": { "mediaType": { - "description": "MediaType specifies the OCI media type of the layer which should be extracted from the OCI Artifact. The first layer matching this type is selected.", + "description": "MediaType specifies the OCI media type of the layer\nwhich should be extracted from the OCI Artifact. The\nfirst layer matching this type is selected.", "type": "string" }, "operation": { - "description": "Operation specifies how the selected layer should be processed. By default, the layer compressed content is extracted to storage. When the operation is set to 'copy', the layer compressed content is persisted to storage as it is.", + "description": "Operation specifies how the selected layer should be processed.\nBy default, the layer compressed content is extracted to storage.\nWhen the operation is set to 'copy', the layer compressed content\nis persisted to storage as it is.", "enum": [ "extract", "copy" diff --git a/provider-notification-v1beta1.json b/provider-notification-v1beta1.json index 93a52b1..dc42b18 100644 --- a/provider-notification-v1beta1.json +++ b/provider-notification-v1beta1.json @@ -2,11 +2,11 @@ "description": "Provider is the Schema for the providers API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -21,7 +21,7 @@ "type": "string" }, "certSecretRef": { - "description": "CertSecretRef can be given the name of a secret containing a PEM-encoded CA certificate (`caFile`)", + "description": "CertSecretRef can be given the name of a secret containing\na PEM-encoded CA certificate (`caFile`)", "properties": { "name": { "description": "Name of the referent.", @@ -44,7 +44,7 @@ "type": "string" }, "secretRef": { - "description": "Secret reference containing the provider webhook URL using \"address\" as data key", + "description": "Secret reference containing the provider webhook URL\nusing \"address\" as data key", "properties": { "name": { "description": "Name of the referent.", @@ -58,7 +58,7 @@ "additionalProperties": false }, "suspend": { - "description": "This flag tells the controller to suspend subsequent events handling. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent events handling.\nDefaults to false.", "type": "boolean" }, "timeout": { @@ -112,26 +112,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -147,7 +147,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" diff --git a/provider-notification-v1beta2.json b/provider-notification-v1beta2.json index 983f46a..62e17e6 100644 --- a/provider-notification-v1beta2.json +++ b/provider-notification-v1beta2.json @@ -2,11 +2,11 @@ "description": "Provider is the Schema for the providers API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,12 +16,12 @@ "description": "ProviderSpec defines the desired state of the Provider.", "properties": { "address": { - "description": "Address specifies the endpoint, in a generic sense, to where alerts are sent. What kind of endpoint depends on the specific Provider type being used. For the generic Provider, for example, this is an HTTP/S address. For other Provider types this could be a project ID or a namespace.", + "description": "Address specifies the endpoint, in a generic sense, to where alerts are sent.\nWhat kind of endpoint depends on the specific Provider type being used.\nFor the generic Provider, for example, this is an HTTP/S address.\nFor other Provider types this could be a project ID or a namespace.", "maxLength": 2048, "type": "string" }, "certSecretRef": { - "description": "CertSecretRef specifies the Secret containing a PEM-encoded CA certificate (in the `ca.crt` key). \n Note: Support for the `caFile` key has been deprecated.", + "description": "CertSecretRef specifies the Secret containing\na PEM-encoded CA certificate (in the `ca.crt` key).\n\n\nNote: Support for the `caFile` key has\nbeen deprecated.", "properties": { "name": { "description": "Name of the referent.", @@ -51,7 +51,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Secret containing the authentication credentials for this Provider.", + "description": "SecretRef specifies the Secret containing the authentication\ncredentials for this Provider.", "properties": { "name": { "description": "Name of the referent.", @@ -65,7 +65,7 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend subsequent events handling for this Provider.", + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Provider.", "type": "boolean" }, "timeout": { @@ -126,26 +126,26 @@ "conditions": { "description": "Conditions holds the conditions for the Provider.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -161,7 +161,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -180,7 +180,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { diff --git a/provider-notification-v1beta3.json b/provider-notification-v1beta3.json index d3d01a2..002baea 100644 --- a/provider-notification-v1beta3.json +++ b/provider-notification-v1beta3.json @@ -2,11 +2,11 @@ "description": "Provider is the Schema for the providers API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,12 +16,12 @@ "description": "ProviderSpec defines the desired state of the Provider.", "properties": { "address": { - "description": "Address specifies the endpoint, in a generic sense, to where alerts are sent. What kind of endpoint depends on the specific Provider type being used. For the generic Provider, for example, this is an HTTP/S address. For other Provider types this could be a project ID or a namespace.", + "description": "Address specifies the endpoint, in a generic sense, to where alerts are sent.\nWhat kind of endpoint depends on the specific Provider type being used.\nFor the generic Provider, for example, this is an HTTP/S address.\nFor other Provider types this could be a project ID or a namespace.", "maxLength": 2048, "type": "string" }, "certSecretRef": { - "description": "CertSecretRef specifies the Secret containing a PEM-encoded CA certificate (in the `ca.crt` key). \n Note: Support for the `caFile` key has been deprecated.", + "description": "CertSecretRef specifies the Secret containing\na PEM-encoded CA certificate (in the `ca.crt` key).\n\n\nNote: Support for the `caFile` key has\nbeen deprecated.", "properties": { "name": { "description": "Name of the referent.", @@ -40,7 +40,7 @@ "type": "string" }, "interval": { - "description": "Interval at which to reconcile the Provider with its Secret references. Deprecated and not used in v1beta3.", + "description": "Interval at which to reconcile the Provider with its Secret references.\nDeprecated and not used in v1beta3.", "pattern": "^([0-9]+(\\.[0-9]+)?(ms|s|m|h))+$", "type": "string" }, @@ -51,7 +51,7 @@ "type": "string" }, "secretRef": { - "description": "SecretRef specifies the Secret containing the authentication credentials for this Provider.", + "description": "SecretRef specifies the Secret containing the authentication\ncredentials for this Provider.", "properties": { "name": { "description": "Name of the referent.", @@ -65,7 +65,7 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend subsequent events handling for this Provider.", + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this Provider.", "type": "boolean" }, "timeout": { diff --git a/receiver-notification-v1.json b/receiver-notification-v1.json index eb61b78..1307419 100644 --- a/receiver-notification-v1.json +++ b/receiver-notification-v1.json @@ -2,11 +2,11 @@ "description": "Receiver is the Schema for the receivers API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,7 +16,7 @@ "description": "ReceiverSpec defines the desired state of the Receiver.", "properties": { "events": { - "description": "Events specifies the list of event types to handle, e.g. 'push' for GitHub or 'Push Hook' for GitLab.", + "description": "Events specifies the list of event types to handle,\ne.g. 'push' for GitHub or 'Push Hook' for GitLab.", "items": { "type": "string" }, @@ -31,7 +31,7 @@ "resources": { "description": "A list of resources to be notified about changes.", "items": { - "description": "CrossNamespaceObjectReference contains enough information to let you locate the typed referenced object at cluster level", + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", "properties": { "apiVersion": { "description": "API version of the referent", @@ -57,11 +57,11 @@ "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed. MatchLabels requires the name to be set to `*`.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", "type": "object" }, "name": { - "description": "Name of the referent If multiple resources are targeted `*` may be set.", + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", "maxLength": 53, "minLength": 1, "type": "string" @@ -83,7 +83,7 @@ "type": "array" }, "secretRef": { - "description": "SecretRef specifies the Secret containing the token used to validate the payload authenticity.", + "description": "SecretRef specifies the Secret containing the token used\nto validate the payload authenticity.", "properties": { "name": { "description": "Name of the referent.", @@ -97,11 +97,11 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend subsequent events handling for this receiver.", + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this receiver.", "type": "boolean" }, "type": { - "description": "Type of webhook sender, used to determine the validation procedure and payload deserialization.", + "description": "Type of webhook sender, used to determine\nthe validation procedure and payload deserialization.", "enum": [ "generic", "generic-hmac", @@ -113,7 +113,8 @@ "quay", "gcr", "nexus", - "acr" + "acr", + "cdevents" ], "type": "string" } @@ -135,26 +136,26 @@ "conditions": { "description": "Conditions holds the conditions for the Receiver.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -170,7 +171,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -189,7 +190,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { @@ -198,7 +199,7 @@ "type": "integer" }, "webhookPath": { - "description": "WebhookPath is the generated incoming webhook address in the format of '/hook/sha256sum(token+name+namespace)'.", + "description": "WebhookPath is the generated incoming webhook address in the format\nof '/hook/sha256sum(token+name+namespace)'.", "type": "string" } }, diff --git a/receiver-notification-v1beta1.json b/receiver-notification-v1beta1.json index 693e2bd..801963e 100644 --- a/receiver-notification-v1beta1.json +++ b/receiver-notification-v1beta1.json @@ -2,11 +2,11 @@ "description": "Receiver is the Schema for the receivers API", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,7 +16,7 @@ "description": "ReceiverSpec defines the desired state of Receiver", "properties": { "events": { - "description": "A list of events to handle, e.g. 'push' for GitHub or 'Push Hook' for GitLab.", + "description": "A list of events to handle,\ne.g. 'push' for GitHub or 'Push Hook' for GitLab.", "items": { "type": "string" }, @@ -25,7 +25,7 @@ "resources": { "description": "A list of resources to be notified about changes.", "items": { - "description": "CrossNamespaceObjectReference contains enough information to let you locate the typed referenced object at cluster level", + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", "properties": { "apiVersion": { "description": "API version of the referent", @@ -51,7 +51,7 @@ "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.", "type": "object" }, "name": { @@ -76,7 +76,7 @@ "type": "array" }, "secretRef": { - "description": "Secret reference containing the token used to validate the payload authenticity", + "description": "Secret reference containing the token used\nto validate the payload authenticity", "properties": { "name": { "description": "Name of the referent.", @@ -90,11 +90,11 @@ "additionalProperties": false }, "suspend": { - "description": "This flag tells the controller to suspend subsequent events handling. Defaults to false.", + "description": "This flag tells the controller to suspend subsequent events handling.\nDefaults to false.", "type": "boolean" }, "type": { - "description": "Type of webhook sender, used to determine the validation procedure and payload deserialization.", + "description": "Type of webhook sender, used to determine\nthe validation procedure and payload deserialization.", "enum": [ "generic", "generic-hmac", @@ -126,26 +126,26 @@ "properties": { "conditions": { "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -161,7 +161,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -185,7 +185,7 @@ "type": "integer" }, "url": { - "description": "Generated webhook URL in the format of '/hook/sha256sum(token+name+namespace)'.", + "description": "Generated webhook URL in the format\nof '/hook/sha256sum(token+name+namespace)'.", "type": "string" } }, diff --git a/receiver-notification-v1beta2.json b/receiver-notification-v1beta2.json index 9a9c5d5..7a84b0f 100644 --- a/receiver-notification-v1beta2.json +++ b/receiver-notification-v1beta2.json @@ -2,11 +2,11 @@ "description": "Receiver is the Schema for the receivers API.", "properties": { "apiVersion": { - "description": "APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", + "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources", "type": "string" }, "kind": { - "description": "Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", + "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds", "type": "string" }, "metadata": { @@ -16,7 +16,7 @@ "description": "ReceiverSpec defines the desired state of the Receiver.", "properties": { "events": { - "description": "Events specifies the list of event types to handle, e.g. 'push' for GitHub or 'Push Hook' for GitLab.", + "description": "Events specifies the list of event types to handle,\ne.g. 'push' for GitHub or 'Push Hook' for GitLab.", "items": { "type": "string" }, @@ -30,7 +30,7 @@ "resources": { "description": "A list of resources to be notified about changes.", "items": { - "description": "CrossNamespaceObjectReference contains enough information to let you locate the typed referenced object at cluster level", + "description": "CrossNamespaceObjectReference contains enough information to let you locate the\ntyped referenced object at cluster level", "properties": { "apiVersion": { "description": "API version of the referent", @@ -56,11 +56,11 @@ "additionalProperties": { "type": "string" }, - "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed. MatchLabels requires the name to be set to `*`.", + "description": "MatchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.\nMatchLabels requires the name to be set to `*`.", "type": "object" }, "name": { - "description": "Name of the referent If multiple resources are targeted `*` may be set.", + "description": "Name of the referent\nIf multiple resources are targeted `*` may be set.", "maxLength": 53, "minLength": 1, "type": "string" @@ -82,7 +82,7 @@ "type": "array" }, "secretRef": { - "description": "SecretRef specifies the Secret containing the token used to validate the payload authenticity.", + "description": "SecretRef specifies the Secret containing the token used\nto validate the payload authenticity.", "properties": { "name": { "description": "Name of the referent.", @@ -96,11 +96,11 @@ "additionalProperties": false }, "suspend": { - "description": "Suspend tells the controller to suspend subsequent events handling for this receiver.", + "description": "Suspend tells the controller to suspend subsequent\nevents handling for this receiver.", "type": "boolean" }, "type": { - "description": "Type of webhook sender, used to determine the validation procedure and payload deserialization.", + "description": "Type of webhook sender, used to determine\nthe validation procedure and payload deserialization.", "enum": [ "generic", "generic-hmac", @@ -133,26 +133,26 @@ "conditions": { "description": "Conditions holds the conditions for the Receiver.", "items": { - "description": "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }", + "description": "Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions. For example,\n\n\n\ttype FooStatus struct{\n\t // Represents the observations of a foo's current state.\n\t // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t // other fields\n\t}", "properties": { "lastTransitionTime": { - "description": "lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", + "description": "lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.", "format": "date-time", "type": "string" }, "message": { - "description": "message is a human readable message indicating details about the transition. This may be an empty string.", + "description": "message is a human readable message indicating details about the transition.\nThis may be an empty string.", "maxLength": 32768, "type": "string" }, "observedGeneration": { - "description": "observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.", + "description": "observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.", "format": "int64", "minimum": 0, "type": "integer" }, "reason": { - "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.", + "description": "reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.", "maxLength": 1024, "minLength": 1, "pattern": "^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$", @@ -168,7 +168,7 @@ "type": "string" }, "type": { - "description": "type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", + "description": "type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)", "maxLength": 316, "pattern": "^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$", "type": "string" @@ -187,7 +187,7 @@ "type": "array" }, "lastHandledReconcileAt": { - "description": "LastHandledReconcileAt holds the value of the most recent reconcile request value, so a change of the annotation value can be detected.", + "description": "LastHandledReconcileAt holds the value of the most recent\nreconcile request value, so a change of the annotation value\ncan be detected.", "type": "string" }, "observedGeneration": { @@ -196,11 +196,11 @@ "type": "integer" }, "url": { - "description": "URL is the generated incoming webhook address in the format of '/hook/sha256sum(token+name+namespace)'. Deprecated: Replaced by WebhookPath.", + "description": "URL is the generated incoming webhook address in the format\nof '/hook/sha256sum(token+name+namespace)'.\nDeprecated: Replaced by WebhookPath.", "type": "string" }, "webhookPath": { - "description": "WebhookPath is the generated incoming webhook address in the format of '/hook/sha256sum(token+name+namespace)'.", + "description": "WebhookPath is the generated incoming webhook address in the format\nof '/hook/sha256sum(token+name+namespace)'.", "type": "string" } },