Fix configuration file permission in a1pms
[it/dep.git] / nonrtric / helm / policymanagementservice / templates / statefulset.yaml
index 779d51f..a279067 100644 (file)
@@ -1,5 +1,6 @@
 ################################################################################
-#   Copyright (c) 2020 Nordix Foundation.                                      #
+#   Copyright (c) 2020-2023 Nordix Foundation.                                 #
+#   Copyright (C) 2023-2024 OpenInfra Foundation Europe. All rights reserved.  #
 #                                                                              #
 #   Licensed under the Apache License, Version 2.0 (the "License");            #
 #   you may not use this file except in compliance with the License.           #
@@ -41,6 +42,22 @@ spec:
         release: {{ .Release.Name }}
     spec:
       hostname: {{ include "common.name.policymanagementservice" . }}
+      initContainers:
+      - name: copy
+        image: busybox:1.28
+        command:
+        - /bin/sh
+        - -c
+        - FILE=/var/policy-management-service/application_configuration.json;
+          if [ ! -f $FILE ]; then
+            cp  /etc/app/policy-management-service/application_configuration_json_initial/application_configuration.json $FILE;
+          fi;
+          chmod 666 $FILE;
+        volumeMounts:
+        - name: {{ include "common.name.policymanagementservice" . }}-vardata
+          mountPath: "/var/policy-management-service"
+        - name: {{ include "common.name.policymanagementservice" . }}-application-configuration-json-initial
+          mountPath: /etc/app/policy-management-service/application_configuration_json_initial
       containers:
       - name: {{ include "common.container.policymanagementservice" . }}
         image: {{ .Values.policymanagementservice.image.registry }}/{{ .Values.policymanagementservice.image.name }}:{{ .Values.policymanagementservice.image.tag }}
@@ -64,17 +81,24 @@ spec:
         volumeMounts:
         - name: {{ include "common.name.policymanagementservice" . }}-vardata
           mountPath: "/var/policy-management-service"
-        - name: {{ include "common.name.policymanagementservice" . }}-policy-config
+        - name: {{ include "common.name.policymanagementservice" . }}-application-yaml
           mountPath: /opt/app/policy-agent/config
-        - name: {{ include "common.name.policymanagementservice" . }}-policy-data
-          mountPath: /opt/app/policy-agent/data
+        - name: {{ include "common.name.policymanagementservice" . }}-application-configuration-json-initial
+          mountPath: /etc/app/policy-management-service/application_configuration_json_initial
       volumes:
-        - name: {{ include "common.name.policymanagementservice" . }}-policy-config
+        - name: {{ include "common.name.policymanagementservice" . }}-application-yaml
           configMap:
-            name: {{ include "common.name.policymanagementservice" . }}-configmap-config
-        - name: {{ include "common.name.policymanagementservice" . }}-policy-data
+            name: {{ include "common.name.policymanagementservice" . }}-configmap-application-yaml
+        - name: {{ include "common.name.policymanagementservice" . }}-application-configuration-json-initial
           configMap:
-            name: {{ include "common.name.policymanagementservice" . }}-configmap-data
-        - name: {{ include "common.name.policymanagementservice" . }}-vardata
-          persistentVolumeClaim:
-            claimName: {{ include "common.name.policymanagementservice" . }}-vardata-pvc
+            name: {{ include "common.name.policymanagementservice" . }}-configmap-application-json-configuration
+  volumeClaimTemplates:
+    - metadata:
+        name: {{ include "common.name.policymanagementservice" . }}-vardata
+      spec:
+        accessModes:
+          - ReadWriteOnce
+        storageClassName: "{{ .Values.policymanagementservice.persistence.storageClassName }}"
+        resources:
+          requests:
+            storage: "{{ .Values.policymanagementservice.persistence.size }}"