summaryrefslogtreecommitdiff
path: root/astroshop-helm/checkout/templates
diff options
context:
space:
mode:
Diffstat (limited to 'astroshop-helm/checkout/templates')
-rw-r--r--astroshop-helm/checkout/templates/_helpers.tpl62
-rw-r--r--astroshop-helm/checkout/templates/deployment.yaml104
-rw-r--r--astroshop-helm/checkout/templates/service.yaml16
3 files changed, 182 insertions, 0 deletions
diff --git a/astroshop-helm/checkout/templates/_helpers.tpl b/astroshop-helm/checkout/templates/_helpers.tpl
new file mode 100644
index 0000000..0efb2b1
--- /dev/null
+++ b/astroshop-helm/checkout/templates/_helpers.tpl
@@ -0,0 +1,62 @@
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "checkout.name" -}}
+{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }}
+{{- end }}
+
+{{/*
+Create a default fully qualified app name.
+We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
+If release name contains chart name it will be used as a full name.
+*/}}
+{{- define "checkout.fullname" -}}
+{{- if .Values.fullnameOverride }}
+{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }}
+{{- else }}
+{{- $name := default .Chart.Name .Values.nameOverride }}
+{{- if contains $name .Release.Name }}
+{{- .Release.Name | trunc 63 | trimSuffix "-" }}
+{{- else }}
+{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }}
+{{- end }}
+{{- end }}
+{{- end }}
+
+{{/*
+Create chart name and version as used by the chart label.
+*/}}
+{{- define "checkout.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
+{{- end }}
+
+{{/*
+Common labels
+*/}}
+{{- define "checkout.labels" -}}
+helm.sh/chart: {{ include "checkout.chart" . }}
+{{ include "checkout.selectorLabels" . }}
+{{- if .Chart.AppVersion }}
+app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
+{{- end }}
+app.kubernetes.io/managed-by: {{ .Release.Service }}
+{{- end }}
+
+{{/*
+Selector labels
+*/}}
+{{- define "checkout.selectorLabels" -}}
+app.kubernetes.io/name: {{ include "checkout.name" . }}
+app.kubernetes.io/instance: {{ .Release.Name }}
+{{- end }}
+
+{{/*
+Create the name of the service account to use
+*/}}
+{{- define "checkout.serviceAccountName" -}}
+{{- if .Values.serviceAccount.create }}
+{{- default (include "checkout.fullname" .) .Values.serviceAccount.name }}
+{{- else }}
+{{- default "default" .Values.serviceAccount.name }}
+{{- end }}
+{{- end }}
diff --git a/astroshop-helm/checkout/templates/deployment.yaml b/astroshop-helm/checkout/templates/deployment.yaml
new file mode 100644
index 0000000..b950c50
--- /dev/null
+++ b/astroshop-helm/checkout/templates/deployment.yaml
@@ -0,0 +1,104 @@
+apiVersion: apps/v1
+kind: Deployment
+metadata:
+ namespace: {{ .Values.namespace }}
+ name: {{ include "checkout.fullname" . }}
+ labels:
+ app.kubernetes.io/component: checkoutservice
+ app.kubernetes.io/part-of: opentelemetry-demo
+ opentelemetry.io/name: {{ .Values.namespace }}-{{ include "checkout.fullname" . }}
+ {{- include "checkout.labels" . | nindent 4 }}
+spec:
+ replicas: {{ .Values.opentelemetryDemoCheckoutservice.replicas }}
+ revisionHistoryLimit: {{ .Values.opentelemetryDemoCheckoutservice.revisionHistoryLimit
+ }}
+ selector:
+ matchLabels:
+ opentelemetry.io/name: {{ .Values.namespace }}-{{ include "checkout.fullname" . }}
+ {{- include "checkout.selectorLabels" . | nindent 6 }}
+ template:
+ metadata:
+ labels:
+ app.kubernetes.io/component: checkoutservice
+ app.kubernetes.io/instance: opentelemetry-demo
+ app.kubernetes.io/name: {{ .Values.namespace }}-{{ include "checkout.fullname" . }}
+ opentelemetry.io/name: {{ .Values.namespace }}-{{ include "checkout.fullname" . }}
+ {{- include "checkout.selectorLabels" . | nindent 8 }}
+ spec:
+ containers:
+ - env:
+ - name: OTEL_SERVICE_NAME
+ valueFrom:
+ fieldRef:
+ apiVersion: v1
+ fieldPath: metadata.labels['app.kubernetes.io/component']
+ - name: OTEL_COLLECTOR_NAME
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.otelCollectorName
+ }}
+ - name: OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.otelExporterOtlpMetricsTemporalityPreference
+ }}
+ - name: CHECKOUT_PORT
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.checkoutServicePort
+ }}
+ - name: CART_ADDR
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.cartServiceAddr
+ }}
+ - name: CURRENCY_ADDR
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.currencyServiceAddr
+ }}
+ - name: EMAIL_ADDR
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.emailServiceAddr
+ }}
+ - name: PAYMENT_ADDR
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.paymentServiceAddr
+ }}
+ - name: PRODUCT_CATALOG_ADDR
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.productCatalogServiceAddr
+ }}
+ - name: SHIPPING_ADDR
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.shippingServiceAddr
+ }}
+ - name: KAFKA_ADDR
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.kafkaServiceAddr
+ }}
+ - name: FLAGD_HOST
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.flagdHost
+ }}
+ - name: FLAGD_PORT
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.flagdPort
+ }}
+ - name: OTEL_EXPORTER_OTLP_ENDPOINT
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.otelExporterOtlpEndpoint
+ }}
+ - name: OTEL_RESOURCE_ATTRIBUTES
+ value: {{ quote .Values.opentelemetryDemoCheckoutservice.checkoutservice.env.otelResourceAttributes
+ }}
+ - name: KUBERNETES_CLUSTER_DOMAIN
+ value: {{ quote .Values.kubernetesClusterDomain }}
+ image: '{{ .Values.opentelemetryDemoCheckoutservice.checkoutservice.image.repository
+ }}:{{ .Values.opentelemetryDemoCheckoutservice.checkoutservice.image.tag | default
+ .Chart.AppVersion }}'
+ imagePullPolicy: {{ .Values.opentelemetryDemoCheckoutservice.checkoutservice.imagePullPolicy
+ }}
+ name: checkoutservice
+ ports:
+ - containerPort: 8080
+ name: service
+ resources: {{- toYaml .Values.opentelemetryDemoCheckoutservice.checkoutservice.resources
+ | nindent 10 }}
+ initContainers:
+ - command:
+ - sh
+ - -c
+ - until nc -z -v -w30 opentelemetry-demo-kafka 9092; do echo waiting for kafka;
+ sleep 2; done;
+ env:
+ - name: KUBERNETES_CLUSTER_DOMAIN
+ value: {{ quote .Values.kubernetesClusterDomain }}
+ image: '{{ .Values.opentelemetryDemoCheckoutservice.waitForKafka.image.repository
+ }}:{{ .Values.opentelemetryDemoCheckoutservice.waitForKafka.image.tag | default
+ .Chart.AppVersion }}'
+ name: wait-for-kafka
+ resources: {}
+ serviceAccountName: {{ .Values.serviceAccount.name }}
diff --git a/astroshop-helm/checkout/templates/service.yaml b/astroshop-helm/checkout/templates/service.yaml
new file mode 100644
index 0000000..3ad61a3
--- /dev/null
+++ b/astroshop-helm/checkout/templates/service.yaml
@@ -0,0 +1,16 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.namespace }}-{{ include "checkout.fullname" . }}
+ labels:
+ app.kubernetes.io/component: checkoutservice
+ app.kubernetes.io/part-of: opentelemetry-demo
+ opentelemetry.io/name: opentelemetry-demo-checkoutservice
+ {{- include "checkout.labels" . | nindent 4 }}
+spec:
+ type: {{ .Values.opentelemetryDemoCheckoutservice.type }}
+ selector:
+ opentelemetry.io/name: opentelemetry-demo-checkoutservice
+ {{- include "checkout.selectorLabels" . | nindent 4 }}
+ ports:
+ {{- .Values.opentelemetryDemoCheckoutservice.ports | toYaml | nindent 2 }}