Skip to content

Commit

Permalink
crds: genrate crds for vr and vrc
Browse files Browse the repository at this point in the history
This commit generates the volumereplication
and volumereplicationclass crds using the
make manifest and updates the deepcopy using
make generate.
The genrated files are stored in api/v1aplha1/
This is the part of moving volume replication operator
to kubernetes-csi-addons repo.
https://github.com/csi-addons/volume-replication-operator

Updates: csi-addons#116

Signed-off-by: yati1998 <ypadia@redhat.com>
  • Loading branch information
yati1998 committed Jul 29, 2022
1 parent f1021d3 commit fcb30c5
Show file tree
Hide file tree
Showing 8 changed files with 311 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
---
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.9.1
creationTimestamp: null
name: volumereplicationclasses.replication.storage.openshift.io
spec:
group: replication.storage.openshift.io
names:
kind: VolumeReplicationClass
listKind: VolumeReplicationClassList
plural: volumereplicationclasses
shortNames:
- vrc
singular: volumereplicationclass
scope: Cluster
versions:
- additionalPrinterColumns:
- jsonPath: .spec.provisioner
name: provisioner
type: string
name: v1alpha1
schema:
openAPIV3Schema:
description: VolumeReplicationClass is the Schema for the volumereplicationclasses
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'
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'
type: string
metadata:
type: object
spec:
description: VolumeReplicationClassSpec specifies parameters that an underlying
storage system uses when creating a volume replica. A specific VolumeReplicationClass
is used by specifying its name in a VolumeReplication object.
properties:
parameters:
additionalProperties:
type: string
description: Parameters is a key-value map with storage provisioner
specific configurations for creating volume replicas
type: object
provisioner:
description: Provisioner is the name of storage provisioner
type: string
required:
- provisioner
type: object
status:
description: VolumeReplicationClassStatus defines the observed state of
VolumeReplicationClass.
type: object
type: object
served: true
storage: true
subresources:
status: {}
Original file line number Diff line number Diff line change
@@ -0,0 +1,186 @@
---
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.9.1
creationTimestamp: null
name: volumereplications.replication.storage.openshift.io
spec:
group: replication.storage.openshift.io
names:
kind: VolumeReplication
listKind: VolumeReplicationList
plural: volumereplications
shortNames:
- vr
singular: volumereplication
scope: Namespaced
versions:
- additionalPrinterColumns:
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
- jsonPath: .spec.volumeReplicationClass
name: volumeReplicationClass
type: string
- jsonPath: .spec.dataSource.name
name: pvcName
type: string
- jsonPath: .spec.replicationState
name: desiredState
type: string
- jsonPath: .status.state
name: currentState
type: string
name: v1alpha1
schema:
openAPIV3Schema:
description: VolumeReplication is the Schema for the volumereplications 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'
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'
type: string
metadata:
type: object
spec:
description: VolumeReplicationSpec defines the desired state of VolumeReplication.
properties:
autoResync:
description: AutoResync represents the volume to be auto resynced
when ReplicationState is "secondary"
type: boolean
dataSource:
description: DataSource represents the object associated with the
volume
properties:
apiGroup:
description: APIGroup is the group for the resource being referenced.
If APIGroup is not specified, the specified Kind must be in
the core API group. For any other third-party types, APIGroup
is required.
type: string
kind:
description: Kind is the type of resource being referenced
type: string
name:
description: Name is the name of resource being referenced
type: string
required:
- apiGroup
- kind
- name
type: object
replicationHandle:
description: replicationHandle represents an existing (but new) replication
id
type: string
replicationState:
description: ReplicationState represents the replication operation
to be performed on the volume. Supported operations are "primary",
"secondary" and "resync"
enum:
- primary
- secondary
- resync
type: string
volumeReplicationClass:
description: VolumeReplicationClass is the VolumeReplicationClass
name for this VolumeReplication resource
type: string
required:
- autoResync
- dataSource
- replicationState
- volumeReplicationClass
type: object
status:
description: VolumeReplicationStatus defines the observed state of VolumeReplication.
properties:
conditions:
description: Conditions are the list of conditions and their status.
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,
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 }"
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.
format: date-time
type: string
message:
description: message is a human readable message indicating
details about the transition. This may be an empty string.
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.
format: int64
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.
type: string
status:
description: status of the condition, one of True, False, Unknown.
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)
type: string
required:
- lastTransitionTime
- message
- reason
- status
- type
type: object
type: array
lastCompletionTime:
format: date-time
type: string
lastStartTime:
format: date-time
type: string
message:
type: string
observedGeneration:
description: observedGeneration is the last generation change the
operator has dealt with
format: int64
type: integer
state:
description: State captures the latest state of the replication operation.
type: string
type: object
type: object
served: true
storage: true
subresources:
status: {}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# The following patch adds a directive for certmanager to inject CA into the CRD
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
cert-manager.io/inject-ca-from: $(CERTIFICATE_NAMESPACE)/$(CERTIFICATE_NAME)
name: volumereplicationclasses.replication.storage.openshift.io
7 changes: 7 additions & 0 deletions config/crd/patches/cainjection_in_volumereplications.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# The following patch adds a directive for certmanager to inject CA into the CRD
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
cert-manager.io/inject-ca-from: $(CERTIFICATE_NAMESPACE)/$(CERTIFICATE_NAME)
name: volumereplications.replication.storage.openshift.io
16 changes: 16 additions & 0 deletions config/crd/patches/webhook_in_volumereplicationclasses.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
# The following patch enables a conversion webhook for the CRD
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
name: volumereplicationclasses.replication.storage.openshift.io
spec:
conversion:
strategy: Webhook
webhook:
clientConfig:
service:
namespace: system
name: webhook-service
path: /convert
conversionReviewVersions:
- v1
16 changes: 16 additions & 0 deletions config/crd/patches/webhook_in_volumereplications.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
# The following patch enables a conversion webhook for the CRD
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
name: volumereplications.replication.storage.openshift.io
spec:
conversion:
strategy: Webhook
webhook:
clientConfig:
service:
namespace: system
name: webhook-service
path: /convert
conversionReviewVersions:
- v1
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
apiVersion: replication.storage.openshift.io/v1alpha1
kind: VolumeReplication
metadata:
name: volumereplication-sample
spec:
# TODO(user): Add fields here
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
apiVersion: replication.storage.openshift.io/v1alpha1
kind: VolumeReplicationClass
metadata:
name: volumereplicationclass-sample
spec:
# TODO(user): Add fields here

0 comments on commit fcb30c5

Please sign in to comment.