From d007be9ce4a3b6781c084b656d98ccb7e7ba635e Mon Sep 17 00:00:00 2001 From: Adam Dyess Date: Wed, 31 Jul 2024 08:44:33 -0500 Subject: [PATCH] Provide charm config to set the cinder-csi storage class as the default --- config.yaml | 10 +++++++++- src/storage_manifests.py | 6 +++++- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/config.yaml b/config.yaml index 753708d..2683ff8 100644 --- a/config.yaml +++ b/config.yaml @@ -54,4 +54,12 @@ options: through to the parameters.reclaimPolicy field of the csi-cinder-default StorageClass. - Potential values are "Delete" or "Retain" \ No newline at end of file + Potential values are "Delete" or "Retain" + + storage-class-default: + type: boolean + default: False + description: | + https://kubernetes.io/docs/tasks/administer-cluster/change-default-storage-class/ + + Whether to set the storage class for the Cinder CSI driver as the cluster default diff --git a/src/storage_manifests.py b/src/storage_manifests.py index 3853a7e..ae0aec1 100644 --- a/src/storage_manifests.py +++ b/src/storage_manifests.py @@ -57,12 +57,16 @@ def __call__(self) -> Optional[AnyResource]: storage_name = STORAGE_CLASS_NAME.format(type=self.type) log.info(f"Creating storage class {storage_name}") reclaim_policy: str = self.manifests.config.get("reclaim-policy") or "Delete" + is_default: str = "true" if self.manifests.config.get("storage-class-default") else "false" sc = from_dict( dict( apiVersion="storage.k8s.io/v1", kind="StorageClass", - metadata=dict(name=storage_name), + metadata=dict( + name=storage_name, + annotations={"storageclass.kubernetes.io/is-default-class": is_default}, + ), provisioner="cinder.csi.openstack.org", reclaimPolicy=reclaim_policy.title(), volumeBindingMode="WaitForFirstConsumer",