1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
{{/*
# Copyright © 2017 Amdocs, Bell Canada
# Modifications Copyright © 2019 AT&T
# Copyright (c) 2021-2022 J. F. Lucas. All rights reserved.
# Copyright (c) 2021 Nordix Foundation.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
*/}}
{{/*
dcaegen2-services-common.configMap:
This template produces Kubernetes configMap(s) needed by a
DCAE microservice.
The template expects the full chart context as input. A chart for a
DCAE microservice references this template using:
{{ include "dcaegen2-services-common.configMap" . }}
The template directly references data in .Values, and indirectly (through its
use of templates from the ONAP "common" collection) references data in
.Release.
The template always produces a configMap containing the microservice's
initial configuration data. (See the documentation for
dcaegen2-services-common.microserviceDeployment for more details.)
If the microservice is using one or more Data Router (DR) feeds, the
template produces a configMap containing the information needed to
provision the feed(s). An init container performs the provisioning.
If the microservice acts as a DR publisher for one or more feeds, the
template produces a configMap containing the information needed to
provision the publisher(s). An init container performs the provisioning.
If the microservice acts as a DR subscriber for one or more feeds, the
template produces a configMap containing the information needed to
provision the subscribeer(s). An init container performs the provisioning.
*/}}
{{- define "dcaegen2-services-common.configMap" -}}
{{- $appConf := .Values.applicationConfig | default (dict) -}}
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ include "common.fullname" . }}-application-config-configmap
namespace: {{ include "common.namespace" . }}
labels: {{ include "common.labels" . | nindent 6 }}
data:
application_config.yaml: |
{{ $appConf | toYaml | indent 4 }}
{{- if .Values.drFeedConfig }}
---
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ include "common.fullname" . }}-feeds-config
namespace: {{ include "common.namespace" . }}
labels: {{ include "common.labels" . | nindent 6 }}
data:
{{- range $i, $feed := .Values.drFeedConfig }}
feedConfig-{{$i}}.json: |-
{{ $feed | toJson | indent 2 }}
{{- end }}
{{- end }}
{{- if .Values.drPubConfig }}
---
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ include "common.fullname" . }}-drpub-config
namespace: {{ include "common.namespace" . }}
labels: {{ include "common.labels" . | nindent 6 }}
data:
{{- range $i, $drpub := .Values.drPubConfig }}
drpubConfig-{{$i}}.json: |-
{{ $drpub | toJson | indent 2 }}
{{- end }}
{{- end }}
{{- if .Values.drSubConfig }}
---
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ include "common.fullname" . }}-drsub-config
namespace: {{ include "common.namespace" . }}
labels: {{ include "common.labels" . | nindent 6 }}
data:
{{- range $i, $drsub := .Values.drSubConfig }}
drsubConfig-{{$i}}.json: |-
{{ $drsub | toJson | indent 2 }}
{{- end }}
{{- end }}
{{- end }}
|