From c365c8e9f8c9ac64d536f41c6c8aaeb16ee0f6b9 Mon Sep 17 00:00:00 2001 From: andyzhangx Date: Fri, 17 Jan 2025 13:15:30 +0000 Subject: [PATCH] doc: update new chart versions --- README.md | 3 +- charts/README.md | 2 +- charts/index.yaml | 129 +-- .../azurefile-csi-driver-v1.29.10.tgz | Bin 0 -> 13385 bytes .../v1.29.10/azurefile-csi-driver/Chart.yaml | 5 + .../azurefile-csi-driver/templates/NOTES.txt | 5 + .../templates/_helpers.tpl | 49 + .../templates/crd-csi-snapshot.yaml | 840 ++++++++++++++++++ .../templates/csi-azurefile-controller.yaml | 252 ++++++ .../templates/csi-azurefile-driver.yaml | 19 + ...si-azurefile-node-windows-hostprocess.yaml | 164 ++++ .../templates/csi-azurefile-node-windows.yaml | 229 +++++ .../templates/csi-azurefile-node.yaml | 224 +++++ .../templates/csi-snapshot-controller.yaml | 78 ++ .../rbac-csi-azurefile-controller.yaml | 207 +++++ .../templates/rbac-csi-azurefile-node.yaml | 29 + .../rbac-csi-snapshot-controller.yaml | 80 ++ ...rviceaccount-csi-azurefile-controller.yaml | 17 + .../serviceaccount-csi-azurefile-node.yaml | 17 + ...erviceaccount-csi-snapshot-controller.yaml | 9 + .../v1.29.10/azurefile-csi-driver/values.yaml | 265 ++++++ .../v1.30.7/azurefile-csi-driver-v1.30.7.tgz | Bin 0 -> 13848 bytes .../v1.30.7/azurefile-csi-driver/Chart.yaml | 5 + .../azurefile-csi-driver/templates/NOTES.txt | 5 + .../templates/_helpers.tpl | 49 + .../templates/crd-csi-snapshot.yaml | 840 ++++++++++++++++++ .../templates/csi-azurefile-controller.yaml | 272 ++++++ .../templates/csi-azurefile-driver.yaml | 19 + ...si-azurefile-node-windows-hostprocess.yaml | 164 ++++ .../templates/csi-azurefile-node-windows.yaml | 229 +++++ .../templates/csi-azurefile-node.yaml | 224 +++++ .../templates/csi-snapshot-controller.yaml | 95 ++ .../rbac-csi-azurefile-controller.yaml | 207 +++++ .../templates/rbac-csi-azurefile-node.yaml | 29 + .../rbac-csi-snapshot-controller.yaml | 80 ++ ...rviceaccount-csi-azurefile-controller.yaml | 17 + .../serviceaccount-csi-azurefile-node.yaml | 17 + ...erviceaccount-csi-snapshot-controller.yaml | 9 + .../v1.30.7/azurefile-csi-driver/values.yaml | 262 ++++++ .../v1.31.2/azurefile-csi-driver-1.31.2.tgz | Bin 0 -> 14005 bytes .../v1.31.2/azurefile-csi-driver/Chart.yaml | 5 + .../azurefile-csi-driver/templates/NOTES.txt | 5 + .../templates/_helpers.tpl | 49 + .../templates/crd-csi-snapshot.yaml | 840 ++++++++++++++++++ .../templates/csi-azurefile-controller.yaml | 279 ++++++ .../templates/csi-azurefile-driver.yaml | 19 + ...si-azurefile-node-windows-hostprocess.yaml | 164 ++++ .../templates/csi-azurefile-node-windows.yaml | 229 +++++ .../templates/csi-azurefile-node.yaml | 227 +++++ .../templates/csi-snapshot-controller.yaml | 98 ++ .../rbac-csi-azurefile-controller.yaml | 207 +++++ .../templates/rbac-csi-azurefile-node.yaml | 61 ++ .../rbac-csi-snapshot-controller.yaml | 80 ++ ...rviceaccount-csi-azurefile-controller.yaml | 17 + .../serviceaccount-csi-azurefile-node.yaml | 17 + ...erviceaccount-csi-snapshot-controller.yaml | 9 + .../v1.31.2/azurefile-csi-driver/values.yaml | 263 ++++++ deploy/v1.29.10/crd-csi-snapshot.yaml | 838 +++++++++++++++++ deploy/v1.29.10/csi-azurefile-controller.yaml | 184 ++++ deploy/v1.29.10/csi-azurefile-driver.yaml | 15 + ...si-azurefile-node-windows-hostprocess.yaml | 122 +++ .../v1.29.10/csi-azurefile-node-windows.yaml | 187 ++++ deploy/v1.29.10/csi-azurefile-node.yaml | 160 ++++ deploy/v1.29.10/csi-snapshot-controller.yaml | 59 ++ .../rbac-csi-azurefile-controller.yaml | 194 ++++ deploy/v1.29.10/rbac-csi-azurefile-node.yaml | 30 + .../rbac-csi-snapshot-controller.yaml | 78 ++ deploy/v1.30.7/crd-csi-snapshot.yaml | 838 +++++++++++++++++ deploy/v1.30.7/csi-azurefile-controller.yaml | 191 ++++ deploy/v1.30.7/csi-azurefile-driver.yaml | 15 + ...si-azurefile-node-windows-hostprocess.yaml | 122 +++ .../v1.30.7/csi-azurefile-node-windows.yaml | 187 ++++ deploy/v1.30.7/csi-azurefile-node.yaml | 160 ++++ deploy/v1.30.7/csi-snapshot-controller.yaml | 59 ++ .../rbac-csi-azurefile-controller.yaml | 194 ++++ deploy/v1.30.7/rbac-csi-azurefile-node.yaml | 30 + .../v1.30.7/rbac-csi-snapshot-controller.yaml | 78 ++ deploy/v1.31.2/crd-csi-snapshot.yaml | 838 +++++++++++++++++ deploy/v1.31.2/csi-azurefile-controller.yaml | 194 ++++ deploy/v1.31.2/csi-azurefile-driver.yaml | 17 + ...si-azurefile-node-windows-hostprocess.yaml | 122 +++ .../v1.31.2/csi-azurefile-node-windows.yaml | 187 ++++ deploy/v1.31.2/csi-azurefile-node.yaml | 167 ++++ deploy/v1.31.2/csi-snapshot-controller.yaml | 62 ++ .../rbac-csi-azurefile-controller.yaml | 195 ++++ deploy/v1.31.2/rbac-csi-azurefile-node.yaml | 56 ++ .../v1.31.2/rbac-csi-snapshot-controller.yaml | 78 ++ docs/install-azurefile-csi-driver.md | 2 +- docs/install-csi-driver-v1.29.10.md | 45 + docs/install-csi-driver-v1.30.7.md | 45 + docs/install-csi-driver-v1.31.2.md | 45 + 91 files changed, 13454 insertions(+), 55 deletions(-) create mode 100644 charts/v1.29.10/azurefile-csi-driver-v1.29.10.tgz create mode 100644 charts/v1.29.10/azurefile-csi-driver/Chart.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/NOTES.txt create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/_helpers.tpl create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/crd-csi-snapshot.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/csi-azurefile-controller.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/csi-azurefile-driver.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/csi-azurefile-node-windows-hostprocess.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/csi-azurefile-node-windows.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/csi-azurefile-node.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/csi-snapshot-controller.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/rbac-csi-azurefile-controller.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/rbac-csi-azurefile-node.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/rbac-csi-snapshot-controller.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-controller.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-node.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/templates/serviceaccount-csi-snapshot-controller.yaml create mode 100644 charts/v1.29.10/azurefile-csi-driver/values.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver-v1.30.7.tgz create mode 100644 charts/v1.30.7/azurefile-csi-driver/Chart.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/NOTES.txt create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/_helpers.tpl create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/crd-csi-snapshot.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-controller.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-driver.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows-hostprocess.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/csi-snapshot-controller.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-controller.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-node.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-snapshot-controller.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-controller.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-node.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-snapshot-controller.yaml create mode 100644 charts/v1.30.7/azurefile-csi-driver/values.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver-1.31.2.tgz create mode 100644 charts/v1.31.2/azurefile-csi-driver/Chart.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/NOTES.txt create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/_helpers.tpl create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/crd-csi-snapshot.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/csi-azurefile-controller.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/csi-azurefile-driver.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/csi-azurefile-node-windows-hostprocess.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/csi-azurefile-node-windows.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/csi-azurefile-node.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/csi-snapshot-controller.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/rbac-csi-azurefile-controller.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/rbac-csi-azurefile-node.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/rbac-csi-snapshot-controller.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-controller.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-node.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/templates/serviceaccount-csi-snapshot-controller.yaml create mode 100644 charts/v1.31.2/azurefile-csi-driver/values.yaml create mode 100644 deploy/v1.29.10/crd-csi-snapshot.yaml create mode 100644 deploy/v1.29.10/csi-azurefile-controller.yaml create mode 100644 deploy/v1.29.10/csi-azurefile-driver.yaml create mode 100644 deploy/v1.29.10/csi-azurefile-node-windows-hostprocess.yaml create mode 100644 deploy/v1.29.10/csi-azurefile-node-windows.yaml create mode 100644 deploy/v1.29.10/csi-azurefile-node.yaml create mode 100644 deploy/v1.29.10/csi-snapshot-controller.yaml create mode 100644 deploy/v1.29.10/rbac-csi-azurefile-controller.yaml create mode 100644 deploy/v1.29.10/rbac-csi-azurefile-node.yaml create mode 100644 deploy/v1.29.10/rbac-csi-snapshot-controller.yaml create mode 100644 deploy/v1.30.7/crd-csi-snapshot.yaml create mode 100644 deploy/v1.30.7/csi-azurefile-controller.yaml create mode 100644 deploy/v1.30.7/csi-azurefile-driver.yaml create mode 100644 deploy/v1.30.7/csi-azurefile-node-windows-hostprocess.yaml create mode 100644 deploy/v1.30.7/csi-azurefile-node-windows.yaml create mode 100644 deploy/v1.30.7/csi-azurefile-node.yaml create mode 100644 deploy/v1.30.7/csi-snapshot-controller.yaml create mode 100644 deploy/v1.30.7/rbac-csi-azurefile-controller.yaml create mode 100644 deploy/v1.30.7/rbac-csi-azurefile-node.yaml create mode 100644 deploy/v1.30.7/rbac-csi-snapshot-controller.yaml create mode 100644 deploy/v1.31.2/crd-csi-snapshot.yaml create mode 100644 deploy/v1.31.2/csi-azurefile-controller.yaml create mode 100644 deploy/v1.31.2/csi-azurefile-driver.yaml create mode 100644 deploy/v1.31.2/csi-azurefile-node-windows-hostprocess.yaml create mode 100644 deploy/v1.31.2/csi-azurefile-node-windows.yaml create mode 100644 deploy/v1.31.2/csi-azurefile-node.yaml create mode 100644 deploy/v1.31.2/csi-snapshot-controller.yaml create mode 100644 deploy/v1.31.2/rbac-csi-azurefile-controller.yaml create mode 100644 deploy/v1.31.2/rbac-csi-azurefile-node.yaml create mode 100644 deploy/v1.31.2/rbac-csi-snapshot-controller.yaml create mode 100644 docs/install-csi-driver-v1.29.10.md create mode 100644 docs/install-csi-driver-v1.30.7.md create mode 100644 docs/install-csi-driver-v1.31.2.md diff --git a/README.md b/README.md index e1771f4299..81c0c683f9 100644 --- a/README.md +++ b/README.md @@ -17,10 +17,9 @@ Disclaimer: Deploying this driver manually is not an officially supported Micros |Driver Version |Image | supported k8s version | |----------------|---------------------------------------------------------- |-----------------------| |master branch |mcr.microsoft.com/k8s/csi/azurefile-csi:latest | 1.21+ | -|v1.31.0 |mcr.microsoft.com/oss/kubernetes-csi/azurefile-csi:v1.31.0 | 1.21+ | +|v1.31.2 |mcr.microsoft.com/oss/kubernetes-csi/azurefile-csi:v1.31.2 | 1.21+ | |v1.30.6 |mcr.microsoft.com/oss/kubernetes-csi/azurefile-csi:v1.30.6 | 1.21+ | |v1.29.9 |mcr.microsoft.com/oss/kubernetes-csi/azurefile-csi:v1.29.9 | 1.21+ | -|v1.28.13 |mcr.microsoft.com/oss/kubernetes-csi/azurefile-csi:v1.28.13 | 1.21+ | ### Driver parameters Please refer to [driver parameters](./docs/driver-parameters.md) diff --git a/charts/README.md b/charts/README.md index 21c0d02139..1d3d0ba0ed 100644 --- a/charts/README.md +++ b/charts/README.md @@ -16,7 +16,7 @@ ### install a specific version ```console helm repo add azurefile-csi-driver https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts -helm install azurefile-csi-driver azurefile-csi-driver/azurefile-csi-driver --namespace kube-system --version v1.31.0 +helm install azurefile-csi-driver azurefile-csi-driver/azurefile-csi-driver --namespace kube-system --version v1.31.2 ``` ### install on RedHat/CentOS diff --git a/charts/index.yaml b/charts/index.yaml index c6c92ba89f..8c02401b56 100644 --- a/charts/index.yaml +++ b/charts/index.yaml @@ -1,27 +1,45 @@ apiVersion: v1 entries: azurefile-csi-driver: + - apiVersion: v1 + appVersion: 1.31.2 + created: "2025-01-17T13:14:47.281453571Z" + description: Azure File Container Storage Interface (CSI) Storage Plugin + digest: f6b1e1a8193729c7115a3544ce2c7b6123a63350616d7a5f5fb9313f17500092 + name: azurefile-csi-driver + urls: + - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/v1.31.2/azurefile-csi-driver-1.31.2.tgz + version: 1.31.2 - apiVersion: v1 appVersion: 1.31.0 - created: "2024-10-15T13:19:44.77077894Z" + created: "2025-01-17T13:14:47.280275964Z" description: Azure File Container Storage Interface (CSI) Storage Plugin - digest: da5e0d5677abc3e0f334ceaf5674cb82ddf644d126b3fcf6ed0032c85a78921f + digest: 1c845c70fce56ee90b3ce9e043de581eda35d9daaa700adb6cd458af02bd0301 name: azurefile-csi-driver urls: - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/v1.31.0/azurefile-csi-driver-1.31.0.tgz version: 1.31.0 + - apiVersion: v1 + appVersion: v1.30.7 + created: "2025-01-17T13:14:47.27887689Z" + description: Azure File Container Storage Interface (CSI) Storage Plugin + digest: 2034bb28c298847c412bd7fbf7850929e2b5a4b9a011726e373a7eabf325b57f + name: azurefile-csi-driver + urls: + - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/v1.30.7/azurefile-csi-driver-v1.30.7.tgz + version: v1.30.7 - apiVersion: v1 appVersion: v1.30.6 - created: "2024-10-15T13:19:44.769698739Z" + created: "2025-01-17T13:14:47.276731901Z" description: Azure File Container Storage Interface (CSI) Storage Plugin - digest: 2e3a947a66ae6d512919c86ebcef34361bc667d6bb37f7fc873415600b30e8a7 + digest: 1ebab292295056e48cc848d45a48a6715ee4b1bcb0de6c31ff3fbe028ecc1159 name: azurefile-csi-driver urls: - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/v1.30.6/azurefile-csi-driver-v1.30.6.tgz version: v1.30.6 - apiVersion: v1 appVersion: v1.30.5 - created: "2024-10-15T13:19:44.768574141Z" + created: "2025-01-17T13:14:47.275654949Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 6b3692dac69d38c069f3ad271d4a72db47e99c78b3881644fe970aa3978a29f3 name: azurefile-csi-driver @@ -30,7 +48,7 @@ entries: version: v1.30.5 - apiVersion: v1 appVersion: v1.30.4 - created: "2024-10-15T13:19:44.767531404Z" + created: "2025-01-17T13:14:47.274571834Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: cc928f9a3704d37838a04e2691714ad97000b8985db1c02be48e30071a94cd3a name: azurefile-csi-driver @@ -39,7 +57,7 @@ entries: version: v1.30.4 - apiVersion: v1 appVersion: v1.30.2 - created: "2024-10-15T13:19:44.766441162Z" + created: "2025-01-17T13:14:47.273491316Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: fc059dd694e8cb922cf7e4c073fe7c6a0beec54cef22a1e2b089280b3957e0eb name: azurefile-csi-driver @@ -48,7 +66,7 @@ entries: version: v1.30.2 - apiVersion: v1 appVersion: v1.30.1 - created: "2024-10-15T13:19:44.764546743Z" + created: "2025-01-17T13:14:47.272354041Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 4311cb88212ad1341e2d4bd470aaab03c8cd8397ad9be20177814d3a69bfdd9b name: azurefile-csi-driver @@ -57,25 +75,34 @@ entries: version: v1.30.1 - apiVersion: v1 appVersion: v1.30.0 - created: "2024-10-15T13:19:44.763455021Z" + created: "2025-01-17T13:14:47.271224206Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 57e4c1185b8941ff9285588791a5d8897883da7fab69f0dd21fadc97bd7553db name: azurefile-csi-driver urls: - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/v1.30.0/azurefile-csi-driver-v1.30.0.tgz version: v1.30.0 + - apiVersion: v1 + appVersion: v1.29.10 + created: "2025-01-17T13:14:47.26332518Z" + description: Azure File Container Storage Interface (CSI) Storage Plugin + digest: fac12cd7a4b1142e50d83112bdf659e5f1dacb0862bebc3b7cd9c0e54ef0c386 + name: azurefile-csi-driver + urls: + - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/v1.29.10/azurefile-csi-driver-v1.29.10.tgz + version: v1.29.10 - apiVersion: v1 appVersion: v1.29.9 - created: "2024-10-15T13:19:44.762403954Z" + created: "2025-01-17T13:14:47.269249594Z" description: Azure File Container Storage Interface (CSI) Storage Plugin - digest: 13be7bcd3fb77b1e539c85668064841de355a268e854263fcf6d4ff16f70b942 + digest: 3103431483cf832076ae3d67d2cf02640ed50b134c2c8d2cc6ba62bdd52613bf name: azurefile-csi-driver urls: - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/v1.29.9/azurefile-csi-driver-v1.29.9.tgz version: v1.29.9 - apiVersion: v1 appVersion: v1.29.7 - created: "2024-10-15T13:19:44.761322085Z" + created: "2025-01-17T13:14:47.268117957Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: d31aba313d13f53e90ad41ccbc65ff4d95c957dd22672d634a98c2a2998dc5e9 name: azurefile-csi-driver @@ -84,7 +111,7 @@ entries: version: v1.29.7 - apiVersion: v1 appVersion: v1.29.5 - created: "2024-10-15T13:19:44.760193886Z" + created: "2025-01-17T13:14:47.26703Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: e243170530c27b63b7091543b94ce197eeebbe9f5b1b1075f64af73cd69a43ce name: azurefile-csi-driver @@ -93,7 +120,7 @@ entries: version: v1.29.5 - apiVersion: v1 appVersion: v1.29.4 - created: "2024-10-15T13:19:44.758072806Z" + created: "2025-01-17T13:14:47.265898691Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 16ff777186fc090d80a73551bbe2690a81c4b37a8a64b53e21e58cb9a2ea4570 name: azurefile-csi-driver @@ -102,7 +129,7 @@ entries: version: v1.29.4 - apiVersion: v1 appVersion: v1.29.2 - created: "2024-10-15T13:19:44.756964044Z" + created: "2025-01-17T13:14:47.264775064Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 37d89c48dda1666fa0a73a4b038b0f0da7f291b4b07abac47a6ccecda11464b3 name: azurefile-csi-driver @@ -111,7 +138,7 @@ entries: version: v1.29.2 - apiVersion: v1 appVersion: v1.29.1 - created: "2024-10-15T13:19:44.755870723Z" + created: "2025-01-17T13:14:47.261336878Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 5f1060cf8d7cd81dcde897f7c0ef83908e49145a2af84a3615c8faf4a1cea007 name: azurefile-csi-driver @@ -120,7 +147,7 @@ entries: version: v1.29.1 - apiVersion: v1 appVersion: v1.29.0 - created: "2024-10-15T13:19:44.754778522Z" + created: "2025-01-17T13:14:47.26018477Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 2da242b471ff0eaf6ea3f1a9d2c1f6aaa1b78c8cbb4e850bbefb336e043b8098 name: azurefile-csi-driver @@ -129,7 +156,7 @@ entries: version: v1.29.0 - apiVersion: v1 appVersion: v1.28.13 - created: "2024-10-15T13:19:44.746670281Z" + created: "2025-01-17T13:14:47.251841031Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: dd78057674cbbc119201f820f4a168cbac0a2663e8acba827d66247b9b456e5a name: azurefile-csi-driver @@ -138,7 +165,7 @@ entries: version: v1.28.13 - apiVersion: v1 appVersion: v1.28.12 - created: "2024-10-15T13:19:44.744416204Z" + created: "2025-01-17T13:14:47.25070577Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 68de5f2048c770bff5d95966c1af00375b7bfc0f8b7e114c807b6e8958538a76 name: azurefile-csi-driver @@ -147,7 +174,7 @@ entries: version: v1.28.12 - apiVersion: v1 appVersion: v1.28.10 - created: "2024-10-15T13:19:44.743352405Z" + created: "2025-01-17T13:14:47.249604963Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 9c7bae01fc3770550ebddcd5045f69d66baca6c6fc4678da3de6c1d4f63a3592 name: azurefile-csi-driver @@ -156,7 +183,7 @@ entries: version: v1.28.10 - apiVersion: v1 appVersion: v1.28.9 - created: "2024-10-15T13:19:44.753655577Z" + created: "2025-01-17T13:14:47.258842399Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 489319dfa4bd9efeefede1fac20bbead9d309da3c90f34d178c30054d562881f name: azurefile-csi-driver @@ -165,7 +192,7 @@ entries: version: v1.28.9 - apiVersion: v1 appVersion: v1.28.7 - created: "2024-10-15T13:19:44.751543981Z" + created: "2025-01-17T13:14:47.257737695Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 7bb57767321958e5851b621962988fb7e245f583430cb19a573b28d33f83d923 name: azurefile-csi-driver @@ -174,7 +201,7 @@ entries: version: v1.28.7 - apiVersion: v1 appVersion: v1.28.6 - created: "2024-10-15T13:19:44.750459359Z" + created: "2025-01-17T13:14:47.256578519Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: cdf86fd396da34c8bf6c401d236dc12ce24697fa8565c63c605f8b5d8d1b195b name: azurefile-csi-driver @@ -183,7 +210,7 @@ entries: version: v1.28.6 - apiVersion: v1 appVersion: v1.28.3 - created: "2024-10-15T13:19:44.749370853Z" + created: "2025-01-17T13:14:47.255163566Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 58e138f7a8f2a925c56ca26dc220cab2dc723691c23fd011b457624d11889395 name: azurefile-csi-driver @@ -192,7 +219,7 @@ entries: version: v1.28.3 - apiVersion: v1 appVersion: v1.28.2 - created: "2024-10-15T13:19:44.748071868Z" + created: "2025-01-17T13:14:47.253286265Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 426fad83a42035af15af775bd37c73309ef0cfe22686babb0668be71da70a66e name: azurefile-csi-driver @@ -201,7 +228,7 @@ entries: version: v1.28.2 - apiVersion: v1 appVersion: v1.27.3 - created: "2024-10-15T13:19:44.742264133Z" + created: "2025-01-17T13:14:47.248379528Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 330d2b11f93e2b10d36f64ed6de528b61351ca794dd9b2c3690c6f6790008732 name: azurefile-csi-driver @@ -210,7 +237,7 @@ entries: version: v1.27.3 - apiVersion: v1 appVersion: v1.27.2 - created: "2024-10-15T13:19:44.741208308Z" + created: "2025-01-17T13:14:47.246159461Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: ab72e0e5f360a38f63e87147ef47ef213016578e8ba64fbb32ecaf2aad7ffdf3 name: azurefile-csi-driver @@ -219,7 +246,7 @@ entries: version: v1.27.2 - apiVersion: v1 appVersion: v1.26.10 - created: "2024-10-15T13:19:44.73735219Z" + created: "2025-01-17T13:14:47.242559887Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 80d2fccdab497044587f8a3299cc761cdf364c2d2d0b4f4cb0ab8197021dc218 name: azurefile-csi-driver @@ -228,7 +255,7 @@ entries: version: v1.26.10 - apiVersion: v1 appVersion: v1.26.6 - created: "2024-10-15T13:19:44.74014142Z" + created: "2025-01-17T13:14:47.244982654Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 3c20488343b47ed618e8c809f6fcdd83f22e00a4d07c78ca097573cafd7075a9 name: azurefile-csi-driver @@ -237,7 +264,7 @@ entries: version: v1.26.6 - apiVersion: v1 appVersion: v1.26.5 - created: "2024-10-15T13:19:44.738374163Z" + created: "2025-01-17T13:14:47.243844396Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 62ac6ab864264ee1e2fb86e8093c8e8263c2c0d3bafff60704c31fd72e40c604 name: azurefile-csi-driver @@ -246,7 +273,7 @@ entries: version: v1.26.5 - apiVersion: v1 appVersion: v1.25.1 - created: "2024-10-15T13:19:44.736313408Z" + created: "2025-01-17T13:14:47.241531472Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 2bf374cc321c5bc8e76e06cd5df85ce7d7d14574397e7e7f7173077393f554c4 name: azurefile-csi-driver @@ -255,7 +282,7 @@ entries: version: v1.25.1 - apiVersion: v1 appVersion: v1.24.11 - created: "2024-10-15T13:19:44.732741651Z" + created: "2025-01-17T13:14:47.236811177Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 501e27a634966a4ae5528025577e926745d896ffa2c253dc69c13623b84254d2 name: azurefile-csi-driver @@ -264,7 +291,7 @@ entries: version: v1.24.11 - apiVersion: v1 appVersion: v1.24.7 - created: "2024-10-15T13:19:44.735000078Z" + created: "2025-01-17T13:14:47.240160983Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 9e5b3f32ad823f845e5a09af230f7a934851943d6afcab3bd545233838680d83 name: azurefile-csi-driver @@ -273,7 +300,7 @@ entries: version: v1.24.7 - apiVersion: v1 appVersion: v1.24.6 - created: "2024-10-15T13:19:44.733967659Z" + created: "2025-01-17T13:14:47.238160421Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: dbd0a6e27a09fec002c57029bd6e34a6ee92d1c10e708935e3f2150069a35ee5 name: azurefile-csi-driver @@ -282,7 +309,7 @@ entries: version: v1.24.6 - apiVersion: v1 appVersion: v1.23.0 - created: "2024-10-15T13:19:44.73093968Z" + created: "2025-01-17T13:14:47.235792193Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 5fcb33617d16e90df1e7041b0df02e5bd92595e86381db30d356b0b2e3500bc4 name: azurefile-csi-driver @@ -291,7 +318,7 @@ entries: version: v1.23.0 - apiVersion: v1 appVersion: v1.22.0 - created: "2024-10-15T13:19:44.729685832Z" + created: "2025-01-17T13:14:47.234495Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 253d87a8b876dbdd55870a7fee88547393179d03f193661125f5a0b63411f922 name: azurefile-csi-driver @@ -300,7 +327,7 @@ entries: version: v1.22.0 - apiVersion: v1 appVersion: v1.21.0 - created: "2024-10-15T13:19:44.728451209Z" + created: "2025-01-17T13:14:47.233218155Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: d45bf3455ebadc9cc5afaf9da66aa1ea1d4b719cfdff5af661f93bb26c01a504 name: azurefile-csi-driver @@ -309,7 +336,7 @@ entries: version: v1.21.0 - apiVersion: v1 appVersion: v1.20.0 - created: "2024-10-15T13:19:44.727333395Z" + created: "2025-01-17T13:14:47.231930746Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 7cc43d57a79137aea5414fb51a9bbd77bb679b29ee49c06865c1a5b9ba60be99 name: azurefile-csi-driver @@ -318,7 +345,7 @@ entries: version: v1.20.0 - apiVersion: v1 appVersion: v1.19.0 - created: "2024-10-15T13:19:44.726189636Z" + created: "2025-01-17T13:14:47.229661481Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 18f6efbed424efd661fde43be2e5a48a5012a46a7938c33b36963cbd9875a5af name: azurefile-csi-driver @@ -327,7 +354,7 @@ entries: version: v1.19.0 - apiVersion: v1 appVersion: v1.18.0 - created: "2024-10-15T13:19:44.724658831Z" + created: "2025-01-17T13:14:47.228641159Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 696ca23d9ee517f71ef5e852955c8d0f1017c331c025426c6fcbe7a06d006c66 name: azurefile-csi-driver @@ -336,7 +363,7 @@ entries: version: v1.18.0 - apiVersion: v1 appVersion: v1.17.0 - created: "2024-10-15T13:19:44.723342588Z" + created: "2025-01-17T13:14:47.227419999Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 5632f61265a3b78dce3e2b15e07cc9b14a7f54a778878c02ca2d9fe69ca0344e name: azurefile-csi-driver @@ -345,7 +372,7 @@ entries: version: v1.17.0 - apiVersion: v1 appVersion: v1.16.0 - created: "2024-10-15T13:19:44.722145244Z" + created: "2025-01-17T13:14:47.22594523Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: a7a2d57e8eca7dc06c8b2cffb9bccb857753eb110b8e70760b3e04f4e6a87552 name: azurefile-csi-driver @@ -354,7 +381,7 @@ entries: version: v1.16.0 - apiVersion: v1 appVersion: v1.15.0 - created: "2024-10-15T13:19:44.721103957Z" + created: "2025-01-17T13:14:47.224859931Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: c1a31dadce233a90c19dce70f6cc92ba2e20bbaa1b1883baea72381d09303118 name: azurefile-csi-driver @@ -363,7 +390,7 @@ entries: version: v1.15.0 - apiVersion: v1 appVersion: v1.14.0 - created: "2024-10-15T13:19:44.71977386Z" + created: "2025-01-17T13:14:47.223659807Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 0c9ad4afa5ebfdb2851ad93eb16a0382d61448714b7556899360730a2fdf463a name: azurefile-csi-driver @@ -372,7 +399,7 @@ entries: version: v1.14.0 - apiVersion: v1 appVersion: v1.13.0 - created: "2024-10-15T13:19:44.71842933Z" + created: "2025-01-17T13:14:47.222269977Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 214042b029d858b50a0f8bba33a7aa2b41d1b67bce16f957ca183ae7438dac3f name: azurefile-csi-driver @@ -381,7 +408,7 @@ entries: version: v1.13.0 - apiVersion: v1 appVersion: v1.12.0 - created: "2024-10-15T13:19:44.716434915Z" + created: "2025-01-17T13:14:47.220538756Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: fbd63929671066a26df898d32282a6e79c39499a39c71761c546d069459d847d name: azurefile-csi-driver @@ -390,7 +417,7 @@ entries: version: v1.12.0 - apiVersion: v1 appVersion: v1.11.0 - created: "2024-10-15T13:19:44.715263829Z" + created: "2025-01-17T13:14:47.219319316Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 76bd438f8391d08235b09fbca859f25a9fcf8e018fd1e7e33444ca9ea946ce4b name: azurefile-csi-driver @@ -399,7 +426,7 @@ entries: version: v1.11.0 - apiVersion: v1 appVersion: v1.10.0 - created: "2024-10-15T13:19:44.714071447Z" + created: "2025-01-17T13:14:47.218314874Z" description: Azure File Container Storage Interface (CSI) Storage Plugin digest: 845a9de8b571b255d05ae9c643d9b90a57fe6507ff3fb735c88b41f99f6f28dc name: azurefile-csi-driver @@ -408,11 +435,11 @@ entries: version: v1.10.0 - apiVersion: v1 appVersion: latest - created: "2024-10-15T13:19:44.712696382Z" + created: "2025-01-17T13:14:47.217078761Z" description: Azure File Container Storage Interface (CSI) Storage Plugin - digest: e6da963cf8ffa4f348346af3818d5e40d2814bbf22b01c26a0cda32499227eed + digest: 686b3b24f624232ab0b19bf7e0d206b78e47f2abf3f27047fdca120d0afd29a2 name: azurefile-csi-driver urls: - https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/master/charts/latest/azurefile-csi-driver-v0.0.0.tgz version: v0.0.0 -generated: "2024-10-15T13:19:44.711336981Z" +generated: "2025-01-17T13:14:47.21572906Z" diff --git a/charts/v1.29.10/azurefile-csi-driver-v1.29.10.tgz b/charts/v1.29.10/azurefile-csi-driver-v1.29.10.tgz new file mode 100644 index 0000000000000000000000000000000000000000..c3c28ca3de13c84b8e7627d6ba3a2ca834895de7 GIT binary patch literal 13385 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 f{BBIeTFDc zVQyr3R8em|NM&qo0PMZ{avM34H`;&eDG>Bb*xqqb)Wy~;PdGL-lG>xwwxp2co-?Q2 zpBJi1k{A_%8URI!?RLaG$nML{lYD_o-BHEjMHkDg@7rmMg-RrVL?V&-LjwO6a~O~i zJYNtm;A8@P^I(Lz>`w7G{9zSOuh;9n+1=Iu?e%))|Ms?bdOvLK?(MwU+wE=bZT-;O zdcD1~^#kgyr1lw4EF|VX^p>ux+_-P#!4dfxxFC%7(PV1_M^Wz2?oO|}w-JEwIfM`NFN$HeDM zuz~FQY`lT8Nvnz?#35pWNXDmqw8@0nypFGcQ;;B(9Bme)N`E2oFq_=!hbRuiGZqqm z+DFHO6DH3%2%vHUAzzR)&L%`@1mNvzRMHz|ALZ(N-QDW;T2y%sg8Vj5b=-VVXx`TL z?7BiS0SZE#ady?RKa)=)^+~S6?e5m@>SL=HJf3`BWMO8T zH=aF1=P&>c)CVLPViXYLXv{bu0X_#Q)X!IdVgUiV83EPQ2pu9Vp+b@1FzBO^l#%Ff z=2-0#wiz&AY)UMy#iq~bfDB^}Uc>^=PZp_7MbFd3yoi$tmXNe(y1Ai$Ka0cg!f?|^ zzx=xK40*_`S>vhgx#>?ZHAPPF7&cT94;{opvM~zr6@ASA>>DKA8n<7j$y17 z^Xp#k1F^qy_-72F`cZFO`D{D+s=Tz_XT=wG0?N57-(9kDhX}Q z4+2KTDGjHK(cI9B;!K@9#$M6$O_kACP_#2U< z;{d4C;+N>zimrd%PS@|0bo55DuB+le^}3VQlJ02gG*BC>S7e{ruZ*?(=Wb%`Hd@?; zst*cQK^qPncFQ7MILspbQD&IbRaCSQW=Uje&2+7r)pfIG<*clo_p)4V3;@fRLnct~ zKpL68kXUU8tjL>}=FJCXGQQ(1j?&iyq5n?C;~a4CH%=s+QXkZu`0+yZ;KqhA@iQY) zEf!s0kglGwcF%403?BvX{UK0kwR)WVeGv}^j!)jbLPzK4r{~HHRC}&7 z&Tglc3H3wv_eMx)d|Q}|wm$-K;xK}hoIFwGt?Ymd# zAdJ;=^dsS-^q1=EzZ%>16*^%Q?D`mj?4!*I=9?k8+O)s8*3Lj}_E;YUa78e6vSD7m zLIVgG$4b2^c{l?;CPEmA?(OaE-Hk=r%Dh>XJyYvHxVtK6noz5;6CDPSbIo?xP7dp8 zKly1R;YRH<4r5N}&@S_Y4v&YFr9U6tf*)(ox@9q6(!qRsr zvqz-TFsSfkZ8~A{n3mpJfiC^3=uHThF%G?CqHNp{8n7GTn(DCtHRH}WQwBg98xSpY zfp%d~#G*F)dK%kl%=mT4aFCkldQ(7v%Hu;jm7bwrm=5{j@KE+QySKi8H>X;S(-+8lDivOv9t>b_9@m#8Tor~#T93!*B zsJT0|UfuwrkWC>#l9~8`ownVLjZ2375%||NL?RXlBqWxxc!i=6umHqk+TTc)Zy6%b zqly3F?Uyg8dk(r>H}y)OuU{1_hM4CGt5@H4a1@o+21Tht1bzM5L7sP`)b4jNspoiR z%>U0L2qWO4E2G7s05j(Q_U`U>Y5woM+1Xjo|ND5peA)aDG$G@@UU`)uD8u9JSapj( zf&97fKHgvJ0+X&M@FUZse(DWLv(PFyXmoFX)U_dCKPAXYlRk(w^?7iOFcMZx+ zPtfkq263WFo=$*s5&-&LneEg^Z+7%Q$=G;2P{+%N0S)xOHG>-mIzDF@GAt^7Ew)IR z96GvuHO<&ITY~OJ1NXXIR%65ol>^lIqwxMHI>lC)e_H?*`dz!xl>X}cse?M7JBzf4 zjmJz`MMmX`MoyDbW)ovbx>aN!effftSzaBgE^>ZJsF0ZY=IgSCt!Lisx*9nTa~!J@ zg!*9|G&Zh=N1u%&Mzy;v7fY{}i!hfS8!Xll*5dT8rp2yE!pTW128l@Qr?5IV!4&?c zs8v4s9sM(Ave3z2zix~m9CyWNQ_E*gbv#m0I`E8v1UZ z8SB5#11}#aSO^o?xc+bLzS-H?E3W_BTRVGe{NKGirOB3#vvu$38Q^)|Mjj`OBLcS) zsCHg-um5aR*w)51p+VoGq0X(F>=3jwg)q92fT8*&=bMR_WeA-iP^})XViE?x3;J== z>;Bn>zHmf597UW>ASkNSKI$YWu_2M8_^Ru(aXH4OTEHm|^PxVC5!-z8=5;3l`w&Ji z$ryyhPID zjHBpGnMS}56phS}SAdTn(}4I&vnZj{J|SC`+HP{d!8DHplnilD{R9YG*1Fce^$)@5 z8J43y>YD9kSATuUK8nO`W`^m!{Ik?C%qzx1z|_g(0AWPoCgY6)1fmEIdu4D?c8L>t zqd4`z>GtVafX;qCKm*Rk=w?Lxk;PCYx=73<_xXYD1&-zjdjEu6l|>dcdgS7O|^; zfG?GGY(mw94hx@WbELTgCNAnV9Z)LOvNO&T7EN2ngpzSQMuPmN+iVy}UBpISN7H~S zBTNl=yAZBeC=sGYk+?OjP8Kmyzfi9`U5c@L5VK_~R z+JP3v<)w;TF*z!+p!b|^{v|^|Ma(nDzWyF_KoKKmB4CLC`y<5U2zVF$#q#puLMr-Cn;D#F35)yN1%oJGJTDTbVKW?~@_RcPCD)qK0RHTyxMUaegLf$cG)476cj z)vz9la#U=9FiqrLBf8awQ;ak+*=KYDT&*=e8&dLHN?WT0RjJ=Lmhl<&A(CR#>efx82-5wKc;?zeWKV*l?-qN*trv8MXd$Wws0-a1jylZ+^?P!z&5h5NN)AtH&pudKw z4*#d2z61eKTIdozo*O;GK@HI>(1DBcZZbW0l5AX*26t@ZT!Mq@g~wgIMgb&G?KY)_ zpwxa_BPh70J%z=*{jLnt>YmQkxXeDN4qV+3*{x*_T{CWa*cc6`cI9Q>NN- zmDiA6axl$H(^Hj~jKb-_g}>qHiKAaSwKKo->x?gJMWOO#%?53T=6&wiB5Fw^)s4QR zsG~Dy?Jr$qbdAb#xN@nH5C#%a5~@i|tSiav;miVRB8$acZYG7Xa8LMsG$a$C393O? zKf)70<2aNg3Ny-v;bH~u)q&CMs|a`w6VWv;mXh8}6_%OTu4#db^}Z^RFn*3~c~o0e zqnOQcSQnGAL^nzAVIi1L^paXYff(JH@85Q#pQC4STv+BQCyeS*QGKFM1Iv*z=4o3I z(`rKRgs>gNTn*Z4FA&wEdIdny81w6j4Q1F)+WE?C8nZFd91k!FHRT~t(2gFZB$c7q zMf#+SgQm5yEgDWAo3Tf7WvZ}BW)x~tMX6dS0SAro;ttMh=ujEOw)bl704Sk7;POW&b^0F{VHO8?r0E)=*87k z?Pf@Tt=WU+d~TXjEoQG$aLc?zS1?e56$?{E#o=Nj}r2y=odUXU(yU1ak>{H**-MJfQF1fXW8c1g<-OmkjXNoWkH;=I+e zgo&0!V-Mv8_$5F$PBTz-mXgDqO{`vxE}3DXEH z)p<~WCo)&FjjoeKC3fk&w5x2wVg0U7Js}$o)l^oC6-m8L)Q%Y@6bYb$NHT%E_32oG z&}@&4bS^=a4wKExj~Uh*Eb`svb}G!)9W%LZa6M$mhZ!0sE0{CES^zOzUFd*jxE9a) zrLtivv{^iJOOR&wvt*xR0j^c0?b_MAQZ^VEO%^~6n}#W;=4!EY&Ri&6D}sDw47wXq zW3vd88me>2W9T^6Stn6625g}qs)2-pD2FVXR@EvRC*Kt*>Y*ywjgzG$^(mS1es%_+ z!!7q_K}y9w8K^wKqj4siCo(j^8Y_@d_k1_{L|(%ak`WASsZZzDy2_nq0Xl zq>Km@D9z$$+Wi^YKReE2zsztaggE#>CTiKc!JO*2noTdEac7Ej#Hg^#VMaW+bX$g* zJ!vWm(anTvYJw`0U!&9n8e=^LlD6gfELKMt{hOiFN1d7@ADao8D%LaO`v1{MdFv^Z zJ~rFmhXb5GA(-iEfTe3FX+4y5Mc~mjT(k{b^d11Bj|&p|)BvE%LOquRbuJ0tTpFnP z?LsnF0KQxvX1O$=@(!Vs4}w=*7M-{XEaLLW!=-VC%c2Tbh#|ZK#Ne{{z~#|^-xKz4 z#c02~!uLI4MBnoGy%nJKR)Wo28j1Ii0(NU{HMoG za%3^|(^}HMpgFZ+@`cTBc#z&hF<)}S9InEq8a9G%y8JNz(=0T}AxPk39o|cJBz4}B zWXmB(oW;W;tk&fP&D_obgdmd}mWdSBGvh)a=zI!~UaF#&mD!b-6n65s!3{v;aXElw*e?BOIQqDP~t`5Yp&W`t3;ZE7YS{#VH!ByvstaTj}AvW34t%vd&rk)wcF^Th&80s(n7#UlLA7}OG!LsKla6?58K`bFNlT)`QZwx?De zjm`VL+PZ7x_1z$^jQ}kJzt$91g~48AFS5!V$jbK}k8`)N#(5`wde=LO`_SR@>>5_J zPq>qv!7BCwPr~|t)b{@R2*WpG(|_|;eEV3-I=b@k(G{b^?;*UBb0gITSWKB&Ar{MW zeT*gh*No6g%F~j;m2WORLg|dW&&H8jRSUuHjBSc^FusAU`A)*CE*x4_GJBuxT3Tx? zk5oD3Es#bOXnQa4JiBpy^nL|f^4cT!2N%c5x{*kcg^y@xtiuq?^!B`mx^-KYbe}Y& z3($6S5eA;JeFY(-L$OS9gZhBg;ykwjub18C36|Z8Rl6pg!$9Bf+R&mo8e@*bE!(2y zTB3PqXwFHg%(oSjwLMhAewh>%sKcli5OLjcg>BNK4$brP5qKfWfrE9-a~-yMgj>8B zr_>9F)U(NC@T84Cp;BkfK4#)}0MsMco7`KKcFcBhwOE_7r_q(u#*lK*T#0kc#p{aP zW%G7J3kRBmo9m4R_*^#Veg?!X;iB@VQJvotHAB{2{!i522imytaI|@TMPg4;+1y$Vl4*(uoMSJI z#AWh_-hn&|;~}BSsC@C#Aj1dFRMC1m2KF?1{rEKW>%s{_k`rA8H^B?Wvz_Tn2g5bf z7%^T+`=@ltKVl)X3~4y$C9IXxlG%6nSxS=j|5dxxTbx@eeo#tkq0a{-B|ej&lfQVj z_|%+Ln7!n=Wl23r9+Rw}-MyNok8B)ll%d-0BD+ZI4$l{Nb+>tMJG(|9WYx~h_>z}# zbEdcM21T^ei}04eJFO_0EiX)~DQt9xSz|u1V3vxxC>2kX_*nhBc#P#{#Bz`UM?WQJ zskQa5M#Sb+`}e>8=SLEPnFas;*Z(T5^Y4HC&tF33U;q1G|JyntcM%O@m7`(qxiB2( z&bAas*hMiN^O7)Nif|Z>u+3pHk6K?Wp%Z1b^FP*GeOkH$n~)~Q?g&Q_w6{(i zloz#E>YQ!KQ;@&?v*R+%%?_n=w>Wd<)-Bau(AjlAKOUIMc$UkOfEkL^cZUcS5^&I9 zCQ$@b5)SF;8r@|)Sh;irSmUj<5TXC~;`C(m9jhT}#tZ8-0Q$%sjDgBmT7Q^~Mmlrg zg?iH+V@d`fWY^XKT>P^AYn?fugcok{I11ra5{OGpuw)JqVY(xws1=@LLuGpaMJ!1g zexsYKmPchLV(Y;R$u;y*M?1hXHoqw8|LVH%Lp?7{mcWiG)G^GZ?$P{0k}+wV2b>It z;J*6-*=>@}@AOisbfQ+|90_WZ^`uL5h3Q|mf34-X*k5WLhg-C5w&+BtUV3R~q?l5P zZ&gjcvNq~^RwsJXvw5Nn0cD&(7<$Rx{{~N0FC+tJ)45_U8>KZ(@ppQ7+Bcjjff~{z z$JKx+-DeVhHJcX5xJ8o~i9f=0nC2TC#4_fvSc-Zizb16(Dbe(7s-#W5{%k(e|5>;#dI4+Opu%c*m#tFuh|Pr> zm4p`BuVc?I5|~oy+mdCJ>e!meLm>f9hGxj)!TW{%ul~`qPDa zFea_0@5kfA`w{S%EHqbZx4d;p{Ay5Q$b}R`b!q>+s#)#`?L5$x!1c!8cYZ(U!Nqaj zk?&%+;@V%|5jt1ywA3+D#N|@4$VH>7V{6{&@1=w(E-X&+tqOwF;ul@vZ;d>v_E` zuear(*z5K6|3@D$59+hSXp%%AJNE z_r05?Mai)Qt?%Ca4)5MVx<>o#E=qndp+my0Lza zkJRFB;-YGtOa#r2xg_ozU#T+Kh8%>LBj~lhFm!z)X6_R)D?ADFt)GBdpM1I3lP~KN zFOT`e%Q`d59c5;*BC}L(7DHoY*;(d1mGljrMOtS>G0!?}#J7E>=vzKT^gt%(I(<&d zlRZnH<5|I}ot2!?nd3xGqaF8z58y0)+-CX1HIMu#&FT)$Jl$h5OC5+==IG0}dB|nS z<1CN)=GsNiF|7L3!qR6Hp2~@YdpLiv{Aq(#o-J7RB*CiA4XjTIlurpPbsk_P$p7Uq z{>!5Im&Wa{1fjnS7JnJk{WAFaHIjbr#;uX`Yb5;|Grz{nuQBtF@BZ)EF0$|T4)9`7 zaT(P5(irt+5$WG3{`|?I&DXbYKTQPro!-4YCpvt6|Mp|Le|seu?qw0%E5T>4@6rBd z@6rB75z&6f3r}@FZ#T*7C1kV@5Ga6}A!Z^|( zu1)o0u1I<x$)LkL(vH}gB{QX#&A(9U@rMYG8wq$W3^ei#RUI;muK4W$n1qTdlE zG*J7`UGF|~#BP7QXh87ZMmJIhdNy*D;WWP<+ zjpaWlZ0ZRMO_@sq{+u5)x{yc|(Ml9Gb%cy3&B&V}$K_$@UhzWTDQnkIVhjT@; znw1?veAxH(4*aC7ScL6QYX@~-qE5a&m%zuOll5Ao8p{YJ@?n3;lu2FBRD?VIGZcEa!MIbImHV%@km<@= z&Wt?lSANZG+(Yf;~{0~&quf5$FdS;s`O-eN8uTjdvvSz%_6(REdP`= zN>l4|Iwh;&8m4{CiN{$8#S6|hlPFT8K6iMhSOgra8G?>92G7YI(7;ji48BVP(wgHj z7VaE3bFx~JHH0Eg7$qZ1Ia?*Wks3$aSlaU=|eKcLpY1W z@B(}eGFL(QO`(>$uUkw(l;IylewSxVIc4H!kWIc}*&ShVrk2)Q)Ym=N09%WvzfaR(7e z#=v6vc5A!W6OQ+AD>?QIUeHUdwzow~CoQbzzlS5@{WB78U-z0yT*X|-w_80|p#fkS zbMS_0cl!3Pj52=q^Evn-CSwx-u46!lWjuW*X@Wyk8&ymxWDDRC`ne&61-iEn5_!iA_2lQ&|zEvHI1VVN^VnI5gZVzCd~b z;e`b;yDjvKS5`8GorWz~VmD`HZ*Aup&a0JtKC?!(lE%H$p1H_AU6p>Bqmq8>&*s)R zch5yT9n@Ca+>f$xYsCAWvrSX2VKS+wekLw9)pDa-JJr+<%8#|V!>EK?S>)Nr5xycJ zah_x2EUMbE`|sa7=P?ICers(SoSV`sHw&C}oy&7la&dED$+}iM1)Y=QKIY|f&s@ar znTg>M8Vm4r?EJ0v^gpkBkTV)Y^=)zaJ_nyofE%Rw(QSnF9nwEy62{zYqRSK>>pGqY z!6Iw;Ju4Q=>cc9PkW7Gr5NhLb1#R?7^2M3@V702Hfpm4o7Yi?_U{+OQ8#PnhSJX+l zDXB*zox(dJ85sEIET5kCZk7B1isDGh$V*PHzYUp>L-kqT?ZqlKbp$w+qcg^3x~;Bs zv8_dy^diRP+XX3?yV4MzyxpEl6%?y^?AoBf?ZYaB)Q{gr7i3QVmFj^Sveg-x6*7bM^g-725@ijLDvNmP)l?!?7kMg5ozp{NicCjvmm>~h#KNGDUKif01^pe!vR04G zl9X_?l-*zgihYz?3+1{N?7}(=BB7XP-eC_AN+iMIA%u8(Vc_h2v{QtpS<@+fy;Xc2 z0VgbQe_X$7`TswjAALSJKRP@*xjf!~|M|z`_eZWh%#WNovTT^C_W?&g!PI$t+5zd% z%gzA@9mB@qk0gYHgiN*f)T5(4N(db9SY(bY=aP+;+n8Ty+}pF5lH2~~X1)DdouF1_ z=>tt?oZU`Qr&FDohJn9cUY=ciK081C|Nic-zp4szbW22Q1gMe2HVn?s-#qLU3wEp%wZD>` z&7cC(&z+>(tRWP0@ciZc zrbEJQM&RNXPKlfGg+sK|l3LAP5X}}?gX%ieNhlbfo^pe--^h>GoD%Dn)|nhuMYmou zXA+wsra38mXt3rTJagfHt&X1u`}@O8{BLiox3gEm|88$@@2&B__wjh1SAhIhvZ!tt zgz&+|u}#q22nH_hwM!7+d9k}CY@#CJ3u4%4cB>@b5|ld*GEW#b`9488VkxmdI!`Yb zui3~JN|_c!EI6hEc1pFmk}h&)Rd`PZ;7|QfUn!m@c|TKQA<`>=J#-X}U<@296*&;^ zIEy2P^<-l!-9iZquw~ak&uxy-q#7It1gNi8iHP(!H}_TV?H^vMvPZWjgUD0VcmMQGOlTf4h&wo3Z{_1^mY$NfCkX2Ued;O=ICyFl?( z2-V+X0e@9Cl^Oek6k4csjXh3+Va(_SEO446sU#35D?Ci%qPl{!BnjE&50WI5R(guW zq<_9BoXk*56`{kA`c+~QkMZqCiYJ(aYQzgYr>1HV}Eeyr=m1!k+#i!RxiI83De}#?cvPYS!iV_eM3H$5fIr z9GXik($}`DP9s@9t1-%!wTe56$8=wO6u?cFbxtnP{>RI|o}M3H{{7RZi@#r79(_n6 zR)qsmIXY@o4jQ2N>ixGE0MBf~=>B5i)k@2*!r8v&IuEnWaa4(^N9+c;7(p0z;nsmN z_bWf0z>Rk-VT|P0bipds%J%Mm*0fBH1R{L`n9Tz&eaR8|P`)2B%10T-V>)o!mp zeL~)kjQa&f?#z+dbcRH04#S+sVMvq_&?EUDRHd z@;X^nTQ}#plts4&JyJxc&Vqtiu}y2yh|>tm(c3?~I6Oc8`RM%f`O&-27pDh5eLma2 z{Hu$Gk$5MGv-cn09iM0thsWoxk4qrg+Hh*?P@}^Dw2f3#FPWY7ld}e8XD>T*bcvgr zCA32$2gM#;r0&mlpr)TbIcxao<6n+GpPU{ZeLmU$Fh|5%r{AdwRcEP}wPmVjOYVv` z)Jp5SrdZud&>U_`1S5+zIcTqubx+N(s8hKqB{M@>D%t`}Pw$~u2GCQ~NbvR#FN$-q zPJvfpT6xX)K*&4YBX@zht0(;A(0011ZE$v}h~cXcydlWs=!cM4inoq%gDLtBq`fde zm1`uL_aA%Kfn0ZJvjxD^IH+o&rB4J_mGqjU%qrnkcVhFbky$H3X5EEBm3Pojw(iQ} zT9tM6KuDe^oKbG!_}?5TkQw>kwsy8F`QLV4@2um0_wlrd|Gl70whjWmTt@-dQNVQ+ za2*9)M**Ku6mYd6xJM9EYzk(S4yR{LYI*M9p#Q1vF{6Gne};hYLDn_`8qiHaKXt(6I;C3N%xrId`}_@ zH#=iSA|s6{Gdj*rE=x;gsjj8xSm~3`3$i+kNWSno_V`F*kKaUAk9D|k9WH#L;X=bG zp&_AZ0=jFMdggX(bLD7~W#7&GvHsRn^b<_?^@o2Wa+Dxe$88@^&X1>K_uGsMdY(5DaPQV^GXC4C zHxOP#BJe7Mnf9^eOil3BfvYOJ7#25aX+b>QLX6K6!@Z2n1;5B@pJ2-czT; zA^{pOuCJ2BlIVSfz9AQ;&$+p$v_wqblVWd4)DeUcPHw(aKV5;uXkzbmx0fFtTpT0K zUh95URF>%6>gSC;Jb!Jbo6FyQBajL6@7m-iGvvG}XGd$HZ!7R~R#uY!l}Y}Jq<$WW zU#6RjwB{21g*x0_UxS;asg_naw+!E2v`&jza4IahSER+cnX7W=>a}!FG&modxT_=x znz2YW@mX0h%RTXgF&=^W{)c;cO0js8u*)L9R)OTQ z8NgPGH<7nenvwaIY1#+g0R zyH&~sT3nSfSD@(b?k{O}L78d1MuM%8U~|r&>vAGdoGiJhSuLxTN?p3jRGOx>~ z^}1}+$2@rLe9cbIiOB0aToLN|BGw*4A4cxOj(@8 zg*d30C`)%#3e;JQty*V9Gh<6#mDMoaXVhAr`*nz*2A%Na@9A1&fm%N;@IT2_NnY-% zqq#spGw%P|+wSd_@BiA{+g{^;?&B#%NYiVvlH^Zb1_FX8WYaOw1yDdK+2kJwnJB5k zD*^_!s%8aPp{9D4M-VkpUn#DLLlhDpi`IRZe6S!MsO9i10};|_?DWbvlxZwV2j_dM-dqldaiiS z{5G%Ec(ekDUBr9{ebmc-DL}@|X14+fYZ|&LQfxV(R%f+MnnC_iWaz50 zwkUQA=~E0mrl-^rI}0%do!l2OZr*&rLIStH(Qt|+z6OC{FaTfbRD=mui3miQL;~bS z&T6%I8i8KOC@jR9@;5PNkg5*qzC@jTLoR`jMW+baDU6z%P%=Cz;41mLZiFgkY5Hd< zKsAMNSCy6it1V=@vX-+lKrAz=xxJ$DFy@2~FZ>Y%u~HVtL(0;hk8Z(_wGX6VkXL%L z>fzB#!O?BR!9)qF9=4Lz(bRf}`_?n=TaD)6EQD@RAT2d7QlC5hyTGv$XmoT-M8#>5 z4w<9o8GM%pq&3H5{oV4cR@@x*$UZ-eRh=2QuW1&1Pnf*<7NW-Jef=G?MVo3BA^rL5 z>d*W2+`<3*=BYJIVA~Np3;_qgJ+0XYqjeeSOT|hdao3)u)7s_OY|J~jy`+s(O+ppLDpZj=9tFapIuCKS8IoHpD zF&55Q2nFAdE{$V3Vx0V@O@Z9K@r@24{iTg&cyKF$Qyh8`XA`1G1J`EKlK02+I5aBB zLpUNDP9ys0mrm!`jgm6{r4yx>uG>J4Ei?gsr3(x}c3z=QNQD0Hjk0moKTKz-e?`ep z0fZny6Ih^TKg49*x_Waq%vD$MCVyAWwuG;Y!byE zZO~E#vvqwY?^gKi2aPqZvLdC^XN{PnKA$lj5SpL)uDY~MR7X3Nf}|Vm>?ue?d6NCQ z;d$OhRXhEK(16h4T_`D=k08}gSGKCt$y%E^q@ zc%GGHCF@6}_DvzNj91CT_og`0iMQ68HLB>bs?5YfkoT`O-A3ec)}zx5Hm*b0G+U{S zwVau~a@#KJx7ms;Q!Vv+by@yuwCq}&RdfSxM##>40+H7vD5mUd2Z?DL)#Rf9d2$@H%^y|MyX zp09Jhmj!qsk!d5{U%n)f+lP*Ye2>rk@xS?#K+eE_Z|&?>@ZYcB?5*Q}_wme#|K01# zqv27HZq0e1l_uXAk7|v{XV<%z)x{we>vd&SPh0)J%psr|`hRzCYp;C&`(AI2|G1aO zasPYe4A8xRLu!QV+whXCp&l!BkgR>|_v>R{eT54<7xO#(6|&RXDR`&0o=d+yD%-C9 zEYM0Vy#_u1aQ-kCQwHswg1zr>EqXwo@V$$CsaMxCph?*7c&jtR{FsTo?Eg1gJ6mh}|304b`TvqXIWzW4DY2XrtT_ijv#Wak)BlScD^RG4k`gx#de*HgxBw&XA@9plC_5Yh*Z)dIl@8g-r|9^jrL)|X?ewK>0 ao?AcbXZ?H+&;Jbo0RR7+*aLn5=m7wa!BG+b literal 0 HcmV?d00001 diff --git a/charts/v1.30.7/azurefile-csi-driver/Chart.yaml b/charts/v1.30.7/azurefile-csi-driver/Chart.yaml new file mode 100644 index 0000000000..a78c760e2e --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/Chart.yaml @@ -0,0 +1,5 @@ +apiVersion: v1 +appVersion: v1.30.7 +description: Azure File Container Storage Interface (CSI) Storage Plugin +name: azurefile-csi-driver +version: v1.30.7 diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/NOTES.txt b/charts/v1.30.7/azurefile-csi-driver/templates/NOTES.txt new file mode 100644 index 0000000000..bea09b0829 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/NOTES.txt @@ -0,0 +1,5 @@ +The Azure File CSI Driver is getting deployed to your cluster. + +To check Azure File CSI Driver pods status, please run: + + kubectl --namespace={{ .Release.Namespace }} get pods --selector="app.kubernetes.io/name={{ .Release.Name }}" --watch diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/_helpers.tpl b/charts/v1.30.7/azurefile-csi-driver/templates/_helpers.tpl new file mode 100644 index 0000000000..b1bf4dc1b6 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/_helpers.tpl @@ -0,0 +1,49 @@ +{{/* vim: set filetype=mustache: */}} + +{{/* Expand the name of the chart.*/}} +{{- define "azurefile.name" -}} +{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create chart name and version as used by the chart label. +*/}} +{{- define "azurefile.chart" -}} +{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Common selectors. +*/}} +{{- define "azurefile.selectorLabels" -}} +app.kubernetes.io/name: {{ template "azurefile.name" . }} +app.kubernetes.io/instance: {{ .Release.Name }} +{{- end -}} + +{{/* +Common labels. +*/}} +{{- define "azurefile.labels" -}} +{{- include "azurefile.selectorLabels" . }} +app.kubernetes.io/component: csi-driver +app.kubernetes.io/part-of: {{ template "azurefile.name" . }} +app.kubernetes.io/managed-by: {{ .Release.Service }} +{{- if .Chart.AppVersion }} +app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} +{{- end }} +helm.sh/chart: {{ template "azurefile.chart" . }} +{{- if .Values.customLabels }} +{{ toYaml .Values.customLabels }} +{{- end }} +{{- end -}} + + +{{/* pull secrets for containers */}} +{{- define "azurefile.pullSecrets" -}} +{{- if .Values.imagePullSecrets }} +imagePullSecrets: +{{- range .Values.imagePullSecrets }} + - name: {{ . }} +{{- end }} +{{- end }} +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/crd-csi-snapshot.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/crd-csi-snapshot.yaml new file mode 100644 index 0000000000..76df8af7e9 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/crd-csi-snapshot.yaml @@ -0,0 +1,840 @@ +{{- if .Values.snapshot.enabled -}} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + annotations: + controller-gen.kubebuilder.io/version: v0.8.0 + api-approved.kubernetes.io: "https://github.com/kubernetes-csi/external-snapshotter/pull/665" + creationTimestamp: null + name: volumesnapshots.snapshot.storage.k8s.io +spec: + group: snapshot.storage.k8s.io + names: + kind: VolumeSnapshot + listKind: VolumeSnapshotList + plural: volumesnapshots + shortNames: + - vs + singular: volumesnapshot + scope: Namespaced + versions: + - additionalPrinterColumns: + - description: Indicates if the snapshot is ready to be used to restore a volume. + jsonPath: .status.readyToUse + name: ReadyToUse + type: boolean + - description: If a new snapshot needs to be created, this contains the name of + the source PVC from which this snapshot was (or will be) created. + jsonPath: .spec.source.persistentVolumeClaimName + name: SourcePVC + type: string + - description: If a snapshot already exists, this contains the name of the existing + VolumeSnapshotContent object representing the existing snapshot. + jsonPath: .spec.source.volumeSnapshotContentName + name: SourceSnapshotContent + type: string + - description: Represents the minimum size of volume required to rehydrate from + this snapshot. + jsonPath: .status.restoreSize + name: RestoreSize + type: string + - description: The name of the VolumeSnapshotClass requested by the VolumeSnapshot. + jsonPath: .spec.volumeSnapshotClassName + name: SnapshotClass + type: string + - description: Name of the VolumeSnapshotContent object to which the VolumeSnapshot + object intends to bind to. Please note that verification of binding actually + requires checking both VolumeSnapshot and VolumeSnapshotContent to ensure + both are pointing at each other. Binding MUST be verified prior to usage of + this object. + jsonPath: .status.boundVolumeSnapshotContentName + name: SnapshotContent + type: string + - description: Timestamp when the point-in-time snapshot was taken by the underlying + storage system. + jsonPath: .status.creationTime + name: CreationTime + type: date + - jsonPath: .metadata.creationTimestamp + name: Age + type: date + name: v1 + schema: + openAPIV3Schema: + description: VolumeSnapshot is a user's request for either creating a point-in-time + snapshot of a persistent volume, or binding to a pre-existing snapshot. + 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 + spec: + description: 'spec defines the desired characteristics of a snapshot requested + by a user. More info: https://kubernetes.io/docs/concepts/storage/volume-snapshots#volumesnapshots + Required.' + properties: + source: + description: source specifies where a snapshot will be created from. + This field is immutable after creation. Required. + properties: + persistentVolumeClaimName: + description: persistentVolumeClaimName specifies the name of the + PersistentVolumeClaim object representing the volume from which + a snapshot should be created. This PVC is assumed to be in the + same namespace as the VolumeSnapshot object. This field should + be set if the snapshot does not exists, and needs to be created. + This field is immutable. + type: string + volumeSnapshotContentName: + description: volumeSnapshotContentName specifies the name of a + pre-existing VolumeSnapshotContent object representing an existing + volume snapshot. This field should be set if the snapshot already + exists and only needs a representation in Kubernetes. This field + is immutable. + type: string + type: object + oneOf: + - required: ["persistentVolumeClaimName"] + - required: ["volumeSnapshotContentName"] + volumeSnapshotClassName: + description: 'VolumeSnapshotClassName is the name of the VolumeSnapshotClass + requested by the VolumeSnapshot. VolumeSnapshotClassName may be + left nil to indicate that the default SnapshotClass should be used. + A given cluster may have multiple default Volume SnapshotClasses: + one default per CSI Driver. If a VolumeSnapshot does not specify + a SnapshotClass, VolumeSnapshotSource will be checked to figure + out what the associated CSI Driver is, and the default VolumeSnapshotClass + associated with that CSI Driver will be used. If more than one VolumeSnapshotClass + exist for a given CSI Driver and more than one have been marked + as default, CreateSnapshot will fail and generate an event. Empty + string is not allowed for this field.' + type: string + required: + - source + type: object + status: + description: status represents the current information of a snapshot. + Consumers must verify binding between VolumeSnapshot and VolumeSnapshotContent + objects is successful (by validating that both VolumeSnapshot and VolumeSnapshotContent + point at each other) before using this object. + properties: + boundVolumeSnapshotContentName: + description: 'boundVolumeSnapshotContentName is the name of the VolumeSnapshotContent + object to which this VolumeSnapshot object intends to bind to. If + not specified, it indicates that the VolumeSnapshot object has not + been successfully bound to a VolumeSnapshotContent object yet. NOTE: + To avoid possible security issues, consumers must verify binding + between VolumeSnapshot and VolumeSnapshotContent objects is successful + (by validating that both VolumeSnapshot and VolumeSnapshotContent + point at each other) before using this object.' + type: string + creationTime: + description: creationTime is the timestamp when the point-in-time + snapshot is taken by the underlying storage system. In dynamic snapshot + creation case, this field will be filled in by the snapshot controller + with the "creation_time" value returned from CSI "CreateSnapshot" + gRPC call. For a pre-existing snapshot, this field will be filled + with the "creation_time" value returned from the CSI "ListSnapshots" + gRPC call if the driver supports it. If not specified, it may indicate + that the creation time of the snapshot is unknown. + format: date-time + type: string + error: + description: error is the last observed error during snapshot creation, + if any. This field could be helpful to upper level controllers(i.e., + application controller) to decide whether they should continue on + waiting for the snapshot to be created based on the type of error + reported. The snapshot controller will keep retrying when an error + occurs during the snapshot creation. Upon success, this error field + will be cleared. + properties: + message: + description: 'message is a string detailing the encountered error + during snapshot creation if specified. NOTE: message may be + logged, and it should not contain sensitive information.' + type: string + time: + description: time is the timestamp when the error was encountered. + format: date-time + type: string + type: object + readyToUse: + description: readyToUse indicates if the snapshot is ready to be used + to restore a volume. In dynamic snapshot creation case, this field + will be filled in by the snapshot controller with the "ready_to_use" + value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing + snapshot, this field will be filled with the "ready_to_use" value + returned from the CSI "ListSnapshots" gRPC call if the driver supports + it, otherwise, this field will be set to "True". If not specified, + it means the readiness of a snapshot is unknown. + type: boolean + restoreSize: + type: string + description: restoreSize represents the minimum size of volume required + to create a volume from this snapshot. In dynamic snapshot creation + case, this field will be filled in by the snapshot controller with + the "size_bytes" value returned from CSI "CreateSnapshot" gRPC call. + For a pre-existing snapshot, this field will be filled with the + "size_bytes" value returned from the CSI "ListSnapshots" gRPC call + if the driver supports it. When restoring a volume from this snapshot, + the size of the volume MUST NOT be smaller than the restoreSize + if it is specified, otherwise the restoration will fail. If not + specified, it indicates that the size is unknown. + pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ + x-kubernetes-int-or-string: true + type: object + required: + - spec + type: object + served: true + storage: true + subresources: + status: {} + - additionalPrinterColumns: + - description: Indicates if the snapshot is ready to be used to restore a volume. + jsonPath: .status.readyToUse + name: ReadyToUse + type: boolean + - description: If a new snapshot needs to be created, this contains the name of the source PVC from which this snapshot was (or will be) created. + jsonPath: .spec.source.persistentVolumeClaimName + name: SourcePVC + type: string + - description: If a snapshot already exists, this contains the name of the existing VolumeSnapshotContent object representing the existing snapshot. + jsonPath: .spec.source.volumeSnapshotContentName + name: SourceSnapshotContent + type: string + - description: Represents the minimum size of volume required to rehydrate from this snapshot. + jsonPath: .status.restoreSize + name: RestoreSize + type: string + - description: The name of the VolumeSnapshotClass requested by the VolumeSnapshot. + jsonPath: .spec.volumeSnapshotClassName + name: SnapshotClass + type: string + - description: Name of the VolumeSnapshotContent object to which the VolumeSnapshot object intends to bind to. Please note that verification of binding actually requires checking both VolumeSnapshot and VolumeSnapshotContent to ensure both are pointing at each other. Binding MUST be verified prior to usage of this object. + jsonPath: .status.boundVolumeSnapshotContentName + name: SnapshotContent + type: string + - description: Timestamp when the point-in-time snapshot was taken by the underlying storage system. + jsonPath: .status.creationTime + name: CreationTime + type: date + - jsonPath: .metadata.creationTimestamp + name: Age + type: date + name: v1beta1 + # This indicates the v1beta1 version of the custom resource is deprecated. + # API requests to this version receive a warning in the server response. + deprecated: true + # This overrides the default warning returned to clients making v1beta1 API requests. + deprecationWarning: "snapshot.storage.k8s.io/v1beta1 VolumeSnapshot is deprecated; use snapshot.storage.k8s.io/v1 VolumeSnapshot" + schema: + openAPIV3Schema: + description: VolumeSnapshot is a user's request for either creating a point-in-time snapshot of a persistent volume, or binding to a pre-existing snapshot. + 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 + spec: + description: 'spec defines the desired characteristics of a snapshot requested by a user. More info: https://kubernetes.io/docs/concepts/storage/volume-snapshots#volumesnapshots Required.' + properties: + source: + description: source specifies where a snapshot will be created from. This field is immutable after creation. Required. + properties: + persistentVolumeClaimName: + description: persistentVolumeClaimName specifies the name of the PersistentVolumeClaim object representing the volume from which a snapshot should be created. This PVC is assumed to be in the same namespace as the VolumeSnapshot object. This field should be set if the snapshot does not exists, and needs to be created. This field is immutable. + type: string + volumeSnapshotContentName: + description: volumeSnapshotContentName specifies the name of a pre-existing VolumeSnapshotContent object representing an existing volume snapshot. This field should be set if the snapshot already exists and only needs a representation in Kubernetes. This field is immutable. + type: string + type: object + volumeSnapshotClassName: + description: 'VolumeSnapshotClassName is the name of the VolumeSnapshotClass requested by the VolumeSnapshot. VolumeSnapshotClassName may be left nil to indicate that the default SnapshotClass should be used. A given cluster may have multiple default Volume SnapshotClasses: one default per CSI Driver. If a VolumeSnapshot does not specify a SnapshotClass, VolumeSnapshotSource will be checked to figure out what the associated CSI Driver is, and the default VolumeSnapshotClass associated with that CSI Driver will be used. If more than one VolumeSnapshotClass exist for a given CSI Driver and more than one have been marked as default, CreateSnapshot will fail and generate an event. Empty string is not allowed for this field.' + type: string + required: + - source + type: object + status: + description: status represents the current information of a snapshot. Consumers must verify binding between VolumeSnapshot and VolumeSnapshotContent objects is successful (by validating that both VolumeSnapshot and VolumeSnapshotContent point at each other) before using this object. + properties: + boundVolumeSnapshotContentName: + description: 'boundVolumeSnapshotContentName is the name of the VolumeSnapshotContent object to which this VolumeSnapshot object intends to bind to. If not specified, it indicates that the VolumeSnapshot object has not been successfully bound to a VolumeSnapshotContent object yet. NOTE: To avoid possible security issues, consumers must verify binding between VolumeSnapshot and VolumeSnapshotContent objects is successful (by validating that both VolumeSnapshot and VolumeSnapshotContent point at each other) before using this object.' + type: string + creationTime: + description: creationTime is the timestamp when the point-in-time snapshot is taken by the underlying storage system. In dynamic snapshot creation case, this field will be filled in by the snapshot controller with the "creation_time" value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing snapshot, this field will be filled with the "creation_time" value returned from the CSI "ListSnapshots" gRPC call if the driver supports it. If not specified, it may indicate that the creation time of the snapshot is unknown. + format: date-time + type: string + error: + description: error is the last observed error during snapshot creation, if any. This field could be helpful to upper level controllers(i.e., application controller) to decide whether they should continue on waiting for the snapshot to be created based on the type of error reported. The snapshot controller will keep retrying when an error occurs during the snapshot creation. Upon success, this error field will be cleared. + properties: + message: + description: 'message is a string detailing the encountered error during snapshot creation if specified. NOTE: message may be logged, and it should not contain sensitive information.' + type: string + time: + description: time is the timestamp when the error was encountered. + format: date-time + type: string + type: object + readyToUse: + description: readyToUse indicates if the snapshot is ready to be used to restore a volume. In dynamic snapshot creation case, this field will be filled in by the snapshot controller with the "ready_to_use" value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing snapshot, this field will be filled with the "ready_to_use" value returned from the CSI "ListSnapshots" gRPC call if the driver supports it, otherwise, this field will be set to "True". If not specified, it means the readiness of a snapshot is unknown. + type: boolean + restoreSize: + type: string + description: restoreSize represents the minimum size of volume required to create a volume from this snapshot. In dynamic snapshot creation case, this field will be filled in by the snapshot controller with the "size_bytes" value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing snapshot, this field will be filled with the "size_bytes" value returned from the CSI "ListSnapshots" gRPC call if the driver supports it. When restoring a volume from this snapshot, the size of the volume MUST NOT be smaller than the restoreSize if it is specified, otherwise the restoration will fail. If not specified, it indicates that the size is unknown. + pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ + x-kubernetes-int-or-string: true + type: object + required: + - spec + type: object + served: false + storage: false + subresources: + status: {} +status: + acceptedNames: + kind: "" + plural: "" + conditions: [] + storedVersions: [] +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + annotations: + controller-gen.kubebuilder.io/version: v0.8.0 + api-approved.kubernetes.io: "https://github.com/kubernetes-csi/external-snapshotter/pull/665" + creationTimestamp: null + name: volumesnapshotclasses.snapshot.storage.k8s.io +spec: + group: snapshot.storage.k8s.io + names: + kind: VolumeSnapshotClass + listKind: VolumeSnapshotClassList + plural: volumesnapshotclasses + shortNames: + - vsclass + - vsclasses + singular: volumesnapshotclass + scope: Cluster + versions: + - additionalPrinterColumns: + - jsonPath: .driver + name: Driver + type: string + - description: Determines whether a VolumeSnapshotContent created through the + VolumeSnapshotClass should be deleted when its bound VolumeSnapshot is deleted. + jsonPath: .deletionPolicy + name: DeletionPolicy + type: string + - jsonPath: .metadata.creationTimestamp + name: Age + type: date + name: v1 + schema: + openAPIV3Schema: + description: VolumeSnapshotClass specifies parameters that a underlying storage + system uses when creating a volume snapshot. A specific VolumeSnapshotClass + is used by specifying its name in a VolumeSnapshot object. VolumeSnapshotClasses + are non-namespaced + 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 + deletionPolicy: + description: deletionPolicy determines whether a VolumeSnapshotContent + created through the VolumeSnapshotClass should be deleted when its bound + VolumeSnapshot is deleted. Supported values are "Retain" and "Delete". + "Retain" means that the VolumeSnapshotContent and its physical snapshot + on underlying storage system are kept. "Delete" means that the VolumeSnapshotContent + and its physical snapshot on underlying storage system are deleted. + Required. + enum: + - Delete + - Retain + type: string + driver: + description: driver is the name of the storage driver that handles this + VolumeSnapshotClass. Required. + 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 + parameters: + additionalProperties: + type: string + description: parameters is a key-value map with storage driver specific + parameters for creating snapshots. These values are opaque to Kubernetes. + type: object + required: + - deletionPolicy + - driver + type: object + served: true + storage: true + subresources: {} + - additionalPrinterColumns: + - jsonPath: .driver + name: Driver + type: string + - description: Determines whether a VolumeSnapshotContent created through the VolumeSnapshotClass should be deleted when its bound VolumeSnapshot is deleted. + jsonPath: .deletionPolicy + name: DeletionPolicy + type: string + - jsonPath: .metadata.creationTimestamp + name: Age + type: date + name: v1beta1 + # This indicates the v1beta1 version of the custom resource is deprecated. + # API requests to this version receive a warning in the server response. + deprecated: true + # This overrides the default warning returned to clients making v1beta1 API requests. + deprecationWarning: "snapshot.storage.k8s.io/v1beta1 VolumeSnapshotClass is deprecated; use snapshot.storage.k8s.io/v1 VolumeSnapshotClass" + schema: + openAPIV3Schema: + description: VolumeSnapshotClass specifies parameters that a underlying storage system uses when creating a volume snapshot. A specific VolumeSnapshotClass is used by specifying its name in a VolumeSnapshot object. VolumeSnapshotClasses are non-namespaced + 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 + deletionPolicy: + description: deletionPolicy determines whether a VolumeSnapshotContent created through the VolumeSnapshotClass should be deleted when its bound VolumeSnapshot is deleted. Supported values are "Retain" and "Delete". "Retain" means that the VolumeSnapshotContent and its physical snapshot on underlying storage system are kept. "Delete" means that the VolumeSnapshotContent and its physical snapshot on underlying storage system are deleted. Required. + enum: + - Delete + - Retain + type: string + driver: + description: driver is the name of the storage driver that handles this VolumeSnapshotClass. Required. + 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 + parameters: + additionalProperties: + type: string + description: parameters is a key-value map with storage driver specific parameters for creating snapshots. These values are opaque to Kubernetes. + type: object + required: + - deletionPolicy + - driver + type: object + served: false + storage: false + subresources: {} +status: + acceptedNames: + kind: "" + plural: "" + conditions: [] + storedVersions: [] +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + annotations: + controller-gen.kubebuilder.io/version: v0.8.0 + api-approved.kubernetes.io: "https://github.com/kubernetes-csi/external-snapshotter/pull/665" + creationTimestamp: null + name: volumesnapshotcontents.snapshot.storage.k8s.io +spec: + group: snapshot.storage.k8s.io + names: + kind: VolumeSnapshotContent + listKind: VolumeSnapshotContentList + plural: volumesnapshotcontents + shortNames: + - vsc + - vscs + singular: volumesnapshotcontent + scope: Cluster + versions: + - additionalPrinterColumns: + - description: Indicates if the snapshot is ready to be used to restore a volume. + jsonPath: .status.readyToUse + name: ReadyToUse + type: boolean + - description: Represents the complete size of the snapshot in bytes + jsonPath: .status.restoreSize + name: RestoreSize + type: integer + - description: Determines whether this VolumeSnapshotContent and its physical + snapshot on the underlying storage system should be deleted when its bound + VolumeSnapshot is deleted. + jsonPath: .spec.deletionPolicy + name: DeletionPolicy + type: string + - description: Name of the CSI driver used to create the physical snapshot on + the underlying storage system. + jsonPath: .spec.driver + name: Driver + type: string + - description: Name of the VolumeSnapshotClass to which this snapshot belongs. + jsonPath: .spec.volumeSnapshotClassName + name: VolumeSnapshotClass + type: string + - description: Name of the VolumeSnapshot object to which this VolumeSnapshotContent + object is bound. + jsonPath: .spec.volumeSnapshotRef.name + name: VolumeSnapshot + type: string + - description: Namespace of the VolumeSnapshot object to which this VolumeSnapshotContent object is bound. + jsonPath: .spec.volumeSnapshotRef.namespace + name: VolumeSnapshotNamespace + type: string + - jsonPath: .metadata.creationTimestamp + name: Age + type: date + name: v1 + schema: + openAPIV3Schema: + description: VolumeSnapshotContent represents the actual "on-disk" snapshot + object in the underlying storage system + 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 + spec: + description: spec defines properties of a VolumeSnapshotContent created + by the underlying storage system. Required. + properties: + deletionPolicy: + description: deletionPolicy determines whether this VolumeSnapshotContent + and its physical snapshot on the underlying storage system should + be deleted when its bound VolumeSnapshot is deleted. Supported values + are "Retain" and "Delete". "Retain" means that the VolumeSnapshotContent + and its physical snapshot on underlying storage system are kept. + "Delete" means that the VolumeSnapshotContent and its physical snapshot + on underlying storage system are deleted. For dynamically provisioned + snapshots, this field will automatically be filled in by the CSI + snapshotter sidecar with the "DeletionPolicy" field defined in the + corresponding VolumeSnapshotClass. For pre-existing snapshots, users + MUST specify this field when creating the VolumeSnapshotContent + object. Required. + enum: + - Delete + - Retain + type: string + driver: + description: driver is the name of the CSI driver used to create the + physical snapshot on the underlying storage system. This MUST be + the same as the name returned by the CSI GetPluginName() call for + that driver. Required. + type: string + source: + description: source specifies whether the snapshot is (or should be) + dynamically provisioned or already exists, and just requires a Kubernetes + object representation. This field is immutable after creation. Required. + properties: + snapshotHandle: + description: snapshotHandle specifies the CSI "snapshot_id" of + a pre-existing snapshot on the underlying storage system for + which a Kubernetes object representation was (or should be) + created. This field is immutable. + type: string + volumeHandle: + description: volumeHandle specifies the CSI "volume_id" of the + volume from which a snapshot should be dynamically taken from. + This field is immutable. + type: string + type: object + oneOf: + - required: ["snapshotHandle"] + - required: ["volumeHandle"] + sourceVolumeMode: + description: SourceVolumeMode is the mode of the volume whose snapshot + is taken. Can be either “Filesystem” or “Block”. If not specified, + it indicates the source volume's mode is unknown. This field is + immutable. This field is an alpha field. + type: string + volumeSnapshotClassName: + description: name of the VolumeSnapshotClass from which this snapshot + was (or will be) created. Note that after provisioning, the VolumeSnapshotClass + may be deleted or recreated with different set of values, and as + such, should not be referenced post-snapshot creation. + type: string + volumeSnapshotRef: + description: volumeSnapshotRef specifies the VolumeSnapshot object + to which this VolumeSnapshotContent object is bound. VolumeSnapshot.Spec.VolumeSnapshotContentName + field must reference to this VolumeSnapshotContent's name for the + bidirectional binding to be valid. For a pre-existing VolumeSnapshotContent + object, name and namespace of the VolumeSnapshot object MUST be + provided for binding to happen. This field is immutable after creation. + Required. + properties: + apiVersion: + description: API version of the referent. + type: string + fieldPath: + description: 'If referring to a piece of an object instead of + an entire object, this string should contain a valid JSON/Go + field access statement, such as desiredState.manifest.containers[2]. + For example, if the object reference is to a container within + a pod, this would take on a value like: "spec.containers{name}" + (where "name" refers to the name of the container that triggered + the event) or if no container name is specified "spec.containers[2]" + (container with index 2 in this pod). This syntax is chosen + only to have some well-defined way of referencing a part of + an object. TODO: this design is not final and this field is + subject to change in the future.' + type: string + kind: + description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + name: + description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names' + type: string + namespace: + description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/' + type: string + resourceVersion: + description: 'Specific resourceVersion to which this reference + is made, if any. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency' + type: string + uid: + description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids' + type: string + type: object + required: + - deletionPolicy + - driver + - source + - volumeSnapshotRef + type: object + status: + description: status represents the current information of a snapshot. + properties: + creationTime: + description: creationTime is the timestamp when the point-in-time + snapshot is taken by the underlying storage system. In dynamic snapshot + creation case, this field will be filled in by the CSI snapshotter + sidecar with the "creation_time" value returned from CSI "CreateSnapshot" + gRPC call. For a pre-existing snapshot, this field will be filled + with the "creation_time" value returned from the CSI "ListSnapshots" + gRPC call if the driver supports it. If not specified, it indicates + the creation time is unknown. The format of this field is a Unix + nanoseconds time encoded as an int64. On Unix, the command `date + +%s%N` returns the current time in nanoseconds since 1970-01-01 + 00:00:00 UTC. + format: int64 + type: integer + error: + description: error is the last observed error during snapshot creation, + if any. Upon success after retry, this error field will be cleared. + properties: + message: + description: 'message is a string detailing the encountered error + during snapshot creation if specified. NOTE: message may be + logged, and it should not contain sensitive information.' + type: string + time: + description: time is the timestamp when the error was encountered. + format: date-time + type: string + type: object + readyToUse: + description: readyToUse indicates if a snapshot is ready to be used + to restore a volume. In dynamic snapshot creation case, this field + will be filled in by the CSI snapshotter sidecar with the "ready_to_use" + value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing + snapshot, this field will be filled with the "ready_to_use" value + returned from the CSI "ListSnapshots" gRPC call if the driver supports + it, otherwise, this field will be set to "True". If not specified, + it means the readiness of a snapshot is unknown. + type: boolean + restoreSize: + description: restoreSize represents the complete size of the snapshot + in bytes. In dynamic snapshot creation case, this field will be + filled in by the CSI snapshotter sidecar with the "size_bytes" value + returned from CSI "CreateSnapshot" gRPC call. For a pre-existing + snapshot, this field will be filled with the "size_bytes" value + returned from the CSI "ListSnapshots" gRPC call if the driver supports + it. When restoring a volume from this snapshot, the size of the + volume MUST NOT be smaller than the restoreSize if it is specified, + otherwise the restoration will fail. If not specified, it indicates + that the size is unknown. + format: int64 + minimum: 0 + type: integer + snapshotHandle: + description: snapshotHandle is the CSI "snapshot_id" of a snapshot + on the underlying storage system. If not specified, it indicates + that dynamic snapshot creation has either failed or it is still + in progress. + type: string + type: object + required: + - spec + type: object + served: true + storage: true + subresources: + status: {} + - additionalPrinterColumns: + - description: Indicates if the snapshot is ready to be used to restore a volume. + jsonPath: .status.readyToUse + name: ReadyToUse + type: boolean + - description: Represents the complete size of the snapshot in bytes + jsonPath: .status.restoreSize + name: RestoreSize + type: integer + - description: Determines whether this VolumeSnapshotContent and its physical snapshot on the underlying storage system should be deleted when its bound VolumeSnapshot is deleted. + jsonPath: .spec.deletionPolicy + name: DeletionPolicy + type: string + - description: Name of the CSI driver used to create the physical snapshot on the underlying storage system. + jsonPath: .spec.driver + name: Driver + type: string + - description: Name of the VolumeSnapshotClass to which this snapshot belongs. + jsonPath: .spec.volumeSnapshotClassName + name: VolumeSnapshotClass + type: string + - description: Name of the VolumeSnapshot object to which this VolumeSnapshotContent object is bound. + jsonPath: .spec.volumeSnapshotRef.name + name: VolumeSnapshot + type: string + - description: Namespace of the VolumeSnapshot object to which this VolumeSnapshotContent object is bound. + jsonPath: .spec.volumeSnapshotRef.namespace + name: VolumeSnapshotNamespace + type: string + - jsonPath: .metadata.creationTimestamp + name: Age + type: date + name: v1beta1 + # This indicates the v1beta1 version of the custom resource is deprecated. + # API requests to this version receive a warning in the server response. + deprecated: true + # This overrides the default warning returned to clients making v1beta1 API requests. + deprecationWarning: "snapshot.storage.k8s.io/v1beta1 VolumeSnapshotContent is deprecated; use snapshot.storage.k8s.io/v1 VolumeSnapshotContent" + schema: + openAPIV3Schema: + description: VolumeSnapshotContent represents the actual "on-disk" snapshot object in the underlying storage system + 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 + spec: + description: spec defines properties of a VolumeSnapshotContent created by the underlying storage system. Required. + properties: + deletionPolicy: + description: deletionPolicy determines whether this VolumeSnapshotContent and its physical snapshot on the underlying storage system should be deleted when its bound VolumeSnapshot is deleted. Supported values are "Retain" and "Delete". "Retain" means that the VolumeSnapshotContent and its physical snapshot on underlying storage system are kept. "Delete" means that the VolumeSnapshotContent and its physical snapshot on underlying storage system are deleted. For dynamically provisioned snapshots, this field will automatically be filled in by the CSI snapshotter sidecar with the "DeletionPolicy" field defined in the corresponding VolumeSnapshotClass. For pre-existing snapshots, users MUST specify this field when creating the VolumeSnapshotContent object. Required. + enum: + - Delete + - Retain + type: string + driver: + description: driver is the name of the CSI driver used to create the physical snapshot on the underlying storage system. This MUST be the same as the name returned by the CSI GetPluginName() call for that driver. Required. + type: string + source: + description: source specifies whether the snapshot is (or should be) dynamically provisioned or already exists, and just requires a Kubernetes object representation. This field is immutable after creation. Required. + properties: + snapshotHandle: + description: snapshotHandle specifies the CSI "snapshot_id" of a pre-existing snapshot on the underlying storage system for which a Kubernetes object representation was (or should be) created. This field is immutable. + type: string + volumeHandle: + description: volumeHandle specifies the CSI "volume_id" of the volume from which a snapshot should be dynamically taken from. This field is immutable. + type: string + type: object + volumeSnapshotClassName: + description: name of the VolumeSnapshotClass from which this snapshot was (or will be) created. Note that after provisioning, the VolumeSnapshotClass may be deleted or recreated with different set of values, and as such, should not be referenced post-snapshot creation. + type: string + volumeSnapshotRef: + description: volumeSnapshotRef specifies the VolumeSnapshot object to which this VolumeSnapshotContent object is bound. VolumeSnapshot.Spec.VolumeSnapshotContentName field must reference to this VolumeSnapshotContent's name for the bidirectional binding to be valid. For a pre-existing VolumeSnapshotContent object, name and namespace of the VolumeSnapshot object MUST be provided for binding to happen. This field is immutable after creation. Required. + properties: + apiVersion: + description: API version of the referent. + type: string + fieldPath: + description: 'If referring to a piece of an object instead of an entire object, this string should contain a valid JSON/Go field access statement, such as desiredState.manifest.containers[2]. For example, if the object reference is to a container within a pod, this would take on a value like: "spec.containers{name}" (where "name" refers to the name of the container that triggered the event) or if no container name is specified "spec.containers[2]" (container with index 2 in this pod). This syntax is chosen only to have some well-defined way of referencing a part of an object. TODO: this design is not final and this field is subject to change in the future.' + type: string + kind: + description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + name: + description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names' + type: string + namespace: + description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/' + type: string + resourceVersion: + description: 'Specific resourceVersion to which this reference is made, if any. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency' + type: string + uid: + description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids' + type: string + type: object + required: + - deletionPolicy + - driver + - source + - volumeSnapshotRef + type: object + status: + description: status represents the current information of a snapshot. + properties: + creationTime: + description: creationTime is the timestamp when the point-in-time snapshot is taken by the underlying storage system. In dynamic snapshot creation case, this field will be filled in by the CSI snapshotter sidecar with the "creation_time" value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing snapshot, this field will be filled with the "creation_time" value returned from the CSI "ListSnapshots" gRPC call if the driver supports it. If not specified, it indicates the creation time is unknown. The format of this field is a Unix nanoseconds time encoded as an int64. On Unix, the command `date +%s%N` returns the current time in nanoseconds since 1970-01-01 00:00:00 UTC. + format: int64 + type: integer + error: + description: error is the last observed error during snapshot creation, if any. Upon success after retry, this error field will be cleared. + properties: + message: + description: 'message is a string detailing the encountered error during snapshot creation if specified. NOTE: message may be logged, and it should not contain sensitive information.' + type: string + time: + description: time is the timestamp when the error was encountered. + format: date-time + type: string + type: object + readyToUse: + description: readyToUse indicates if a snapshot is ready to be used to restore a volume. In dynamic snapshot creation case, this field will be filled in by the CSI snapshotter sidecar with the "ready_to_use" value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing snapshot, this field will be filled with the "ready_to_use" value returned from the CSI "ListSnapshots" gRPC call if the driver supports it, otherwise, this field will be set to "True". If not specified, it means the readiness of a snapshot is unknown. + type: boolean + restoreSize: + description: restoreSize represents the complete size of the snapshot in bytes. In dynamic snapshot creation case, this field will be filled in by the CSI snapshotter sidecar with the "size_bytes" value returned from CSI "CreateSnapshot" gRPC call. For a pre-existing snapshot, this field will be filled with the "size_bytes" value returned from the CSI "ListSnapshots" gRPC call if the driver supports it. When restoring a volume from this snapshot, the size of the volume MUST NOT be smaller than the restoreSize if it is specified, otherwise the restoration will fail. If not specified, it indicates that the size is unknown. + format: int64 + minimum: 0 + type: integer + snapshotHandle: + description: snapshotHandle is the CSI "snapshot_id" of a snapshot on the underlying storage system. If not specified, it indicates that dynamic snapshot creation has either failed or it is still in progress. + type: string + type: object + required: + - spec + type: object + served: false + storage: false + subresources: + status: {} +status: + acceptedNames: + kind: "" + plural: "" + conditions: [] + storedVersions: [] +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-controller.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-controller.yaml new file mode 100644 index 0000000000..1ef3101ec1 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-controller.yaml @@ -0,0 +1,272 @@ +kind: Deployment +apiVersion: apps/v1 +metadata: + name: {{ .Values.controller.name }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Values.controller.name }} + {{- include "azurefile.labels" . | nindent 4 }} +{{- with .Values.controller.labels }} +{{ . | toYaml | indent 4 }} +{{- end }} +{{- with .Values.controller.annotations }} + annotations: +{{ . | toYaml | indent 4 }} +{{- end }} +spec: + replicas: {{ .Values.controller.replicas }} + selector: + matchLabels: + {{- include "azurefile.selectorLabels" . | nindent 6 }} + app: {{ .Values.controller.name }} + strategy: + type: {{ .Values.controller.strategyType }} + template: + metadata: + labels: + {{- include "azurefile.labels" . | nindent 8 }} + app: {{ .Values.controller.name }} + {{- if .Values.workloadIdentity.clientID }} + azure.workload.identity/use: "true" + {{- end }} +{{- with .Values.controller.podLabels }} +{{ toYaml . | indent 8 }} +{{- end }} +{{- with .Values.controller.podAnnotations }} + annotations: +{{ toYaml . | indent 8 }} +{{- end }} + spec: + hostNetwork: {{ .Values.controller.hostNetwork }} + serviceAccountName: {{ .Values.serviceAccount.controller }} + nodeSelector: + kubernetes.io/os: linux +{{- with .Values.controller.nodeSelector }} +{{ toYaml . | indent 8 }} +{{- end }} + # runOnControlPlane=true or runOnMaster=true only takes effect if affinity is not set + {{- if contains (tpl "{{ .Values.controller.affinity }}" .) "nodeSelectorTerms" }} + {{- with .Values.controller.affinity }} + affinity: + {{ toYaml . | indent 8 }} + {{- end }} + {{- else if or .Values.controller.runOnControlPlane .Values.controller.runOnMaster}} + affinity: + nodeAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + nodeSelectorTerms: + - matchExpressions: + {{- if .Values.controller.runOnControlPlane}} + - key: node-role.kubernetes.io/control-plane + operator: Exists + {{- end}} + {{- if .Values.controller.runOnMaster}} + - key: node-role.kubernetes.io/master + operator: Exists + {{- end}} + {{- end }} + priorityClassName: system-cluster-critical +{{- with .Values.controller.tolerations }} + tolerations: +{{ toYaml . | indent 8 }} +{{- end }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: +{{ toYaml .Values.imagePullSecrets | indent 8 }} + {{- end }} + containers: + - name: csi-provisioner +{{- if hasPrefix "/" .Values.image.csiProvisioner.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.csiProvisioner.repository }}:{{ .Values.image.csiProvisioner.tag }}" +{{- else }} + image: "{{ .Values.image.csiProvisioner.repository }}:{{ .Values.image.csiProvisioner.tag }}" +{{- end }} + args: + - "-v=2" + - "--csi-address=$(ADDRESS)" + - "--leader-election" + - "--leader-election-namespace={{ .Release.Namespace }}" + - "--timeout=1200s" + - "--extra-create-metadata=true" + - "--kube-api-qps=50" + - "--kube-api-burst=100" + - "--feature-gates=HonorPVReclaimPolicy=true" + - "--retry-interval-max=30m" + env: + - name: ADDRESS + value: /csi/csi.sock + imagePullPolicy: {{ .Values.image.csiProvisioner.pullPolicy }} + volumeMounts: + - mountPath: /csi + name: socket-dir + resources: {{- toYaml .Values.controller.resources.csiProvisioner | nindent 12 }} + - name: csi-snapshotter +{{- if hasPrefix "/" .Values.snapshot.image.csiSnapshotter.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.snapshot.image.csiSnapshotter.repository }}:{{ .Values.snapshot.image.csiSnapshotter.tag }}" +{{- else }} + image: "{{ .Values.snapshot.image.csiSnapshotter.repository }}:{{ .Values.snapshot.image.csiSnapshotter.tag }}" +{{- end }} + args: + - "-csi-address=$(ADDRESS)" + - "-leader-election" + - "--leader-election-namespace={{ .Release.Namespace }}" + - "-v=2" + - "--retry-interval-max=30m" + env: + - name: ADDRESS + value: /csi/csi.sock + volumeMounts: + - name: socket-dir + mountPath: /csi + resources: {{- toYaml .Values.controller.resources.csiSnapshotter | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: csi-resizer +{{- if hasPrefix "/" .Values.image.csiResizer.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.csiResizer.repository }}:{{ .Values.image.csiResizer.tag }}" +{{- else }} + image: "{{ .Values.image.csiResizer.repository }}:{{ .Values.image.csiResizer.tag }}" +{{- end }} + args: + - "-csi-address=$(ADDRESS)" + - "-v=2" + - "-leader-election" + - "--leader-election-namespace={{ .Release.Namespace }}" + - '-handle-volume-inuse-error=false' + - '-timeout=120s' + - '-feature-gates=RecoverVolumeExpansionFailure=true' + - "--retry-interval-max=30m" + env: + - name: ADDRESS + value: /csi/csi.sock + imagePullPolicy: {{ .Values.image.csiResizer.pullPolicy }} + volumeMounts: + - name: socket-dir + mountPath: /csi + resources: {{- toYaml .Values.controller.resources.csiResizer | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: liveness-probe +{{- if hasPrefix "/" .Values.image.livenessProbe.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.livenessProbe.repository }}:{{ .Values.image.livenessProbe.tag }}" +{{- else }} + image: "{{ .Values.image.livenessProbe.repository }}:{{ .Values.image.livenessProbe.tag }}" +{{- end }} + args: + - --csi-address=/csi/csi.sock + - --probe-timeout=3s +{{- if eq .Values.controller.hostNetwork true }} + - --http-endpoint=localhost:{{ .Values.controller.livenessProbe.healthPort }} +{{- else }} + - --health-port={{ .Values.controller.livenessProbe.healthPort }} +{{- end }} + - --v=2 + imagePullPolicy: {{ .Values.image.livenessProbe.pullPolicy }} + volumeMounts: + - name: socket-dir + mountPath: /csi + resources: {{- toYaml .Values.controller.resources.livenessProbe | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: azurefile +{{- if hasPrefix "/" .Values.image.azurefile.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}" +{{- else }} + image: "{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}" +{{- end }} + args: + - "--v={{ .Values.controller.logLevel }}" + - "--endpoint=$(CSI_ENDPOINT)" + - "--metrics-address=0.0.0.0:{{ .Values.controller.metricsPort }}" + - "--kubeconfig={{ .Values.controller.kubeconfig }}" + - "--drivername={{ .Values.driver.name }}" + - "--cloud-config-secret-name={{ .Values.controller.cloudConfigSecretName }}" + - "--cloud-config-secret-namespace={{ .Values.controller.cloudConfigSecretNamespace }}" + - "--custom-user-agent={{ .Values.driver.customUserAgent }}" + - "--user-agent-suffix={{ .Values.driver.userAgentSuffix }}" + - "--allow-empty-cloud-config={{ .Values.controller.allowEmptyCloudConfig }}" + ports: + - containerPort: {{ .Values.controller.metricsPort }} + name: metrics + protocol: TCP +{{- if ne .Values.controller.hostNetwork true }} + - containerPort: {{ .Values.controller.livenessProbe.healthPort }} + name: healthz + protocol: TCP +{{- end }} + livenessProbe: + failureThreshold: 5 + httpGet: + path: /healthz +{{- if eq .Values.controller.hostNetwork true }} + host: localhost + port: {{ .Values.controller.livenessProbe.healthPort }} +{{- else }} + port: healthz +{{- end }} + initialDelaySeconds: 30 + timeoutSeconds: 10 + periodSeconds: 30 + env: + - name: AZURE_CREDENTIAL_FILE + valueFrom: + configMapKeyRef: + name: {{ .Values.azureCredentialFileConfigMap }} + key: path + optional: true + - name: CSI_ENDPOINT + value: unix:///csi/csi.sock + {{- if ne .Values.driver.httpsProxy "" }} + - name: HTTPS_PROXY + value: {{ .Values.driver.httpsProxy }} + {{- end }} + {{- if ne .Values.driver.httpProxy "" }} + - name: HTTP_PROXY + value: {{ .Values.driver.httpProxy }} + {{- end }} + - name: AZURE_GO_SDK_LOG_LEVEL + value: {{ .Values.driver.azureGoSDKLogLevel }} + imagePullPolicy: {{ .Values.image.azurefile.pullPolicy }} + volumeMounts: + - mountPath: /csi + name: socket-dir + - mountPath: /root/.azcopy + name: azcopy-dir + - mountPath: /etc/kubernetes/ + name: azure-cred + {{- if eq .Values.linux.distro "fedora" }} + - name: ssl + mountPath: /etc/ssl/certs + readOnly: true + - name: ssl-pki + mountPath: /etc/pki/ca-trust/extracted + readOnly: true + {{- end }} + resources: {{- toYaml .Values.controller.resources.azurefile | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + volumes: + - name: socket-dir + emptyDir: {} + - name: azcopy-dir + emptyDir: {} + - name: azure-cred + hostPath: + path: /etc/kubernetes/ + type: DirectoryOrCreate + {{- if eq .Values.linux.distro "fedora" }} + - name: ssl + hostPath: + path: /etc/ssl/certs + - name: ssl-pki + hostPath: + path: /etc/pki/ca-trust/extracted + {{- end }} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-driver.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-driver.yaml new file mode 100644 index 0000000000..77df01e32d --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-driver.yaml @@ -0,0 +1,19 @@ +--- +apiVersion: storage.k8s.io/v1 +kind: CSIDriver +metadata: + name: {{ .Values.driver.name }} + labels: + {{- include "azurefile.labels" . | nindent 4 }} + annotations: + csiDriver: "{{ .Values.image.azurefile.tag }}" + snapshot: "{{ .Values.snapshot.image.csiSnapshotter.tag }}" +spec: + attachRequired: {{ .Values.controller.attachRequired }} + podInfoOnMount: true + volumeLifecycleModes: + - Persistent + - Ephemeral + fsGroupPolicy: {{ .Values.feature.fsGroupPolicy }} + tokenRequests: + - audience: api://AzureADTokenExchange diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows-hostprocess.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows-hostprocess.yaml new file mode 100644 index 0000000000..30acee27fb --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows-hostprocess.yaml @@ -0,0 +1,164 @@ +{{- if and .Values.windows.enabled .Values.windows.useHostProcessContainers }} +kind: DaemonSet +apiVersion: apps/v1 +metadata: + name: {{ .Values.windows.dsName }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Values.windows.dsName }} + {{- include "azurefile.labels" . | nindent 4 }} +{{- with .Values.windows.labels }} +{{ . | toYaml | indent 4 }} +{{- end }} +{{- with .Values.windows.annotations }} + annotations: +{{ . | toYaml | indent 4 }} +{{- end }} +spec: + updateStrategy: + rollingUpdate: + maxUnavailable: {{ .Values.node.maxUnavailable }} + type: {{ .Values.node.strategyType }} + selector: + matchLabels: + app: {{ .Values.windows.dsName }} + {{- include "azurefile.selectorLabels" . | nindent 6 }} + template: + metadata: + labels: + app: {{ .Values.windows.dsName }} + {{- include "azurefile.labels" . | nindent 8 }} +{{- with .Values.windows.podLabels }} +{{ toYaml . | indent 8 }} +{{- end }} +{{- with .Values.windows.podAnnotations }} + annotations: +{{ toYaml . | indent 8 }} +{{- end }} + spec: + serviceAccountName: {{ .Values.serviceAccount.node }} +{{- with .Values.windows.tolerations }} + tolerations: +{{ toYaml . | indent 8 }} +{{- end }} + nodeSelector: + kubernetes.io/os: windows +{{- with .Values.windows.nodeSelector }} +{{ toYaml . | indent 8 }} +{{- end }} + affinity: +{{- with .Values.windows.affinity }} +{{ toYaml . | indent 8 }} +{{- end }} + nodeAffinity: +{{ toYaml .Values.windows.nodeAffinity | indent 10 }} + priorityClassName: system-node-critical + {{- if .Values.imagePullSecrets }} + imagePullSecrets: +{{ toYaml .Values.imagePullSecrets | indent 8 }} + {{- end }} + securityContext: + seccompProfile: + type: RuntimeDefault + windowsOptions: + hostProcess: true + runAsUserName: "NT AUTHORITY\\SYSTEM" + hostNetwork: true + initContainers: + - name: init +{{- if hasPrefix "/" .Values.image.azurefile.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}-windows-hp" +{{- else }} + image: "{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}-windows-hp" +{{- end }} + imagePullPolicy: {{ .Values.image.pullPolicy }} + command: + - "powershell.exe" + - "-c" + - "New-Item -ItemType Directory -Path C:\\var\\lib\\kubelet\\plugins\\{{ .Values.driver.name }}\\ -Force" + securityContext: + capabilities: + drop: + - ALL + containers: + - name: node-driver-registrar +{{- if hasPrefix "/" .Values.image.nodeDriverRegistrar.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.nodeDriverRegistrar.repository }}:{{ .Values.image.nodeDriverRegistrar.tag }}" +{{- else }} + image: "{{ .Values.image.nodeDriverRegistrar.repository }}:{{ .Values.image.nodeDriverRegistrar.tag }}" +{{- end }} + command: + - "csi-node-driver-registrar.exe" + args: + - "--csi-address=$(CSI_ENDPOINT)" + - "--kubelet-registration-path=$(DRIVER_REG_SOCK_PATH)" + - "--plugin-registration-path=$(PLUGIN_REG_DIR)" + - "--v=2" + env: + - name: CSI_ENDPOINT + value: unix://{{ .Values.windows.kubelet }}\plugins\{{ .Values.driver.name }}\csi.sock + - name: DRIVER_REG_SOCK_PATH + value: C:\\var\\lib\\kubelet\\plugins\\{{ .Values.driver.name }}\\csi.sock + - name: PLUGIN_REG_DIR + value: C:\\var\\lib\\kubelet\\plugins_registry\\ + - name: KUBE_NODE_NAME + valueFrom: + fieldRef: + fieldPath: spec.nodeName + imagePullPolicy: {{ .Values.image.nodeDriverRegistrar.pullPolicy }} + resources: {{- toYaml .Values.windows.resources.nodeDriverRegistrar | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: azurefile +{{- if hasPrefix "/" .Values.image.azurefile.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}-windows-hp" +{{- else }} + image: "{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}-windows-hp" +{{- end }} + command: + - "azurefileplugin.exe" + args: + - "--v={{ .Values.node.logLevel }}" + - "--endpoint=$(CSI_ENDPOINT)" + - "--nodeid=$(KUBE_NODE_NAME)" + - "--kubeconfig={{ .Values.windows.kubeconfig }}" + - "--drivername={{ .Values.driver.name }}" + - "--cloud-config-secret-name={{ .Values.node.cloudConfigSecretName }}" + - "--cloud-config-secret-namespace={{ .Values.node.cloudConfigSecretNamespace }}" + - "--custom-user-agent={{ .Values.driver.customUserAgent }}" + - "--user-agent-suffix={{ .Values.driver.userAgentSuffix }}" + - "--allow-empty-cloud-config={{ .Values.node.allowEmptyCloudConfig }}" + - "--enable-get-volume-stats={{ .Values.feature.enableGetVolumeStats }}" + - "--enable-windows-host-process=true" + - "--metrics-address=0.0.0.0:{{ .Values.node.metricsPort }}" + env: + - name: AZURE_CREDENTIAL_FILE + valueFrom: + configMapKeyRef: + name: {{ .Values.azureCredentialFileConfigMap }} + key: path-windows + optional: true + - name: CSI_ENDPOINT + value: unix://{{ .Values.windows.kubelet }}\plugins\{{ .Values.driver.name }}\csi.sock + {{- if ne .Values.driver.httpsProxy "" }} + - name: HTTPS_PROXY + value: {{ .Values.driver.httpsProxy }} + {{- end }} + {{- if ne .Values.driver.httpProxy "" }} + - name: HTTP_PROXY + value: {{ .Values.driver.httpProxy }} + {{- end }} + - name: KUBE_NODE_NAME + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: spec.nodeName + imagePullPolicy: {{ .Values.image.pullPolicy }} + resources: {{- toYaml .Values.windows.resources.azurefile | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows.yaml new file mode 100644 index 0000000000..c8af9e986a --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node-windows.yaml @@ -0,0 +1,229 @@ +{{- if and .Values.windows.enabled (not .Values.windows.useHostProcessContainers) }} +kind: DaemonSet +apiVersion: apps/v1 +metadata: + name: {{ .Values.windows.dsName }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Values.windows.dsName }} + {{- include "azurefile.labels" . | nindent 4 }} +{{- with .Values.windows.labels }} +{{ . | toYaml | indent 4 }} +{{- end }} +{{- with .Values.windows.annotations }} + annotations: +{{ . | toYaml | indent 4 }} +{{- end }} +spec: + updateStrategy: + rollingUpdate: + maxUnavailable: {{ .Values.node.maxUnavailable }} + type: {{ .Values.node.strategyType }} + selector: + matchLabels: + app: {{ .Values.windows.dsName }} + {{- include "azurefile.selectorLabels" . | nindent 6 }} + template: + metadata: + labels: + app: {{ .Values.windows.dsName }} + {{- include "azurefile.labels" . | nindent 8 }} +{{- with .Values.windows.podLabels }} +{{ toYaml . | indent 8 }} +{{- end }} +{{- with .Values.windows.podAnnotations }} + annotations: +{{ toYaml . | indent 8 }} +{{- end }} + spec: + serviceAccountName: {{ .Values.serviceAccount.node }} +{{- with .Values.windows.tolerations }} + tolerations: +{{ toYaml . | indent 8 }} +{{- end }} + nodeSelector: + kubernetes.io/os: windows +{{- with .Values.windows.nodeSelector }} +{{ toYaml . | indent 8 }} +{{- end }} + affinity: +{{- with .Values.windows.affinity }} +{{ toYaml . | indent 8 }} +{{- end }} + nodeAffinity: +{{ toYaml .Values.windows.nodeAffinity | indent 10 }} + priorityClassName: system-node-critical + securityContext: + seccompProfile: + type: RuntimeDefault + {{- if .Values.imagePullSecrets }} + imagePullSecrets: +{{ toYaml .Values.imagePullSecrets | indent 8 }} + {{- end }} + containers: + - name: liveness-probe + volumeMounts: + - mountPath: C:\csi + name: plugin-dir +{{- if hasPrefix "/" .Values.image.livenessProbe.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.livenessProbe.repository }}:{{ .Values.image.livenessProbe.tag }}" +{{- else }} + image: "{{ .Values.image.livenessProbe.repository }}:{{ .Values.image.livenessProbe.tag }}" +{{- end }} + args: + - "--csi-address=$(CSI_ENDPOINT)" + - "--probe-timeout=3s" + - "--health-port={{ .Values.node.livenessProbe.healthPort }}" + - "--v=2" + env: + - name: CSI_ENDPOINT + value: unix://C:\\csi\\csi.sock + imagePullPolicy: {{ .Values.image.livenessProbe.pullPolicy }} + resources: {{- toYaml .Values.windows.resources.livenessProbe | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: node-driver-registrar +{{- if hasPrefix "/" .Values.image.nodeDriverRegistrar.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.nodeDriverRegistrar.repository }}:{{ .Values.image.nodeDriverRegistrar.tag }}" +{{- else }} + image: "{{ .Values.image.nodeDriverRegistrar.repository }}:{{ .Values.image.nodeDriverRegistrar.tag }}" +{{- end }} + args: + - "--csi-address=$(CSI_ENDPOINT)" + - "--kubelet-registration-path=$(DRIVER_REG_SOCK_PATH)" + - "--v=2" + env: + - name: CSI_ENDPOINT + value: unix://C:\\csi\\csi.sock + - name: DRIVER_REG_SOCK_PATH + value: C:\\var\\lib\\kubelet\\plugins\\{{ .Values.driver.name }}\\csi.sock + - name: KUBE_NODE_NAME + valueFrom: + fieldRef: + fieldPath: spec.nodeName + imagePullPolicy: {{ .Values.image.nodeDriverRegistrar.pullPolicy }} + volumeMounts: + - name: kubelet-dir + mountPath: "C:\\var\\lib\\kubelet" + - name: plugin-dir + mountPath: C:\csi + - name: registration-dir + mountPath: C:\registration + resources: {{- toYaml .Values.windows.resources.nodeDriverRegistrar | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: azurefile +{{- if hasPrefix "/" .Values.image.azurefile.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}" +{{- else }} + image: "{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}" +{{- end }} + args: + - "--v={{ .Values.node.logLevel }}" + - "--endpoint=$(CSI_ENDPOINT)" + - "--nodeid=$(KUBE_NODE_NAME)" + - "--kubeconfig={{ .Values.windows.kubeconfig }}" + - "--drivername={{ .Values.driver.name }}" + - "--cloud-config-secret-name={{ .Values.node.cloudConfigSecretName }}" + - "--cloud-config-secret-namespace={{ .Values.node.cloudConfigSecretNamespace }}" + - "--custom-user-agent={{ .Values.driver.customUserAgent }}" + - "--user-agent-suffix={{ .Values.driver.userAgentSuffix }}" + - "--allow-empty-cloud-config={{ .Values.node.allowEmptyCloudConfig }}" + - "--enable-get-volume-stats={{ .Values.feature.enableGetVolumeStats }}" + - "--allow-inline-volume-key-access-with-identity={{ .Values.node.allowInlineVolumeKeyAccessWithIdentity }}" + - "--metrics-address=0.0.0.0:{{ .Values.node.metricsPort }}" + ports: + - containerPort: {{ .Values.node.livenessProbe.healthPort }} + name: healthz + protocol: TCP + livenessProbe: + failureThreshold: 5 + httpGet: + path: /healthz + port: healthz + initialDelaySeconds: 30 + timeoutSeconds: 10 + periodSeconds: 30 + env: + - name: AZURE_CREDENTIAL_FILE + valueFrom: + configMapKeyRef: + name: {{ .Values.azureCredentialFileConfigMap }} + key: path-windows + optional: true + - name: CSI_ENDPOINT + value: unix://C:\\csi\\csi.sock + {{- if ne .Values.driver.httpsProxy "" }} + - name: HTTPS_PROXY + value: {{ .Values.driver.httpsProxy }} + {{- end }} + {{- if ne .Values.driver.httpProxy "" }} + - name: HTTP_PROXY + value: {{ .Values.driver.httpProxy }} + {{- end }} + - name: KUBE_NODE_NAME + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: spec.nodeName + - name: AZURE_GO_SDK_LOG_LEVEL + value: {{ .Values.driver.azureGoSDKLogLevel }} + imagePullPolicy: {{ .Values.image.pullPolicy }} + volumeMounts: + - name: kubelet-dir + mountPath: "C:\\var\\lib\\kubelet" + - name: plugin-dir + mountPath: C:\csi + - name: azure-config + mountPath: C:\k + - name: csi-proxy-fs-pipe-v1 + mountPath: \\.\pipe\csi-proxy-filesystem-v1 + - name: csi-proxy-smb-pipe-v1 + mountPath: \\.\pipe\csi-proxy-smb-v1 + # these paths are still included for compatibility, they're used + # only if the node has still the beta version of the CSI proxy + - name: csi-proxy-fs-pipe-v1beta1 + mountPath: \\.\pipe\csi-proxy-filesystem-v1beta1 + - name: csi-proxy-smb-pipe-v1beta1 + mountPath: \\.\pipe\csi-proxy-smb-v1beta1 + resources: {{- toYaml .Values.windows.resources.azurefile | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + volumes: + - name: csi-proxy-fs-pipe-v1 + hostPath: + path: \\.\pipe\csi-proxy-filesystem-v1 + - name: csi-proxy-smb-pipe-v1 + hostPath: + path: \\.\pipe\csi-proxy-smb-v1 + # these paths are still included for compatibility, they're used + # only if the node has still the beta version of the CSI proxy + - name: csi-proxy-fs-pipe-v1beta1 + hostPath: + path: \\.\pipe\csi-proxy-filesystem-v1beta1 + - name: csi-proxy-smb-pipe-v1beta1 + hostPath: + path: \\.\pipe\csi-proxy-smb-v1beta1 + - name: registration-dir + hostPath: + path: {{ .Values.windows.kubelet }}\plugins_registry\ + type: Directory + - name: kubelet-dir + hostPath: + path: {{ .Values.windows.kubelet }}\ + type: Directory + - name: plugin-dir + hostPath: + path: {{ .Values.windows.kubelet }}\plugins\{{ .Values.driver.name }}\ + type: DirectoryOrCreate + - name: azure-config + hostPath: + path: C:\k + type: Directory +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node.yaml new file mode 100644 index 0000000000..601c864ff1 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/csi-azurefile-node.yaml @@ -0,0 +1,224 @@ +{{- if .Values.linux.enabled}} +kind: DaemonSet +apiVersion: apps/v1 +metadata: + name: {{ .Values.linux.dsName }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Values.linux.dsName }} + {{- include "azurefile.labels" . | nindent 4 }} +{{- with .Values.linux.labels }} +{{ . | toYaml | indent 4 }} +{{- end }} +{{- with .Values.linux.annotations }} + annotations: +{{ . | toYaml | indent 4 }} +{{- end }} +spec: + updateStrategy: + rollingUpdate: + maxUnavailable: {{ .Values.node.maxUnavailable }} + type: {{ .Values.node.strategyType }} + selector: + matchLabels: + app: {{ .Values.linux.dsName }} + {{- include "azurefile.selectorLabels" . | nindent 6 }} + template: + metadata: + labels: + app: {{ .Values.linux.dsName }} + {{- include "azurefile.labels" . | nindent 8 }} + {{- if .Values.workloadIdentity.clientID }} + azure.workload.identity/use: "true" + {{- end }} +{{- with .Values.linux.podLabels }} +{{ toYaml . | indent 8 }} +{{- end }} +{{- with .Values.linux.podAnnotations }} + annotations: +{{ toYaml . | indent 8 }} +{{- end }} + spec: + hostNetwork: true + dnsPolicy: {{ .Values.linux.dnsPolicy }} + serviceAccountName: {{ .Values.serviceAccount.node }} + nodeSelector: + kubernetes.io/os: linux +{{- with .Values.linux.nodeSelector }} +{{ toYaml . | indent 8 }} +{{- end }} + affinity: +{{- with .Values.linux.affinity }} +{{ toYaml . | indent 8 }} +{{- end }} + nodeAffinity: +{{ toYaml .Values.linux.nodeAffinity | indent 10 }} + priorityClassName: system-node-critical + securityContext: + seccompProfile: + type: RuntimeDefault +{{- with .Values.linux.tolerations }} + tolerations: +{{ toYaml . | indent 8 }} +{{- end }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: +{{ toYaml .Values.imagePullSecrets | indent 8 }} + {{- end }} + containers: + - name: liveness-probe + volumeMounts: + - mountPath: /csi + name: socket-dir +{{- if hasPrefix "/" .Values.image.livenessProbe.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.livenessProbe.repository }}:{{ .Values.image.livenessProbe.tag }}" +{{- else }} + image: "{{ .Values.image.livenessProbe.repository }}:{{ .Values.image.livenessProbe.tag }}" +{{- end }} + args: + - --csi-address=/csi/csi.sock + - --probe-timeout=3s + - --http-endpoint=localhost:{{ .Values.node.livenessProbe.healthPort }} + - --v=2 + imagePullPolicy: {{ .Values.image.livenessProbe.pullPolicy }} + resources: {{- toYaml .Values.linux.resources.livenessProbe | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: node-driver-registrar +{{- if hasPrefix "/" .Values.image.nodeDriverRegistrar.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.nodeDriverRegistrar.repository }}:{{ .Values.image.nodeDriverRegistrar.tag }}" +{{- else }} + image: "{{ .Values.image.nodeDriverRegistrar.repository }}:{{ .Values.image.nodeDriverRegistrar.tag }}" +{{- end }} + args: + - --csi-address=$(ADDRESS) + - --kubelet-registration-path=$(DRIVER_REG_SOCK_PATH) + - --v=2 + env: + - name: ADDRESS + value: /csi/csi.sock + - name: DRIVER_REG_SOCK_PATH + value: {{ .Values.linux.kubelet }}/plugins/{{ .Values.driver.name }}/csi.sock + imagePullPolicy: {{ .Values.image.nodeDriverRegistrar.pullPolicy }} + volumeMounts: + - name: socket-dir + mountPath: /csi + - name: registration-dir + mountPath: /registration + resources: {{- toYaml .Values.linux.resources.nodeDriverRegistrar | nindent 12 }} + securityContext: + capabilities: + drop: + - ALL + - name: azurefile +{{- if hasPrefix "/" .Values.image.azurefile.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}" +{{- else }} + image: "{{ .Values.image.azurefile.repository }}:{{ .Values.image.azurefile.tag }}" +{{- end }} + args: + - "--v={{ .Values.node.logLevel }}" + - "--endpoint=$(CSI_ENDPOINT)" + - "--nodeid=$(KUBE_NODE_NAME)" + - "--kubeconfig={{ .Values.linux.kubeconfig }}" + - "--drivername={{ .Values.driver.name }}" + - "--cloud-config-secret-name={{ .Values.node.cloudConfigSecretName }}" + - "--cloud-config-secret-namespace={{ .Values.node.cloudConfigSecretNamespace }}" + - "--custom-user-agent={{ .Values.driver.customUserAgent }}" + - "--user-agent-suffix={{ .Values.driver.userAgentSuffix }}" + - "--allow-empty-cloud-config={{ .Values.node.allowEmptyCloudConfig }}" + - "--enable-volume-mount-group={{ .Values.feature.enableVolumeMountGroup }}" + - "--enable-get-volume-stats={{ .Values.feature.enableGetVolumeStats }}" + - "--mount-permissions={{ .Values.linux.mountPermissions }}" + - "--allow-inline-volume-key-access-with-identity={{ .Values.node.allowInlineVolumeKeyAccessWithIdentity }}" + - "--metrics-address=0.0.0.0:{{ .Values.node.metricsPort }}" + livenessProbe: + failureThreshold: 5 + httpGet: + host: localhost + path: /healthz + port: {{ .Values.node.livenessProbe.healthPort }} + initialDelaySeconds: 30 + timeoutSeconds: 10 + periodSeconds: 30 + env: + - name: AZURE_CREDENTIAL_FILE + valueFrom: + configMapKeyRef: + name: {{ .Values.azureCredentialFileConfigMap }} + key: path + optional: true + - name: CSI_ENDPOINT + value: unix:///csi/csi.sock + {{- if ne .Values.driver.httpsProxy "" }} + - name: HTTPS_PROXY + value: {{ .Values.driver.httpsProxy }} + {{- end }} + {{- if ne .Values.driver.httpProxy "" }} + - name: HTTP_PROXY + value: {{ .Values.driver.httpProxy }} + {{- end }} + - name: KUBE_NODE_NAME + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: spec.nodeName + - name: AZURE_GO_SDK_LOG_LEVEL + value: {{ .Values.driver.azureGoSDKLogLevel }} + imagePullPolicy: {{ .Values.image.azurefile.pullPolicy }} + securityContext: + privileged: true + capabilities: + drop: + - ALL + volumeMounts: + - mountPath: /csi + name: socket-dir + - mountPath: {{ .Values.linux.kubelet }}/ + mountPropagation: Bidirectional + name: mountpoint-dir + - mountPath: /etc/kubernetes/ + name: azure-cred + - mountPath: /dev + name: device-dir + {{- if eq .Values.linux.distro "fedora" }} + - name: ssl + mountPath: /etc/ssl/certs + readOnly: true + - name: ssl-pki + mountPath: /etc/pki/ca-trust/extracted + readOnly: true + {{- end }} + resources: {{- toYaml .Values.linux.resources.azurefile | nindent 12 }} + volumes: + - hostPath: + path: {{ .Values.linux.kubelet }}/plugins/{{ .Values.driver.name }} + type: DirectoryOrCreate + name: socket-dir + - hostPath: + path: {{ .Values.linux.kubelet }}/ + type: DirectoryOrCreate + name: mountpoint-dir + - hostPath: + path: {{ .Values.linux.kubelet }}/plugins_registry/ + type: DirectoryOrCreate + name: registration-dir + - hostPath: + path: /etc/kubernetes/ + type: DirectoryOrCreate + name: azure-cred + - hostPath: + path: /dev + type: Directory + name: device-dir + {{- if eq .Values.linux.distro "fedora" }} + - name: ssl + hostPath: + path: /etc/ssl/certs + - name: ssl-pki + hostPath: + path: /etc/pki/ca-trust/extracted + {{- end }} +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/csi-snapshot-controller.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/csi-snapshot-controller.yaml new file mode 100644 index 0000000000..124bf493dd --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/csi-snapshot-controller.yaml @@ -0,0 +1,95 @@ +{{- if .Values.snapshot.enabled -}} +kind: Deployment +apiVersion: apps/v1 +metadata: + name: {{ .Values.snapshot.snapshotController.name}} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Values.snapshot.snapshotController.name}} + {{- include "azurefile.labels" . | nindent 4 }} +{{- with .Values.snapshot.snapshotController.labels }} +{{ . | toYaml | indent 4 }} +{{- end }} +{{- with .Values.snapshot.snapshotController.annotations }} + annotations: +{{ . | toYaml | indent 4 }} +{{- end }} +spec: + replicas: {{ .Values.snapshot.snapshotController.replicas }} + selector: + matchLabels: + app: {{ .Values.snapshot.snapshotController.name}} + {{- include "azurefile.selectorLabels" . | nindent 6 }} + # the snapshot controller won't be marked as ready if the v1 CRDs are unavailable + # in #504 the snapshot-controller will exit after around 7.5 seconds if it + # can't find the v1 CRDs so this value should be greater than that + minReadySeconds: 15 + strategy: + rollingUpdate: + maxSurge: 0 + maxUnavailable: 1 + type: {{ .Values.snapshot.snapshotController.strategyType }} + template: + metadata: + labels: + app: {{ .Values.snapshot.snapshotController.name}} + {{- include "azurefile.labels" . | nindent 8 }} +{{- with .Values.snapshot.snapshotController.podLabels }} +{{ toYaml . | indent 8 }} +{{- end }} +{{- with .Values.snapshot.snapshotController.podAnnotations }} + annotations: +{{ toYaml . | indent 8 }} +{{- end }} + spec: + serviceAccountName: {{ .Values.serviceAccount.snapshotController }} + nodeSelector: + kubernetes.io/os: linux + # runOnControlPlane=true or runOnMaster=true only takes effect if affinity is not set + {{- if contains (tpl "{{ .Values.controller.affinity }}" .) "nodeSelectorTerms" }} + {{- with .Values.controller.affinity }} + affinity: + {{ toYaml . | indent 8 }} + {{- end }} + {{- else if or .Values.controller.runOnControlPlane .Values.controller.runOnMaster}} + affinity: + nodeAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + nodeSelectorTerms: + - matchExpressions: + {{- if .Values.controller.runOnControlPlane}} + - key: node-role.kubernetes.io/control-plane + operator: Exists + {{- end}} + {{- if .Values.controller.runOnMaster}} + - key: node-role.kubernetes.io/master + operator: Exists + {{- end}} + {{- end }} + priorityClassName: system-cluster-critical +{{- with .Values.controller.tolerations }} + tolerations: +{{ toYaml . | indent 8 }} +{{- end }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: +{{ toYaml .Values.imagePullSecrets | indent 8 }} + {{- end }} + containers: + - name: {{ .Values.snapshot.snapshotController.name}} +{{- if hasPrefix "/" .Values.snapshot.image.csiSnapshotController.repository }} + image: "{{ .Values.image.baseRepo }}{{ .Values.snapshot.image.csiSnapshotController.repository }}:{{ .Values.snapshot.image.csiSnapshotController.tag }}" +{{- else }} + image: "{{ .Values.snapshot.image.csiSnapshotController.repository }}:{{ .Values.snapshot.image.csiSnapshotController.tag }}" +{{- end }} + args: + - "--v=2" + - "--leader-election=true" + - "--leader-election-namespace={{ .Release.Namespace }}" + resources: {{- toYaml .Values.snapshot.snapshotController.resources | nindent 12 }} + imagePullPolicy: {{ .Values.snapshot.image.csiSnapshotController.pullPolicy }} + securityContext: + capabilities: + drop: + - ALL +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-controller.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-controller.yaml new file mode 100644 index 0000000000..e0a2e14d95 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-controller.yaml @@ -0,0 +1,207 @@ +{{- if .Values.rbac.create -}} +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-external-provisioner-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: [""] + resources: ["persistentvolumes"] + verbs: ["get", "list", "watch", "create", "patch", "delete"] + - apiGroups: [""] + resources: ["persistentvolumeclaims"] + verbs: ["get", "list", "watch", "update"] + - apiGroups: ["storage.k8s.io"] + resources: ["storageclasses"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["events"] + verbs: ["get", "list", "watch", "create", "update", "patch"] + - apiGroups: ["storage.k8s.io"] + resources: ["csinodes"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["nodes"] + verbs: ["get", "list", "watch"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshots"] + verbs: ["get", "list"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshotcontents"] + verbs: ["get", "list"] + - apiGroups: ["coordination.k8s.io"] + resources: ["leases"] + verbs: ["get", "watch", "list", "delete", "update", "create", "patch"] +--- + +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-csi-provisioner-binding + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.controller }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: {{ .Values.rbac.name }}-external-provisioner-role + apiGroup: rbac.authorization.k8s.io + +--- + +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-external-attacher-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: [""] + resources: ["persistentvolumes"] + verbs: ["get", "list", "watch", "update"] + - apiGroups: [""] + resources: ["nodes"] + verbs: ["get", "list", "watch"] + - apiGroups: ["csi.storage.k8s.io"] + resources: ["csinodeinfos"] + verbs: ["get", "list", "watch"] + - apiGroups: ["storage.k8s.io"] + resources: ["volumeattachments"] + verbs: ["get", "list", "watch", "update", "patch"] + - apiGroups: ["storage.k8s.io"] + resources: ["volumeattachments/status"] + verbs: ["get", "list", "watch", "update", "patch"] + - apiGroups: ["coordination.k8s.io"] + resources: ["leases"] + verbs: ["get", "watch", "list", "delete", "update", "create", "patch"] +--- + +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-csi-attacher-binding + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.controller }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: {{ .Values.rbac.name }}-external-attacher-role + apiGroup: rbac.authorization.k8s.io + +--- + +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-external-snapshotter-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: [""] + resources: ["events"] + verbs: ["list", "watch", "create", "update", "patch"] + - apiGroups: [""] + resources: ["secrets"] + verbs: ["get"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshotclasses"] + verbs: ["get", "list", "watch"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshotcontents"] + verbs: ["create", "get", "list", "watch", "update", "delete", "patch"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshotcontents/status"] + verbs: ["update", "patch"] + - apiGroups: ["coordination.k8s.io"] + resources: ["leases"] + verbs: ["get", "watch", "list", "delete", "update", "create", "patch"] +--- + +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-csi-snapshotter-binding + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.controller }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: {{ .Values.rbac.name }}-external-snapshotter-role + apiGroup: rbac.authorization.k8s.io + +--- +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-external-resizer-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: [""] + resources: ["persistentvolumes"] + verbs: ["get", "list", "watch", "update", "patch"] + - apiGroups: [""] + resources: ["persistentvolumeclaims"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["persistentvolumeclaims/status"] + verbs: ["update", "patch"] + - apiGroups: [""] + resources: ["events"] + verbs: ["list", "watch", "create", "update", "patch"] + - apiGroups: ["coordination.k8s.io"] + resources: ["leases"] + verbs: ["get", "watch", "list", "delete", "update", "create", "patch"] +--- +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: {{ .Values.rbac.name }}-csi-resizer-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.controller }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: {{ .Values.rbac.name }}-external-resizer-role + apiGroup: rbac.authorization.k8s.io + +--- +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-{{ .Values.rbac.name }}-controller-secret-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: [""] + resources: ["secrets"] + verbs: ["get", "create"] + +--- +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-{{ .Values.rbac.name }}-controller-secret-binding + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.controller }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: csi-{{ .Values.rbac.name }}-controller-secret-role + apiGroup: rbac.authorization.k8s.io +{{ end }} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-node.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-node.yaml new file mode 100644 index 0000000000..4e1fbcde94 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-azurefile-node.yaml @@ -0,0 +1,29 @@ +{{- if .Values.rbac.create -}} +--- +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-{{ .Values.rbac.name }}-node-secret-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: [""] + resources: ["secrets"] + verbs: ["get"] + +--- +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-{{ .Values.rbac.name }}-node-secret-binding + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.node }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: csi-{{ .Values.rbac.name }}-node-secret-role + apiGroup: rbac.authorization.k8s.io +{{ end }} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-snapshot-controller.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-snapshot-controller.yaml new file mode 100644 index 0000000000..853a9b4375 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/rbac-csi-snapshot-controller.yaml @@ -0,0 +1,80 @@ +{{- if and .Values.snapshot.enabled .Values.rbac.create -}} +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-snapshot-controller-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: [""] + resources: ["persistentvolumes"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["persistentvolumeclaims"] + verbs: ["get", "list", "watch", "update"] + - apiGroups: ["storage.k8s.io"] + resources: ["storageclasses"] + verbs: ["get", "list", "watch"] + - apiGroups: [""] + resources: ["events"] + verbs: ["list", "watch", "create", "update", "patch"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshotclasses"] + verbs: ["get", "list", "watch"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshotcontents"] + verbs: ["create", "get", "list", "watch", "update", "delete", "patch"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshotcontents/status"] + verbs: ["patch"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshots"] + verbs: ["get", "list", "watch", "update", "patch", "create"] + - apiGroups: ["snapshot.storage.k8s.io"] + resources: ["volumesnapshots/status"] + verbs: ["update", "patch"] + +--- +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-snapshot-controller-binding + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.snapshotController }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: csi-snapshot-controller-role + apiGroup: rbac.authorization.k8s.io + +--- +kind: ClusterRole +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-snapshot-controller-leaderelection-role + labels: + {{- include "azurefile.labels" . | nindent 4 }} +rules: + - apiGroups: ["coordination.k8s.io"] + resources: ["leases"] + verbs: ["get", "watch", "list", "delete", "update", "create", "patch"] + +--- +kind: ClusterRoleBinding +apiVersion: rbac.authorization.k8s.io/v1 +metadata: + name: csi-snapshot-controller-leaderelection-binding + labels: + {{- include "azurefile.labels" . | nindent 4 }} +subjects: + - kind: ServiceAccount + name: {{ .Values.serviceAccount.snapshotController }} + namespace: {{ .Release.Namespace }} +roleRef: + kind: ClusterRole + name: csi-snapshot-controller-leaderelection-role + apiGroup: rbac.authorization.k8s.io +{{ end }} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-controller.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-controller.yaml new file mode 100644 index 0000000000..71442b70dc --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-controller.yaml @@ -0,0 +1,17 @@ +{{- if .Values.serviceAccount.create -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ .Values.serviceAccount.controller }} + namespace: {{ .Release.Namespace }} + labels: + {{- include "azurefile.labels" . | nindent 4 }} +{{- if .Values.workloadIdentity.clientID }} + azure.workload.identity/use: "true" + annotations: + azure.workload.identity/client-id: {{ .Values.workloadIdentity.clientID }} +{{- if .Values.workloadIdentity.tenantID }} + azure.workload.identity/tenant-id: {{ .Values.workloadIdentity.tenantID }} +{{- end }} +{{- end }} +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-node.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-node.yaml new file mode 100644 index 0000000000..ab2074429d --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-azurefile-node.yaml @@ -0,0 +1,17 @@ +{{- if .Values.serviceAccount.create -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ .Values.serviceAccount.node }} + namespace: {{ .Release.Namespace }} + labels: + {{- include "azurefile.labels" . | nindent 4 }} +{{- if .Values.workloadIdentity.clientID }} + azure.workload.identity/use: "true" + annotations: + azure.workload.identity/client-id: {{ .Values.workloadIdentity.clientID }} +{{- if .Values.workloadIdentity.tenantID }} + azure.workload.identity/tenant-id: {{ .Values.workloadIdentity.tenantID }} +{{- end }} +{{- end }} +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-snapshot-controller.yaml b/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-snapshot-controller.yaml new file mode 100644 index 0000000000..e77ef8f991 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/templates/serviceaccount-csi-snapshot-controller.yaml @@ -0,0 +1,9 @@ +{{- if and .Values.snapshot.enabled .Values.serviceAccount.create -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ .Values.serviceAccount.snapshotController }} + namespace: {{ .Release.Namespace }} + labels: + {{- include "azurefile.labels" . | nindent 4 }} +{{- end -}} diff --git a/charts/v1.30.7/azurefile-csi-driver/values.yaml b/charts/v1.30.7/azurefile-csi-driver/values.yaml new file mode 100644 index 0000000000..6c5fdef803 --- /dev/null +++ b/charts/v1.30.7/azurefile-csi-driver/values.yaml @@ -0,0 +1,262 @@ +image: + baseRepo: mcr.microsoft.com + azurefile: + repository: /oss/kubernetes-csi/azurefile-csi + tag: v1.30.7 + pullPolicy: IfNotPresent + csiProvisioner: + repository: /oss/kubernetes-csi/csi-provisioner + tag: v5.1.0 + pullPolicy: IfNotPresent + csiResizer: + repository: /oss/kubernetes-csi/csi-resizer + tag: v1.12.0 + pullPolicy: IfNotPresent + livenessProbe: + repository: /oss/kubernetes-csi/livenessprobe + tag: v2.14.0 + pullPolicy: IfNotPresent + nodeDriverRegistrar: + repository: /oss/kubernetes-csi/csi-node-driver-registrar + tag: v2.12.0 + pullPolicy: IfNotPresent + +## Reference to one or more secrets to be used when pulling images +## ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ +imagePullSecrets: [] +# - name: myRegistryKeySecretName + +# -- Custom labels to add into metadata +customLabels: {} + # k8s-app: azurefile-csi-driver + +serviceAccount: + create: true # When true, service accounts will be created for you. Set to false if you want to use your own. + controller: csi-azurefile-controller-sa # Name of Service Account to be created or used + node: csi-azurefile-node-sa # Name of Service Account to be created or used + snapshotController: csi-snapshot-controller-sa # Name of Service Account to be created or used + +rbac: + create: true + name: azurefile + +controller: + name: csi-azurefile-controller + cloudConfigSecretName: azure-cloud-provider + cloudConfigSecretNamespace: kube-system + allowEmptyCloudConfig: true + replicas: 2 + strategyType: RollingUpdate + hostNetwork: true # this setting could be disabled if controller does not depend on MSI setting + metricsPort: 29614 + livenessProbe: + healthPort: 29612 + runOnMaster: false + runOnControlPlane: false + attachRequired: false + logLevel: 5 + labels: {} + annotations: {} + podLabels: {} + podAnnotations: {} + resources: + csiProvisioner: + limits: + cpu: 1 + memory: 500Mi + requests: + cpu: 10m + memory: 20Mi + csiResizer: + limits: + cpu: 1 + memory: 500Mi + requests: + cpu: 10m + memory: 20Mi + csiSnapshotter: + limits: + cpu: 1 + memory: 400Mi + requests: + cpu: 10m + memory: 20Mi + livenessProbe: + limits: + cpu: 1 + memory: 100Mi + requests: + cpu: 10m + memory: 20Mi + azurefile: + limits: + cpu: 2 + memory: 800Mi + requests: + cpu: 10m + memory: 20Mi + kubeconfig: "" + affinity: {} + nodeSelector: {} + tolerations: + - key: "node-role.kubernetes.io/master" + operator: "Exists" + effect: "NoSchedule" + - key: "node-role.kubernetes.io/controlplane" + operator: "Exists" + effect: "NoSchedule" + - key: "node-role.kubernetes.io/control-plane" + operator: "Exists" + effect: "NoSchedule" + - key: "CriticalAddonsOnly" + operator: "Exists" + effect: "NoSchedule" + +node: + strategyType: RollingUpdate + maxUnavailable: 1 + cloudConfigSecretName: azure-cloud-provider + cloudConfigSecretNamespace: kube-system + allowEmptyCloudConfig: true + allowInlineVolumeKeyAccessWithIdentity: false + metricsPort: 29615 + livenessProbe: + healthPort: 29613 + logLevel: 5 + +snapshot: + enabled: false + image: + csiSnapshotter: + repository: /oss/kubernetes-csi/csi-snapshotter + tag: v8.2.0 + pullPolicy: IfNotPresent + csiSnapshotController: + repository: /oss/kubernetes-csi/snapshot-controller + tag: v8.2.0 + pullPolicy: IfNotPresent + snapshotController: + name: csi-snapshot-controller + replicas: 2 + strategyType: RollingUpdate + labels: {} + annotations: {} + podLabels: {} + podAnnotations: {} + resources: + limits: + cpu: 1 + memory: 500Mi + requests: + cpu: 10m + memory: 20Mi + +feature: + enableGetVolumeStats: true + enableVolumeMountGroup: true + fsGroupPolicy: ReadWriteOnceWithFSType + +driver: + name: file.csi.azure.com + customUserAgent: "" + userAgentSuffix: "OSS-helm" + azureGoSDKLogLevel: "" # available values: ""(no logs), DEBUG, INFO, WARNING, ERROR + httpsProxy: "" + httpProxy: "" + +linux: + enabled: true + dsName: csi-azurefile-node # daemonset name + dnsPolicy: Default # available values: Default, ClusterFirst, ClusterFirstWithHostNet, None + kubelet: /var/lib/kubelet + kubeconfig: "" + distro: debian # available values: debian, fedora + mountPermissions: 0777 + labels: {} + annotations: {} + podLabels: {} + podAnnotations: {} + resources: + livenessProbe: + limits: + memory: 100Mi + requests: + cpu: 10m + memory: 20Mi + nodeDriverRegistrar: + limits: + memory: 100Mi + requests: + cpu: 10m + memory: 20Mi + azurefile: + limits: + memory: 400Mi + requests: + cpu: 10m + memory: 20Mi + tolerations: + - operator: "Exists" + nodeSelector: {} + affinity: {} + nodeAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + nodeSelectorTerms: + - matchExpressions: + - key: type + operator: NotIn + values: + - virtual-kubelet + +windows: + enabled: true + useHostProcessContainers: true + dsName: csi-azurefile-node-win # daemonset name + kubelet: 'C:\var\lib\kubelet' + kubeconfig: "" + enableRegistrationProbe: true + labels: {} + annotations: {} + podLabels: {} + podAnnotations: {} + resources: + livenessProbe: + limits: + memory: 150Mi + requests: + cpu: 10m + memory: 40Mi + nodeDriverRegistrar: + limits: + memory: 150Mi + requests: + cpu: 30m + memory: 40Mi + azurefile: + limits: + memory: 600Mi + requests: + cpu: 10m + memory: 40Mi + tolerations: + - key: "node.kubernetes.io/os" + operator: "Exists" + effect: "NoSchedule" + nodeSelector: {} + affinity: {} + nodeAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + nodeSelectorTerms: + - matchExpressions: + - key: type + operator: NotIn + values: + - virtual-kubelet + +workloadIdentity: + clientID: "" + # [optional] If the AAD application or user-assigned managed identity is not in the same tenant as the cluster + # then set tenantID with the application or user-assigned managed identity tenant ID + tenantID: "" + +azureCredentialFileConfigMap: azure-cred-file diff --git a/charts/v1.31.2/azurefile-csi-driver-1.31.2.tgz b/charts/v1.31.2/azurefile-csi-driver-1.31.2.tgz new file mode 100644 index 0000000000000000000000000000000000000000..055725d4f7cb94a07ada82becfb1abdaeb691c0a GIT binary patch literal 14005 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 b>$&x_e%8 - please use helm install method for more customization, e.g. Azure Stack, RedHat OpenShift support. - [install CSI driver master version](./install-csi-driver-master.md)(only for testing purpose) - - [install v1.31.0 CSI driver](./install-csi-driver-v1.31.0.md) + - [install v1.31.2 CSI driver](./install-csi-driver-v1.31.2.md) - [install v1.30.6 CSI driver](./install-csi-driver-v1.30.6.md) - [install v1.29.9 CSI driver](./install-csi-driver-v1.29.9.md) - [install v1.28.13 CSI driver](./install-csi-driver-v1.28.13.md) diff --git a/docs/install-csi-driver-v1.29.10.md b/docs/install-csi-driver-v1.29.10.md new file mode 100644 index 0000000000..82edff2ed8 --- /dev/null +++ b/docs/install-csi-driver-v1.29.10.md @@ -0,0 +1,45 @@ +## Install azurefile CSI driver v1.29.10 version on a Kubernetes cluster +If you have already installed Helm, you can also use it to install this driver. Please check [Installation with Helm](../charts/README.md). + +### Install by kubectl + - Option#1. remote install +```console +curl -skSL https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/v1.29.10/deploy/install-driver.sh | bash -s v1.29.10 -- +``` + + - Option#2. local install +```console +git clone https://github.com/kubernetes-sigs/azurefile-csi-driver.git +cd azurefile-csi-driver +git checkout v1.29.10 +./deploy/install-driver.sh v1.29.10 local +``` + + - check pods status: +```console +kubectl -n kube-system get pod -o wide --watch -l app=csi-azurefile-controller +kubectl -n kube-system get pod -o wide --watch -l app=csi-azurefile-node +``` + +example output: + +``` +NAME READY STATUS RESTARTS AGE IP NODE +csi-azurefile-controller-56bfddd689-dh5tk 6/6 Running 0 35s 10.240.0.19 k8s-agentpool-22533604-0 +csi-azurefile-node-cvgbs 3/3 Running 0 7m4s 10.240.0.35 k8s-agentpool-22533604-1 +csi-azurefile-node-dr4s4 3/3 Running 0 7m4s 10.240.0.4 k8s-agentpool-22533604-0 +``` + +### clean up CSI driver + - Option#1. remote uninstall +```console +curl -skSL https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/v1.29.10/deploy/uninstall-driver.sh | bash -s -- +``` + + - Option#2. local uninstall +```console +git clone https://github.com/kubernetes-sigs/azurefile-csi-driver.git +cd azurefile-csi-driver +git checkout v1.29.10 +./deploy/install-driver.sh v1.29.10 local +``` diff --git a/docs/install-csi-driver-v1.30.7.md b/docs/install-csi-driver-v1.30.7.md new file mode 100644 index 0000000000..ffd3367e03 --- /dev/null +++ b/docs/install-csi-driver-v1.30.7.md @@ -0,0 +1,45 @@ +## Install azurefile CSI driver v1.30.7 version on a Kubernetes cluster +If you have already installed Helm, you can also use it to install this driver. Please check [Installation with Helm](../charts/README.md). + +### Install by kubectl + - Option#1. remote install +```console +curl -skSL https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/v1.30.7/deploy/install-driver.sh | bash -s v1.30.7 -- +``` + + - Option#2. local install +```console +git clone https://github.com/kubernetes-sigs/azurefile-csi-driver.git +cd azurefile-csi-driver +git checkout v1.30.7 +./deploy/install-driver.sh v1.30.7 local +``` + + - check pods status: +```console +kubectl -n kube-system get pod -o wide --watch -l app=csi-azurefile-controller +kubectl -n kube-system get pod -o wide --watch -l app=csi-azurefile-node +``` + +example output: + +``` +NAME READY STATUS RESTARTS AGE IP NODE +csi-azurefile-controller-56bfddd689-dh5tk 6/6 Running 0 35s 10.240.0.19 k8s-agentpool-22533604-0 +csi-azurefile-node-cvgbs 3/3 Running 0 7m4s 10.240.0.35 k8s-agentpool-22533604-1 +csi-azurefile-node-dr4s4 3/3 Running 0 7m4s 10.240.0.4 k8s-agentpool-22533604-0 +``` + +### clean up CSI driver + - Option#1. remote uninstall +```console +curl -skSL https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/v1.30.7/deploy/uninstall-driver.sh | bash -s -- +``` + + - Option#2. local uninstall +```console +git clone https://github.com/kubernetes-sigs/azurefile-csi-driver.git +cd azurefile-csi-driver +git checkout v1.30.7 +./deploy/install-driver.sh v1.30.7 local +``` diff --git a/docs/install-csi-driver-v1.31.2.md b/docs/install-csi-driver-v1.31.2.md new file mode 100644 index 0000000000..15ad31aee4 --- /dev/null +++ b/docs/install-csi-driver-v1.31.2.md @@ -0,0 +1,45 @@ +## Install azurefile CSI driver v1.31.2 version on a Kubernetes cluster +If you have already installed Helm, you can also use it to install this driver. Please check [Installation with Helm](../charts/README.md). + +### Install by kubectl + - Option#1. remote install +```console +curl -skSL https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/v1.31.2/deploy/install-driver.sh | bash -s v1.31.2 -- +``` + + - Option#2. local install +```console +git clone https://github.com/kubernetes-sigs/azurefile-csi-driver.git +cd azurefile-csi-driver +git checkout v1.31.2 +./deploy/install-driver.sh v1.31.2 local +``` + + - check pods status: +```console +kubectl -n kube-system get pod -o wide --watch -l app=csi-azurefile-controller +kubectl -n kube-system get pod -o wide --watch -l app=csi-azurefile-node +``` + +example output: + +``` +NAME READY STATUS RESTARTS AGE IP NODE +csi-azurefile-controller-56bfddd689-dh5tk 6/6 Running 0 35s 10.240.0.19 k8s-agentpool-22533604-0 +csi-azurefile-node-cvgbs 3/3 Running 0 7m4s 10.240.0.35 k8s-agentpool-22533604-1 +csi-azurefile-node-dr4s4 3/3 Running 0 7m4s 10.240.0.4 k8s-agentpool-22533604-0 +``` + +### clean up CSI driver + - Option#1. remote uninstall +```console +curl -skSL https://raw.githubusercontent.com/kubernetes-sigs/azurefile-csi-driver/v1.31.2/deploy/uninstall-driver.sh | bash -s -- +``` + + - Option#2. local uninstall +```console +git clone https://github.com/kubernetes-sigs/azurefile-csi-driver.git +cd azurefile-csi-driver +git checkout v1.31.2 +./deploy/install-driver.sh v1.31.2 local +```