From 78254a56debe8dc78bde93b7d7b344d290431f93 Mon Sep 17 00:00:00 2001 From: titigmr Date: Tue, 8 Oct 2024 16:49:49 +0200 Subject: [PATCH] (vscode-python) Add cacerts (#161) * feat: :sparkles: add cacerts in vscode --- charts/vscode-python/Chart.yaml | 2 +- .../vscode-python/templates/statefulset.yaml | 22 +++++++++++++++- charts/vscode-python/values.schema.json | 26 +++++++++++++++++++ charts/vscode-python/values.yaml | 4 +++ 4 files changed, 52 insertions(+), 2 deletions(-) diff --git a/charts/vscode-python/Chart.yaml b/charts/vscode-python/Chart.yaml index b0fb8f6c..86c3def8 100644 --- a/charts/vscode-python/Chart.yaml +++ b/charts/vscode-python/Chart.yaml @@ -22,7 +22,7 @@ type: application # This is the chart version. This version number should be incremented each time you make changes # to the chart and its templates, including the app version. # Versions are expected to follow Semantic Versioning (https://semver.org/) -version: 2.1.5 +version: 2.1.6 dependencies: - name: library-chart diff --git a/charts/vscode-python/templates/statefulset.yaml b/charts/vscode-python/templates/statefulset.yaml index 294e7d4a..482ddfc0 100644 --- a/charts/vscode-python/templates/statefulset.yaml +++ b/charts/vscode-python/templates/statefulset.yaml @@ -100,6 +100,19 @@ spec: mkdir /dest/metaflow; cp /src/metaflow/config.json /dest/metaflow/config.json; {{- end }} + {{- if .Values.certificates }} + {{- if .Values.certificates.cacerts }} + mkdir /dest/certs; + if [[ {{ .Values.certificates.cacerts }} =~ ^https?://.+$ ]]; + then + curl -s {{ .Values.certificates.cacerts }} -o /tmp/ca.pem + else + echo -n {{ .Values.certificates.cacerts }} | base64 -d > /tmp/ca.pem; + fi + awk 'BEGIN {c=0;} /BEGIN CERT/{c++} { print > "/tmp/cert." c ".crt"}' < /tmp/ca.pem; + cp /tmp/*.crt /dest/certs/; + {{- end }} + {{- end }} volumeMounts: - name: config-files mountPath: /dest @@ -217,7 +230,14 @@ spec: - name: config-files mountPath: /home/{{ .Values.environment.user}}/.metaflowconfig subPath: metaflow - {{- end }} + {{- end }} + {{- if .Values.certificates }} + {{- if .Values.certificates.pathToCaBundle }} + - name: config-files + mountPath: {{ .Values.certificates.pathToCaBundle }} + subPath: certs + {{- end }} + {{- end }} {{- with .Values.nodeSelector }} nodeSelector: {{- toYaml . | nindent 8 }} diff --git a/charts/vscode-python/values.schema.json b/charts/vscode-python/values.schema.json index 660e97b6..f5d55784 100644 --- a/charts/vscode-python/values.schema.json +++ b/charts/vscode-python/values.schema.json @@ -836,6 +836,32 @@ } } } + }, + "certificates": { + "description": "It can be used to inject certificate authority into the services, if the Helm chart in the catalog allows it you can bind this value to the Helm chart value to add some certificate authorities in the pod.", + "type": "object", + "x-onyxia": { + "overwriteSchemaWith": "certificates.json" + }, + "default": {}, + "properties": { + "cacerts": { + "type": "string", + "description": "String of crts concatenated in base64, can be a url", + "default": "", + "x-onyxia": { + "hidden": true + } + }, + "pathToCaBundle": { + "type": "string", + "description": "String path where a bundle is made or injected by third party solution", + "default": "/usr/local/share/ca-certificates/", + "x-onyxia": { + "hidden": true + } + } + } }, "message": { "type": "object", diff --git a/charts/vscode-python/values.yaml b/charts/vscode-python/values.yaml index bdc20548..a41c15c4 100644 --- a/charts/vscode-python/values.yaml +++ b/charts/vscode-python/values.yaml @@ -221,6 +221,10 @@ proxy: httpProxy: "" httpsProxy: "" +certificates: {} + # pathToCaBundle: /usr/local/share/ca-certificates/ + # cacerts: "" + message: fr: "" en: ""