diff --git a/README.md b/README.md
index 6f3c1f5b7..ad35a6d2b 100644
--- a/README.md
+++ b/README.md
@@ -21,15 +21,18 @@ Sample .NET Core reference application, powered by Microsoft, based on a simplif
| Ordering API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=198&branchName=dev) | Webhooks Client | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=208&branchName=dev) |
| Payment API | [](https://msftdevtools.visualstudio.com/eShopOnContainers/_build/latest?definitionId=205&branchName=dev) | | |
-_**Dev** branch contains the latest **beta** code and their images are tagged with `:dev` in our [Docker Hub](https://hub.docker.com/u/eshop)_
+_**Dev** branch contains the latest **beta** code and their images are tagged with `:linux-dev` in our [Docker Hub](https://hub.docker.com/u/eshop)_
+
+## Are you new to **microservices** and **cloud-native development**?
+Take a look at the free course [Create and deploy a cloud-native ASP.NET Core microservice](https://docs.microsoft.com/en-us/learn/modules/microservices-aspnet-core/) on MS Learn. This module explains microservices concepts, cloud-native technologies, and reduce the friction in getting started with `eShopOnContainers`.
## Getting Started
-eShopOnContainers is provided in two flavors: Basic and Advanced.
+*eShopOnContainers* is provided in two flavors: Basic and Advanced.
### Basic scenario
-The basic scenario can be run locally using docker compose, and also deployed to a local Kubernetes cluster. Refer these Wiki pages to Get Started:
+The basic scenario can be run locally using docker-compose, and also deployed to a local Kubernetes cluster. Refer to these Wiki pages to Get Started:
- [CLI or Visual Studio Code](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Windows-setup)
- [Visual Studio (F5 experience)](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Windows-setup#optional---use-visual-studio)
@@ -44,6 +47,7 @@ The Advanced scenario can be run only in a Kubernetes cluster. Currently this sc
In the future more features will be implemented in the advanced scenario.
+
## IMPORTANT NOTES!
**You can use either the latest version of Visual Studio or simply Docker CLI and .NET CLI for Windows, Mac and Linux**.
@@ -55,7 +59,7 @@ Do you want to be up-to-date on .NET Architecture guidance and reference apps li
## Updated for .NET Core 3.1 (LTS)
-eShopOnContainers is updated to .NET Core 3.1 "wave" of technologies. Not just compilation but also new recommended code in EF Core, ASP.NET Core, and other new related versions and a several significant changes.
+eShopOnContainers is updated to .NET Core 3.1 "wave" of technologies. Not just compilation but also new recommended code in EF Core, ASP.NET Core, and other new related versions with several significant changes.
**See more details in the [Release notes](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Release-notes) wiki page**.
@@ -82,11 +86,12 @@ You can download them and start reviewing these Guides/eBooks here:
| Architecting & Developing | Containers Lifecycle & CI/CD | App patterns with Xamarin.Forms |
| ------------ | ------------| ------------|
-| [](https://aka.ms/microservicesebook) | [](https://aka.ms/dockerlifecycleebook) | [](https://aka.ms/xamarinpatternsebook) |
-| **Download .PDF** | **Download** | **Download** |
+| [](https://aka.ms/microservicesebook) | [](https://aka.ms/dockerlifecycleebook) | [](https://aka.ms/xamarinpatternsebook) |
+| **Download PDF** | **Download PDF** | **Download PDF** |
For more free e-Books check out [.NET Architecture center](https://dot.net/architecture). If you have an e-book feedback, let us know by creating a new issue here:
+
## Read further
- [Explore the application](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Explore-the-application)
diff --git a/build/azure-devops/multiarch.yaml b/build/azure-devops/multiarch.yaml
index 162128d0a..1639fff87 100644
--- a/build/azure-devops/multiarch.yaml
+++ b/build/azure-devops/multiarch.yaml
@@ -26,7 +26,7 @@ jobs:
mkdir -p ~/.docker
sed '$ s/.$//' $DOCKER_CONFIG/config.json > ~/.docker/config.json
echo ',"experimental": "enabled" }' >> ~/.docker/config.json
- docker --config ~/.docker manifest create ${{ parameters.registry }}/${{ parameters.image }}:{{ parameters.branch }} ${{ parameters.registry }}/${{ parameters.image }}:linux-${{ parameters.branch }}
+ docker --config ~/.docker manifest create ${{ parameters.registry }}/${{ parameters.image }}:${{ parameters.branch }} ${{ parameters.registry }}/${{ parameters.image }}:linux-${{ parameters.branch }}
docker --config ~/.docker manifest create ${{ parameters.registry }}/${{ parameters.image }}:latest ${{ parameters.registry }}/${{ parameters.image }}:linux-latest
docker --config ~/.docker manifest push ${{ parameters.registry }}/${{ parameters.image }}:${{ parameters.branch }}
docker --config ~/.docker manifest push ${{ parameters.registry }}/${{ parameters.image }}:latest
diff --git a/deploy/k8s/archived/README.md b/deploy/k8s/archived/README.md
new file mode 100644
index 000000000..3e464c3d1
--- /dev/null
+++ b/deploy/k8s/archived/README.md
@@ -0,0 +1,8 @@
+# Kubernetes deployment
+
+This folder contains the files required to deploy eShopOnContainers to a Kubernetes cluster.
+
+For more information see the following articles in the [wiki](https://github.com/dotnet-architecture/eShopOnContainers/wiki):
+
+- [Deploy to Local Kubernetes](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Local-Kubernetes)
+- [Deploy to Azure Kubernetes Service (AKS)](https://github.com/dotnet-architecture/eShopOnContainers/wiki/Deploy-to-Azure-Kubernetes-Service-(AKS))
diff --git a/deploy/k8s/archived/create-aks.ps1 b/deploy/k8s/archived/create-aks.ps1
new file mode 100644
index 000000000..327f5fd6b
--- /dev/null
+++ b/deploy/k8s/archived/create-aks.ps1
@@ -0,0 +1,50 @@
+Param(
+ [parameter(Mandatory=$true)][string]$resourceGroupName,
+ [parameter(Mandatory=$true)][string]$location,
+ [parameter(Mandatory=$true)][string]$serviceName,
+ [parameter(Mandatory=$true)][string]$dnsNamePrefix,
+ [parameter(Mandatory=$false)][string]$registryName,
+ [parameter(Mandatory=$true)][bool]$createAcr=$true,
+ [parameter(Mandatory=$false)][int]$nodeCount=3,
+ [parameter(Mandatory=$false)][string]$nodeVMSize="Standard_D2_v2",
+ [parameter(Mandatory=$false)][bool]$enableHttpApplicationAddon=$true,
+ [parameter(Mandatory=$false)][bool]$enableAzureMonitoring=$false,
+ [parameter(Mandatory=$false)][ValidateSet("VirtualMachineScaleSets","AvailabilitySet",IgnoreCase=$true)]$vmSetType="VirtualMachineScaleSets"
+)
+
+# Create resource group
+Write-Host "Creating Azure Resource Group..." -ForegroundColor Yellow
+az group create --name=$resourceGroupName --location=$location
+
+if ($createAcr -eq $true) {
+ # Create Azure Container Registry
+ if ([string]::IsNullOrEmpty($registryName)) {
+ $registryName=$serviceName
+ }
+ Write-Host "Creating Azure Container Registry named $registryName" -ForegroundColor Yellow
+ az acr create -n $registryName -g $resourceGroupName -l $location --admin-enabled true --sku Basic
+}
+
+# Create kubernetes cluster in AKS
+Write-Host "Creating AKS $resourceGroupName/$serviceName" -ForegroundColor Yellow
+az aks create --resource-group=$resourceGroupName --name=$serviceName --dns-name-prefix=$dnsNamePrefix --generate-ssh-keys --node-count=$nodeCount --node-vm-size=$nodeVMSize --vm-set-type $vmSetType
+
+if ($enableHttpApplicationAddon) {
+ Write-Host "Enabling Http Applciation Routing in AKS $serviceName" -ForegroundColor Yellow
+ az aks enable-addons --resource-group $resourceGroupName --name $serviceName --addons http_application_routing
+}
+
+if ($enableAzureMonitoring) {
+ Write-Host "Enabling Azure Monitoring in AKS $serviceName" -ForegroundColor Yellow
+ az aks enable-addons --resource-group $resourceGroupName --name $serviceName --addons monitoring
+}
+
+# Retrieve kubernetes cluster configuration and save it under ~/.kube/config
+Write-Host "Getting Kubernetes config..." -ForegroundColor Yellow
+az aks get-credentials --resource-group=$resourceGroupName --name=$serviceName
+
+if ($createAcr -eq $true) {
+ # Show ACR credentials
+ Write-Host "ACR $registryName credentials:" -ForegroundColor Yellow
+ az acr credential show -n $registryName
+}
diff --git a/deploy/k8s/archived/dashboard-adminuser.yaml b/deploy/k8s/archived/dashboard-adminuser.yaml
new file mode 100644
index 000000000..9f24303cd
--- /dev/null
+++ b/deploy/k8s/archived/dashboard-adminuser.yaml
@@ -0,0 +1,18 @@
+apiVersion: v1
+kind: ServiceAccount
+metadata:
+ name: admin-user
+ namespace: kubernetes-dashboard
+---
+apiVersion: rbac.authorization.k8s.io/v1
+kind: ClusterRoleBinding
+metadata:
+ name: admin-user
+roleRef:
+ apiGroup: rbac.authorization.k8s.io
+ kind: ClusterRole
+ name: cluster-admin
+subjects:
+- kind: ServiceAccount
+ name: admin-user
+ namespace: kubernetes-dashboard
diff --git a/deploy/k8s/archived/enable-tls.ps1 b/deploy/k8s/archived/enable-tls.ps1
new file mode 100644
index 000000000..cd4ef3ffe
--- /dev/null
+++ b/deploy/k8s/archived/enable-tls.ps1
@@ -0,0 +1,20 @@
+Param (
+[parameter(Mandatory=$false)][string]$aksName="",
+[parameter(Mandatory=$false)][string]$aksRg=""
+)
+
+if ($aksName -and $aksRg) {
+
+ $aks=$(az aks show -n $aksName -g $aksRg -o json | ConvertFrom-Json)
+ if (-not $aks) {
+ Write-Host "AKS $aksName not found in RG $aksRg" -ForegroundColor Red
+ exit 1
+ }
+
+ Write-Host "Switching kubectl context to $aksRg/$aksName" -ForegroundColor Yellow
+ az aks get-credentials -g $aksRg -n $aksName
+}
+
+Write-Host "Installing cert-manager on current cluster"
+
+kubectl apply --validate=false -f https://github.com/jetstack/cert-manager/releases/download/v0.11.0/cert-manager.yaml --validate=false
diff --git a/deploy/k8s/archived/helm-rbac.yaml b/deploy/k8s/archived/helm-rbac.yaml
new file mode 100644
index 000000000..b6180329a
--- /dev/null
+++ b/deploy/k8s/archived/helm-rbac.yaml
@@ -0,0 +1,18 @@
+apiVersion: v1
+kind: ServiceAccount
+metadata:
+ name: tiller
+ namespace: kube-system
+---
+apiVersion: rbac.authorization.k8s.io/v1
+kind: ClusterRoleBinding
+metadata:
+ name: tiller
+roleRef:
+ apiGroup: rbac.authorization.k8s.io
+ kind: ClusterRole
+ name: cluster-admin
+subjects:
+ - kind: ServiceAccount
+ name: tiller
+ namespace: kube-system
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/aks-httpaddon-cfg.yaml b/deploy/k8s/archived/helm/aks-httpaddon-cfg.yaml
new file mode 100644
index 000000000..b9576b0b6
--- /dev/null
+++ b/deploy/k8s/archived/helm/aks-httpaddon-cfg.yaml
@@ -0,0 +1,12 @@
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ labels:
+# addonmanager.kubernetes.io/mode: Reconcile
+ app: addon-http-application-routing-ingress-nginx
+ kubernetes.io/cluster-service: "true"
+ name: addon-http-application-routing-nginx-configuration
+ namespace: kube-system
+data:
+ proxy-buffer-size: "128k"
+ proxy-buffers: "4 256k"
diff --git a/deploy/k8s/archived/helm/apigwmm/.helmignore b/deploy/k8s/archived/helm/apigwmm/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/apigwmm/Chart.yaml b/deploy/k8s/archived/helm/apigwmm/Chart.yaml
new file mode 100644
index 000000000..50b3d07c6
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: apigwmm
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/apigwmm/envoy.yaml b/deploy/k8s/archived/helm/apigwmm/envoy.yaml
new file mode 100644
index 000000000..54b1afa06
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/envoy.yaml
@@ -0,0 +1,75 @@
+admin:
+ access_log_path: "/dev/null"
+ address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 8001
+static_resources:
+ listeners:
+ - address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 80
+ filter_chains:
+ - filters:
+ - name: envoy.http_connection_manager
+ config:
+ codec_type: auto
+ stat_prefix: ingress_http
+ route_config:
+ name: eshop_backend_route
+ virtual_hosts:
+ - name: eshop_backend
+ domains:
+ - "*"
+ routes:
+ - name: "m-short"
+ match:
+ prefix: "/m/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/marketing-api/"
+ cluster: marketing
+ - name: "m-long"
+ match:
+ prefix: "/marketing-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: marketing
+ http_filters:
+ - name: envoy.router
+ access_log:
+ - name: envoy.file_access_log
+ filter:
+ not_health_check_filter: {}
+ config:
+ json_format:
+ time: "%START_TIME%"
+ protocol: "%PROTOCOL%"
+ duration: "%DURATION%"
+ request_method: "%REQ(:METHOD)%"
+ request_host: "%REQ(HOST)%"
+ path: "%REQ(X-ENVOY-ORIGINAL-PATH?:PATH)%"
+ response_flags: "%RESPONSE_FLAGS%"
+ route_name: "%ROUTE_NAME%"
+ upstream_host: "%UPSTREAM_HOST%"
+ upstream_cluster: "%UPSTREAM_CLUSTER%"
+ upstream_local_address: "%UPSTREAM_LOCAL_ADDRESS%"
+ path: "/tmp/access.log"
+ clusters:
+ - name: marketing
+ connect_timeout: 0.25s
+ type: logical_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: marketing-api
+ port_value: 80
+ - name: locations
+ connect_timeout: 0.25s
+ type: logical_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: locations-api
+ port_value: 80
diff --git a/deploy/k8s/archived/helm/apigwmm/templates/NOTES.txt b/deploy/k8s/archived/helm/apigwmm/templates/NOTES.txt
new file mode 100644
index 000000000..30ef33447
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/templates/NOTES.txt
@@ -0,0 +1,2 @@
+eShop API Gateway for Mobile Marketing services installed
+----------------------------------------------------------
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwmm/templates/_helpers.tpl b/deploy/k8s/archived/helm/apigwmm/templates/_helpers.tpl
new file mode 100644
index 000000000..fd3d89212
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "apigwmm.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 "apigwmm.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 "apigwmm.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/apigwmm/templates/_names.tpl b/deploy/k8s/archived/helm/apigwmm/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwmm/templates/deployment.yaml b/deploy/k8s/archived/helm/apigwmm/templates/deployment.yaml
new file mode 100644
index 000000000..f93706bb9
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/templates/deployment.yaml
@@ -0,0 +1,110 @@
+{{- $name := include "apigwmm.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "apigwmm.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "apigwmm.name" . }}
+ chart: {{ template "apigwmm.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "apigwmm.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "apigwmm.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ volumes:
+ - name: config
+ configMap:
+ name: {{ $envoycfgname }}
+ items:
+ - key: envoy.yaml
+ path: envoy.yaml
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: IfNotPresent
+ volumeMounts:
+ - name: config
+ mountPath: {{ .Values.envoy.configPath }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ - name: admin
+ containerPort: 8001
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/apigwmm/templates/envoy-cm.yaml b/deploy/k8s/archived/helm/apigwmm/templates/envoy-cm.yaml
new file mode 100644
index 000000000..71728d084
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/templates/envoy-cm.yaml
@@ -0,0 +1,14 @@
+{{- $name := include "apigwmm.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "envoy-{{ $name }}"
+ labels:
+ app: {{ template "apigwmm.name" . }}
+ chart: {{ template "apigwmm.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ {{ (.Files.Glob "envoy.yaml").AsConfig | indent 2 }}
+
diff --git a/deploy/k8s/archived/helm/apigwmm/templates/ingress.yaml b/deploy/k8s/archived/helm/apigwmm/templates/ingress.yaml
new file mode 100644
index 000000000..44e9a90fc
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/templates/ingress.yaml
@@ -0,0 +1,46 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.mobilemarketingapigw -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "apigwmm.fullname" . }}
+ labels:
+ app: {{ template "apigwmm.name" . }}
+ chart: {{ template "apigwmm.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/apigwmm/templates/service.yaml b/deploy/k8s/archived/helm/apigwmm/templates/service.yaml
new file mode 100644
index 000000000..286277c7d
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/templates/service.yaml
@@ -0,0 +1,23 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.mobilemarketingapigw }}
+ labels:
+ app: {{ template "apigwmm.name" . }}
+ chart: {{ template "apigwmm.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ - port: {{ .Values.service.adminPort }}
+ targetPort: admin
+ protocol: TCP
+ name: admin
+ selector:
+ app: {{ template "apigwmm.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/apigwmm/values.yaml b/deploy/k8s/archived/helm/apigwmm/values.yaml
new file mode 100644
index 000000000..21f12f27a
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwmm/values.yaml
@@ -0,0 +1,45 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /mobilemarketingapigw
+
+image:
+ repository: envoyproxy/envoy
+ tag: v1.11.1
+
+service:
+ type: ClusterIP
+ port: 80
+ adminPort: 8001
+
+ingress:
+ enabled: true
+ annotations:
+ nginx.ingress.kubernetes.io/rewrite-target: "/"
+ ingress.kubernetes.io/rewrite-target: "/"
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+env: {}
+
+envoy:
+ configPath: /etc/envoy
+
+probes:
+ liveness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 15
+ port: 8001
+ readiness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 60
+ port: 8001
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwms/.helmignore b/deploy/k8s/archived/helm/apigwms/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/apigwms/Chart.yaml b/deploy/k8s/archived/helm/apigwms/Chart.yaml
new file mode 100644
index 000000000..3ad3fdf46
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: apigwms
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/apigwms/envoy.yaml b/deploy/k8s/archived/helm/apigwms/envoy.yaml
new file mode 100644
index 000000000..1ae8c45a1
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/envoy.yaml
@@ -0,0 +1,139 @@
+admin:
+ access_log_path: "/dev/null"
+ address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 8001
+static_resources:
+ listeners:
+ - address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 80
+ filter_chains:
+ - filters:
+ - name: envoy.http_connection_manager
+ config:
+ codec_type: auto
+ stat_prefix: ingress_http
+ route_config:
+ name: eshop_backend_route
+ virtual_hosts:
+ - name: eshop_backend
+ domains:
+ - "*"
+ routes:
+ - name: "c-short"
+ match:
+ prefix: "/c/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/catalog-api/"
+ cluster: catalog
+ - name: "c-long"
+ match:
+ prefix: "/catalog-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: catalog
+ - name: "o-short"
+ match:
+ prefix: "/o/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/ordering-api/"
+ cluster: ordering
+ - name: "o-long"
+ match:
+ prefix: "/ordering-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: ordering
+ - name: "h-long"
+ match:
+ prefix: "/hub/notificationhub"
+ route:
+ auto_host_rewrite: true
+ cluster: signalr-hub
+ timeout: 300s
+ - name: "b-short"
+ match:
+ prefix: "/b/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/basket-api/"
+ cluster: basket
+ - name: "b-long"
+ match:
+ prefix: "/basket-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: basket
+ - name: "agg"
+ match:
+ prefix: "/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/"
+ cluster: shoppingagg
+ http_filters:
+ - name: envoy.router
+ access_log:
+ - name: envoy.file_access_log
+ filter:
+ not_health_check_filter: {}
+ config:
+ json_format:
+ time: "%START_TIME%"
+ protocol: "%PROTOCOL%"
+ duration: "%DURATION%"
+ request_method: "%REQ(:METHOD)%"
+ request_host: "%REQ(HOST)%"
+ path: "%REQ(X-ENVOY-ORIGINAL-PATH?:PATH)%"
+ response_flags: "%RESPONSE_FLAGS%"
+ route_name: "%ROUTE_NAME%"
+ upstream_host: "%UPSTREAM_HOST%"
+ upstream_cluster: "%UPSTREAM_CLUSTER%"
+ upstream_local_address: "%UPSTREAM_LOCAL_ADDRESS%"
+ path: "/tmp/access.log"
+ clusters:
+ - name: shoppingagg
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: webshoppingagg
+ port_value: 80
+ - name: catalog
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: catalog-api
+ port_value: 80
+ - name: basket
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: basket-api
+ port_value: 80
+ - name: ordering
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: ordering-api
+ port_value: 80
+ - name: signalr-hub
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: ordering-signalrhub
+ port_value: 80
diff --git a/deploy/k8s/archived/helm/apigwms/templates/NOTES.txt b/deploy/k8s/archived/helm/apigwms/templates/NOTES.txt
new file mode 100644
index 000000000..74b3eedda
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/templates/NOTES.txt
@@ -0,0 +1,2 @@
+eShop API Gateway for Mobile Shopping services installed
+--------------------------------------------------------
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwms/templates/_helpers.tpl b/deploy/k8s/archived/helm/apigwms/templates/_helpers.tpl
new file mode 100644
index 000000000..2ae403c2f
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "apigwms.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 "apigwms.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 "apigwms.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/apigwms/templates/_names.tpl b/deploy/k8s/archived/helm/apigwms/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwms/templates/deployment.yaml b/deploy/k8s/archived/helm/apigwms/templates/deployment.yaml
new file mode 100644
index 000000000..2c5703103
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/templates/deployment.yaml
@@ -0,0 +1,110 @@
+{{- $name := include "apigwms.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "apigwms.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "apigwms.name" . }}
+ chart: {{ template "apigwms.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "apigwms.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "apigwms.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ volumes:
+ - name: config
+ configMap:
+ name: {{ $envoycfgname }}
+ items:
+ - key: envoy.yaml
+ path: envoy.yaml
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: IfNotPresent
+ volumeMounts:
+ - name: config
+ mountPath: {{ .Values.envoy.configPath }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ - name: admin
+ containerPort: 8001
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/apigwms/templates/envoy-cm.yaml b/deploy/k8s/archived/helm/apigwms/templates/envoy-cm.yaml
new file mode 100644
index 000000000..76da5832b
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/templates/envoy-cm.yaml
@@ -0,0 +1,14 @@
+{{- $name := include "apigwms.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "envoy-{{ $name }}"
+ labels:
+ app: {{ template "apigwms.name" . }}
+ chart: {{ template "apigwms.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ {{ (.Files.Glob "envoy.yaml").AsConfig | indent 2 }}
+
diff --git a/deploy/k8s/archived/helm/apigwms/templates/ingress.yaml b/deploy/k8s/archived/helm/apigwms/templates/ingress.yaml
new file mode 100644
index 000000000..bc0c6d05b
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/templates/ingress.yaml
@@ -0,0 +1,47 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.mobileshoppingapigw -}}
+
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "apigwms.fullname" . }}
+ labels:
+ app: {{ template "apigwms.name" . }}
+ chart: {{ template "apigwms.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/apigwms/templates/service.yaml b/deploy/k8s/archived/helm/apigwms/templates/service.yaml
new file mode 100644
index 000000000..aa087d428
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/templates/service.yaml
@@ -0,0 +1,23 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.mobileshoppingapigw }}
+ labels:
+ app: {{ template "apigwms.name" . }}
+ chart: {{ template "apigwms.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ - port: {{ .Values.service.adminPort }}
+ targetPort: admin
+ protocol: TCP
+ name: admin
+ selector:
+ app: {{ template "apigwms.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/apigwms/values.yaml b/deploy/k8s/archived/helm/apigwms/values.yaml
new file mode 100644
index 000000000..4a92d85e9
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwms/values.yaml
@@ -0,0 +1,45 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /mobileshoppingapigw
+
+image:
+ repository: envoyproxy/envoy
+ tag: v1.11.1
+
+service:
+ type: ClusterIP
+ port: 80
+ adminPort: 8001
+
+ingress:
+ enabled: true
+ annotations:
+ nginx.ingress.kubernetes.io/rewrite-target: "/"
+ ingress.kubernetes.io/rewrite-target: "/"
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+env: {}
+
+envoy:
+ configPath: /etc/envoy
+
+probes:
+ liveness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 15
+ port: 8001
+ readiness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 60
+ port: 8001
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwwm/.helmignore b/deploy/k8s/archived/helm/apigwwm/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/apigwwm/Chart.yaml b/deploy/k8s/archived/helm/apigwwm/Chart.yaml
new file mode 100644
index 000000000..4c2082969
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: apigwwm
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/apigwwm/envoy.yaml b/deploy/k8s/archived/helm/apigwwm/envoy.yaml
new file mode 100644
index 000000000..c6f3421de
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/envoy.yaml
@@ -0,0 +1,75 @@
+admin:
+ access_log_path: "/dev/null"
+ address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 8001
+static_resources:
+ listeners:
+ - address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 80
+ filter_chains:
+ - filters:
+ - name: envoy.http_connection_manager
+ config:
+ codec_type: auto
+ stat_prefix: ingress_http
+ route_config:
+ name: eshop_backend_route
+ virtual_hosts:
+ - name: eshop_backend
+ domains:
+ - "*"
+ routes:
+ - name: "m-short"
+ match:
+ prefix: "/m/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/marketing-api/"
+ cluster: marketing
+ - name: "m-long"
+ match:
+ prefix: "/marketing-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: marketing
+ http_filters:
+ - name: envoy.router
+ access_log:
+ - name: envoy.file_access_log
+ filter:
+ not_health_check_filter: {}
+ config:
+ json_format:
+ time: "%START_TIME%"
+ protocol: "%PROTOCOL%"
+ duration: "%DURATION%"
+ request_method: "%REQ(:METHOD)%"
+ request_host: "%REQ(HOST)%"
+ path: "%REQ(X-ENVOY-ORIGINAL-PATH?:PATH)%"
+ response_flags: "%RESPONSE_FLAGS%"
+ route_name: "%ROUTE_NAME%"
+ upstream_host: "%UPSTREAM_HOST%"
+ upstream_cluster: "%UPSTREAM_CLUSTER%"
+ upstream_local_address: "%UPSTREAM_LOCAL_ADDRESS%"
+ path: "/tmp/access.log"
+ clusters:
+ - name: marketing
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: marketing-api
+ port_value: 80
+ - name: locations
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: locations-api
+ port_value: 80
diff --git a/deploy/k8s/archived/helm/apigwwm/templates/NOTES.txt b/deploy/k8s/archived/helm/apigwwm/templates/NOTES.txt
new file mode 100644
index 000000000..3420c97c8
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/templates/NOTES.txt
@@ -0,0 +1,2 @@
+eShop API Gateway for Web Marketing services installed
+------------------------------------------------------
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwwm/templates/_helpers.tpl b/deploy/k8s/archived/helm/apigwwm/templates/_helpers.tpl
new file mode 100644
index 000000000..194cf96ca
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "apigwwm.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 "apigwwm.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 "apigwwm.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/apigwwm/templates/_names.tpl b/deploy/k8s/archived/helm/apigwwm/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwwm/templates/deployment.yaml b/deploy/k8s/archived/helm/apigwwm/templates/deployment.yaml
new file mode 100644
index 000000000..6ceb1fa1b
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/templates/deployment.yaml
@@ -0,0 +1,110 @@
+{{- $name := include "apigwwm.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "apigwwm.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "apigwwm.name" . }}
+ chart: {{ template "apigwwm.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "apigwwm.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "apigwwm.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ volumes:
+ - name: config
+ configMap:
+ name: {{ $envoycfgname }}
+ items:
+ - key: envoy.yaml
+ path: envoy.yaml
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: IfNotPresent
+ volumeMounts:
+ - name: config
+ mountPath: {{ .Values.envoy.configPath }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ - name: admin
+ containerPort: 8001
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/apigwwm/templates/envoy-cm.yaml b/deploy/k8s/archived/helm/apigwwm/templates/envoy-cm.yaml
new file mode 100644
index 000000000..4d6307e36
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/templates/envoy-cm.yaml
@@ -0,0 +1,14 @@
+{{- $name := include "apigwwm.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "envoy-{{ $name }}"
+ labels:
+ app: {{ template "apigwwm.name" . }}
+ chart: {{ template "apigwwm.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ {{ (.Files.Glob "envoy.yaml").AsConfig | indent 2 -}}
+
diff --git a/deploy/k8s/archived/helm/apigwwm/templates/ingress.yaml b/deploy/k8s/archived/helm/apigwwm/templates/ingress.yaml
new file mode 100644
index 000000000..00d54c226
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/templates/ingress.yaml
@@ -0,0 +1,47 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.webmarketingapigw -}}
+
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "apigwwm.fullname" . }}
+ labels:
+ app: {{ template "apigwwm.name" . }}
+ chart: {{ template "apigwwm.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/apigwwm/templates/service.yaml b/deploy/k8s/archived/helm/apigwwm/templates/service.yaml
new file mode 100644
index 000000000..cb11cc665
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/templates/service.yaml
@@ -0,0 +1,23 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.webmarketingapigw }}
+ labels:
+ app: {{ template "apigwwm.name" . }}
+ chart: {{ template "apigwwm.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ - port: {{ .Values.service.adminPort }}
+ targetPort: admin
+ protocol: TCP
+ name: admin
+ selector:
+ app: {{ template "apigwwm.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/apigwwm/values.yaml b/deploy/k8s/archived/helm/apigwwm/values.yaml
new file mode 100644
index 000000000..d866c2d3c
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwwm/values.yaml
@@ -0,0 +1,46 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /webmarketingapigw
+
+image:
+ repository: envoyproxy/envoy
+ tag: v1.11.1
+
+service:
+ type: ClusterIP
+ port: 80
+ adminPort: 8001
+
+ingress:
+ enabled: true
+ annotations:
+ nginx.ingress.kubernetes.io/rewrite-target: "/"
+ ingress.kubernetes.io/rewrite-target: "/"
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env: {}
+
+envoy:
+ configPath: /etc/envoy
+
+probes:
+ liveness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 15
+ port: 8001
+ readiness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 60
+ port: 8001
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwws/.helmignore b/deploy/k8s/archived/helm/apigwws/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/apigwws/Chart.yaml b/deploy/k8s/archived/helm/apigwws/Chart.yaml
new file mode 100644
index 000000000..0a6c34e62
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: apigwws
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/apigwws/envoy.yaml b/deploy/k8s/archived/helm/apigwws/envoy.yaml
new file mode 100644
index 000000000..1ae8c45a1
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/envoy.yaml
@@ -0,0 +1,139 @@
+admin:
+ access_log_path: "/dev/null"
+ address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 8001
+static_resources:
+ listeners:
+ - address:
+ socket_address:
+ address: 0.0.0.0
+ port_value: 80
+ filter_chains:
+ - filters:
+ - name: envoy.http_connection_manager
+ config:
+ codec_type: auto
+ stat_prefix: ingress_http
+ route_config:
+ name: eshop_backend_route
+ virtual_hosts:
+ - name: eshop_backend
+ domains:
+ - "*"
+ routes:
+ - name: "c-short"
+ match:
+ prefix: "/c/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/catalog-api/"
+ cluster: catalog
+ - name: "c-long"
+ match:
+ prefix: "/catalog-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: catalog
+ - name: "o-short"
+ match:
+ prefix: "/o/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/ordering-api/"
+ cluster: ordering
+ - name: "o-long"
+ match:
+ prefix: "/ordering-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: ordering
+ - name: "h-long"
+ match:
+ prefix: "/hub/notificationhub"
+ route:
+ auto_host_rewrite: true
+ cluster: signalr-hub
+ timeout: 300s
+ - name: "b-short"
+ match:
+ prefix: "/b/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/basket-api/"
+ cluster: basket
+ - name: "b-long"
+ match:
+ prefix: "/basket-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: basket
+ - name: "agg"
+ match:
+ prefix: "/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/"
+ cluster: shoppingagg
+ http_filters:
+ - name: envoy.router
+ access_log:
+ - name: envoy.file_access_log
+ filter:
+ not_health_check_filter: {}
+ config:
+ json_format:
+ time: "%START_TIME%"
+ protocol: "%PROTOCOL%"
+ duration: "%DURATION%"
+ request_method: "%REQ(:METHOD)%"
+ request_host: "%REQ(HOST)%"
+ path: "%REQ(X-ENVOY-ORIGINAL-PATH?:PATH)%"
+ response_flags: "%RESPONSE_FLAGS%"
+ route_name: "%ROUTE_NAME%"
+ upstream_host: "%UPSTREAM_HOST%"
+ upstream_cluster: "%UPSTREAM_CLUSTER%"
+ upstream_local_address: "%UPSTREAM_LOCAL_ADDRESS%"
+ path: "/tmp/access.log"
+ clusters:
+ - name: shoppingagg
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: webshoppingagg
+ port_value: 80
+ - name: catalog
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: catalog-api
+ port_value: 80
+ - name: basket
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: basket-api
+ port_value: 80
+ - name: ordering
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: ordering-api
+ port_value: 80
+ - name: signalr-hub
+ connect_timeout: 0.25s
+ type: strict_dns
+ lb_policy: round_robin
+ hosts:
+ - socket_address:
+ address: ordering-signalrhub
+ port_value: 80
diff --git a/deploy/k8s/archived/helm/apigwws/templates/NOTES.txt b/deploy/k8s/archived/helm/apigwws/templates/NOTES.txt
new file mode 100644
index 000000000..8214afb1e
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/templates/NOTES.txt
@@ -0,0 +1,2 @@
+eShop API Gateway for Web Shopping services installed
+-----------------------------------------------------
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwws/templates/_helpers.tpl b/deploy/k8s/archived/helm/apigwws/templates/_helpers.tpl
new file mode 100644
index 000000000..b6aa6b483
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "apigwws.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 "apigwws.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 "apigwws.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/apigwws/templates/_names.tpl b/deploy/k8s/archived/helm/apigwws/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/apigwws/templates/deployment.yaml b/deploy/k8s/archived/helm/apigwws/templates/deployment.yaml
new file mode 100644
index 000000000..3aedde6dd
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/templates/deployment.yaml
@@ -0,0 +1,109 @@
+{{- $name := include "apigwws.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "apigwws.fullname" . }}
+ labels:
+ app: {{ template "apigwws.name" . }}
+ chart: {{ template "apigwws.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "apigwws.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "apigwws.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ volumes:
+ - name: config
+ configMap:
+ name: {{ $envoycfgname }}
+ items:
+ - key: envoy.yaml
+ path: envoy.yaml
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ volumeMounts:
+ - name: config
+ mountPath: {{ .Values.envoy.configPath }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ - name: admin
+ containerPort: 8001
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/apigwws/templates/envoy-cm.yaml b/deploy/k8s/archived/helm/apigwws/templates/envoy-cm.yaml
new file mode 100644
index 000000000..6d41bd2e2
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/templates/envoy-cm.yaml
@@ -0,0 +1,14 @@
+{{- $name := include "apigwws.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "envoy-{{ $name }}"
+ labels:
+ app: {{ template "apigwws.name" . }}
+ chart: {{ template "apigwws.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ {{ (.Files.Glob "envoy.yaml").AsConfig | indent 2 }}
+
diff --git a/deploy/k8s/archived/helm/apigwws/templates/ingress.yaml b/deploy/k8s/archived/helm/apigwws/templates/ingress.yaml
new file mode 100644
index 000000000..945038081
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/templates/ingress.yaml
@@ -0,0 +1,46 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.webshoppingapigw -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "apigwws.fullname" . }}
+ labels:
+ app: {{ template "apigwws.name" . }}
+ chart: {{ template "apigwws.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/apigwws/templates/service.yaml b/deploy/k8s/archived/helm/apigwws/templates/service.yaml
new file mode 100644
index 000000000..55f6daf3f
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/templates/service.yaml
@@ -0,0 +1,23 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.webshoppingapigw }}
+ labels:
+ app: {{ template "apigwws.name" . }}
+ chart: {{ template "apigwws.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ - port: {{ .Values.service.adminPort }}
+ targetPort: admin
+ protocol: TCP
+ name: admin
+ selector:
+ app: {{ template "apigwws.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/apigwws/values.yaml b/deploy/k8s/archived/helm/apigwws/values.yaml
new file mode 100644
index 000000000..fb1182dac
--- /dev/null
+++ b/deploy/k8s/archived/helm/apigwws/values.yaml
@@ -0,0 +1,46 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /webshoppingapigw
+
+image:
+ repository: envoyproxy/envoy
+ tag: v1.11.1
+
+service:
+ type: ClusterIP
+ port: 80
+ adminPort: 8001
+
+ingress:
+ enabled: true
+ annotations:
+ nginx.ingress.kubernetes.io/rewrite-target: "/"
+ ingress.kubernetes.io/rewrite-target: "/"
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env: {}
+
+envoy:
+ configPath: /etc/envoy
+
+probes:
+ liveness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 15
+ port: 8001
+ readiness:
+ path: /ready
+ initialDelaySeconds: 5
+ periodSeconds: 60
+ port: 8001
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/app.yaml b/deploy/k8s/archived/helm/app.yaml
new file mode 100644
index 000000000..e83ea2823
--- /dev/null
+++ b/deploy/k8s/archived/helm/app.yaml
@@ -0,0 +1,46 @@
+# This helm values file defines app-based settings
+# Charts use those values, so this file **MUST** be included in all chart releases
+
+app: # app global settings
+ name: "my-eshop" # Override for custom app name
+ ingress: # ingress related settings
+ entries:
+ basket: basket-api # ingress entry for basket api
+ catalog: catalog-api # ingress entry for catalog api
+ ordering: ordering-api # ingress entry for ordering api
+ identity: identity # ingress entry for identity api
+ mvc: webmvc # ingress entry for web mvc
+ spa: "" # ingress entry for web spa
+ status: webstatus # ingress entry for web status
+ webshoppingapigw: webshoppingapigw # ingress entry for web shopping Agw
+ webmarketingapigw: webmarketingapigw # ingress entry for web mkg Agw
+ mobilemarketingapigw: mobilemarketingapigw # ingress entry for mobile mkg Agw
+ mobileshoppingapigw: mobileshoppingapigw # ingress entry for mobile shopping Agw
+ webshoppingagg: webshoppingagg # ingress entry for web shopping aggregator
+ mobileshoppingagg: mobileshoppingagg # ingress entry for mobile shopping aggregator
+ payment: payment-api # ingress entry for payment api
+ locations: locations-api # ingress entry for locations api
+ marketing: marketing-api # ingress entry for marketing api
+ webhooks: webhooks-api # ingress entry for webhooks api
+ webhooksweb: webhooks-web # ingress entry for webhooks web demo client
+ svc:
+ basket: basket-api # service name for basket api
+ catalog: catalog-api # service name for catalog api
+ ordering: ordering-api # service name for ordering api
+ orderingbackgroundtasks: ordering-backgroundtasks # service name for orderingbackgroundtasks
+ orderingsignalrhub: ordering-signalrhub # service name for orderingsignalrhub
+ identity: identity-api # service name for identity api
+ mvc: webmvc # service name for web mvc
+ spa: webspa # service name for web spa
+ status: webstatus # service name for web status
+ webshoppingapigw: webshoppingapigw # service name for web shopping Agw
+ webmarketingapigw: webmarketingapigw # service name for web mkg Agw
+ mobilemarketingapigw: mobilemarketingapigw # service name for mobile mkg Agw
+ mobileshoppingapigw: mobileshoppingapigw # service name for mobile shopping Agw
+ webshoppingagg: webshoppingagg # service name for web shopping aggregator
+ mobileshoppingagg: mobileshoppingagg # service name for mobile shopping aggregator
+ payment: payment-api # service name for payment api
+ locations: locations-api # service name for locations api
+ marketing: marketing-api # service name for marketing ap
+ webhooks: webhooks-api # service name for webhooks api
+ webhooksweb: webhooks-client # service name for webhooks web
diff --git a/deploy/k8s/archived/helm/basket-api/.helmignore b/deploy/k8s/archived/helm/basket-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/basket-api/Chart.yaml b/deploy/k8s/archived/helm/basket-api/Chart.yaml
new file mode 100644
index 000000000..fd3e01486
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: basket-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/basket-api/templates/NOTES.txt b/deploy/k8s/archived/helm/basket-api/templates/NOTES.txt
new file mode 100644
index 000000000..8ba2c89ee
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Basket API installed.
+--------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "basket-api.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/basket-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/basket-api/templates/_helpers.tpl
new file mode 100644
index 000000000..550eb2e6c
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "basket-api.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 "basket-api.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 "basket-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/basket-api/templates/_names.tpl b/deploy/k8s/archived/helm/basket-api/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/basket-api/templates/configmap.yaml b/deploy/k8s/archived/helm/basket-api/templates/configmap.yaml
new file mode 100644
index 000000000..2de0e28c7
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/templates/configmap.yaml
@@ -0,0 +1,18 @@
+{{- $name := include "basket-api.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "basket-api.name" . }}
+ chart: {{ template "basket-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ basket__ConnectionString: {{ .Values.inf.redis.basket.constr }}
+ urls__IdentityUrl: http://{{ .Values.app.svc.identity }}
+ basket__EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/basket-api/templates/deployment.yaml b/deploy/k8s/archived/helm/basket-api/templates/deployment.yaml
new file mode 100644
index 000000000..dc90666f5
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/templates/deployment.yaml
@@ -0,0 +1,99 @@
+{{- $name := include "basket-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "basket-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "basket-api.name" . }}
+ chart: {{ template "basket-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "basket-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "basket-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ - name: grpc
+ containerPort: 81
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/basket-api/templates/service.yaml b/deploy/k8s/archived/helm/basket-api/templates/service.yaml
new file mode 100644
index 000000000..1783c59aa
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/templates/service.yaml
@@ -0,0 +1,23 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.basket }}
+ labels:
+ app: {{ template "basket-api.name" . }}
+ chart: {{ template "basket-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ - port: {{ .Values.service.grpcPort }}
+ targetPort: grpc
+ protocol: TCP
+ name: grpc
+ selector:
+ app: {{ template "basket-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/basket-api/values.yaml b/deploy/k8s/archived/helm/basket-api/values.yaml
new file mode 100644
index 000000000..121de02de
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-api/values.yaml
@@ -0,0 +1,63 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /basket-api
+
+image:
+ repository: eshop/basket.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+ grpcPort: 81
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ConnectionString
+ key: basket__ConnectionString
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ - name: IdentityUrl
+ key: urls__IdentityUrl
+ - name: UseLoadTest
+ key: basket__EnableLoadTest
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: PORT
+ value: "80"
+ - name: GRPC_PORT
+ value: "81"
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
+
+ingress:
+ enabled: false
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/basket-data/.helmignore b/deploy/k8s/archived/helm/basket-data/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-data/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/basket-data/Chart.yaml b/deploy/k8s/archived/helm/basket-data/Chart.yaml
new file mode 100644
index 000000000..67ceddee1
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-data/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: basket-data
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/basket-data/templates/NOTES.txt b/deploy/k8s/archived/helm/basket-data/templates/NOTES.txt
new file mode 100644
index 000000000..c10513333
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-data/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Redis for keystore data installed
+----------------------------------------
+
+Redis is not directly exposed outside cluster. If need to access it from outside use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "basket-data.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/basket-data/templates/_helpers.tpl b/deploy/k8s/archived/helm/basket-data/templates/_helpers.tpl
new file mode 100644
index 000000000..74b51b089
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-data/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "basket-data.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 "basket-data.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 "basket-data.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/basket-data/templates/deployment.yaml b/deploy/k8s/archived/helm/basket-data/templates/deployment.yaml
new file mode 100644
index 000000000..8ccceceeb
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-data/templates/deployment.yaml
@@ -0,0 +1,43 @@
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "basket-data.fullname" . }}
+ labels:
+ app: {{ template "basket-data.name" . }}
+ chart: {{ template "basket-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "basket-data.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "basket-data.name" . }}
+ release: {{ .Release.Name }}
+ spec:
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ ports:
+ - name: http
+ containerPort: 6379
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
diff --git a/deploy/k8s/archived/helm/basket-data/templates/service.yaml b/deploy/k8s/archived/helm/basket-data/templates/service.yaml
new file mode 100644
index 000000000..98b8cc3bd
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-data/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.inf.redis.basket.svc }}
+ labels:
+ app: {{ template "basket-data.name" . }}
+ chart: {{ template "basket-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "basket-data.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/basket-data/values.yaml b/deploy/k8s/archived/helm/basket-data/values.yaml
new file mode 100644
index 000000000..17cc75ee7
--- /dev/null
+++ b/deploy/k8s/archived/helm/basket-data/values.yaml
@@ -0,0 +1,19 @@
+replicaCount: 1
+
+image:
+ repository: redis
+ tag: 4.0.10
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 6379
+
+
+resources: {}
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
diff --git a/deploy/k8s/archived/helm/catalog-api/.helmignore b/deploy/k8s/archived/helm/catalog-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/catalog-api/Chart.yaml b/deploy/k8s/archived/helm/catalog-api/Chart.yaml
new file mode 100644
index 000000000..a143a0afe
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: catalog-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/catalog-api/templates/NOTES.txt b/deploy/k8s/archived/helm/catalog-api/templates/NOTES.txt
new file mode 100644
index 000000000..1f01a2b92
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/templates/NOTES.txt
@@ -0,0 +1,9 @@
+eShop Catalog API installed.
+----------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "catalog-api.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
+
diff --git a/deploy/k8s/archived/helm/catalog-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/catalog-api/templates/_helpers.tpl
new file mode 100644
index 000000000..6fd128e77
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "catalog-api.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 "catalog-api.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 "catalog-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/catalog-api/templates/_names.tpl b/deploy/k8s/archived/helm/catalog-api/templates/_names.tpl
new file mode 100644
index 000000000..605e92e7e
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/templates/_names.tpl
@@ -0,0 +1,60 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "protocol" -}}
+{{- if .Values.inf.tls.enabled -}}
+{{- printf "%s" "https" -}}
+{{- else -}}
+{{- printf "%s" "http" -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/catalog-api/templates/configmap.yaml b/deploy/k8s/archived/helm/catalog-api/templates/configmap.yaml
new file mode 100644
index 000000000..292b9e9b9
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/templates/configmap.yaml
@@ -0,0 +1,21 @@
+{{- $name := include "catalog-api.fullname" . -}}
+{{- $sqlsrv := include "sql-name" . -}}
+{{- $webshoppingapigw := include "url-of" (list .Values.app.ingress.entries.webshoppingapigw .) -}}
+{{- $protocol := include "protocol" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "catalog-api.name" . }}
+ chart: {{ template "catalog-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ catalog__ConnectionString: Server={{ $sqlsrv }};Initial Catalog={{ .Values.inf.sql.catalog.db }};User Id={{ .Values.inf.sql.common.user }};Password={{ .Values.inf.sql.common.pwd }};
+ catalog__PicBaseUrl: {{ $protocol }}://{{ $webshoppingapigw }}/c/api/v1/catalog/items/[0]/pic/
+ catalog__AzureStorageEnabled: "{{ .Values.inf.misc.useAzureStorage }}"
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/catalog-api/templates/deployment.yaml b/deploy/k8s/archived/helm/catalog-api/templates/deployment.yaml
new file mode 100644
index 000000000..33a0ad5b4
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/templates/deployment.yaml
@@ -0,0 +1,99 @@
+{{- $name := include "catalog-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "catalog-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "catalog-api.name" . }}
+ chart: {{ template "catalog-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "catalog-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "catalog-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ - name: grpc
+ containerPort: 81
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/catalog-api/templates/service.yaml b/deploy/k8s/archived/helm/catalog-api/templates/service.yaml
new file mode 100644
index 000000000..f634a7088
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/templates/service.yaml
@@ -0,0 +1,23 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.catalog }}
+ labels:
+ app: {{ template "catalog-api.name" . }}
+ chart: {{ template "catalog-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ - port: {{ .Values.service.grpcPort }}
+ targetPort: grpc
+ protocol: TCP
+ name: grpc
+ selector:
+ app: {{ template "catalog-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/catalog-api/values.yaml b/deploy/k8s/archived/helm/catalog-api/values.yaml
new file mode 100644
index 000000000..0de49b7f6
--- /dev/null
+++ b/deploy/k8s/archived/helm/catalog-api/values.yaml
@@ -0,0 +1,63 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /catalog-api
+
+image:
+ repository: eshop/catalog.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+ grpcPort: 81
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ConnectionString
+ key: catalog__ConnectionString
+ - name: PicBaseUrl
+ key: catalog__PicBaseUrl
+ - name: AzureStorageEnabled
+ key: catalog__AzureStorageEnabled
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: PORT
+ value: "80"
+ - name: GRPC_PORT
+ value: "81"
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
+
diff --git a/deploy/k8s/archived/helm/deploy-all.ps1 b/deploy/k8s/archived/helm/deploy-all.ps1
new file mode 100644
index 000000000..1711c0c2c
--- /dev/null
+++ b/deploy/k8s/archived/helm/deploy-all.ps1
@@ -0,0 +1,149 @@
+Param(
+ [parameter(Mandatory=$false)][string]$registry,
+ [parameter(Mandatory=$false)][string]$dockerUser,
+ [parameter(Mandatory=$false)][string]$dockerPassword,
+ [parameter(Mandatory=$false)][string]$externalDns,
+ [parameter(Mandatory=$false)][string]$appName="eshop",
+ [parameter(Mandatory=$false)][bool]$deployInfrastructure=$true,
+ [parameter(Mandatory=$false)][bool]$deployCharts=$true,
+ [parameter(Mandatory=$false)][bool]$clean=$true,
+ [parameter(Mandatory=$false)][string]$aksName="",
+ [parameter(Mandatory=$false)][string]$aksRg="",
+ [parameter(Mandatory=$false)][string]$imageTag="latest",
+ [parameter(Mandatory=$false)][bool]$useLocalk8s=$false,
+ [parameter(Mandatory=$false)][bool]$useMesh=$false,
+ [parameter(Mandatory=$false)][string][ValidateSet('Always','IfNotPresent','Never', IgnoreCase=$false)]$imagePullPolicy="Always",
+ [parameter(Mandatory=$false)][string][ValidateSet('prod','staging','none','custom', IgnoreCase=$false)]$sslSupport = "none",
+ [parameter(Mandatory=$false)][string]$tlsSecretName = "eshop-tls-custom",
+ [parameter(Mandatory=$false)][string]$chartsToDeploy="*",
+ [parameter(Mandatory=$false)][string]$ingressMeshAnnotationsFile="ingress_values_linkerd.yaml"
+ )
+
+function Install-Chart {
+ Param([string]$chart,[string]$initialOptions, [bool]$customRegistry)
+ $options=$initialOptions
+ if ($sslEnabled) {
+ $options = "$options --set ingress.tls[0].secretName=$tlsSecretName --set ingress.tls[0].hosts={$dns}"
+ if ($sslSupport -ne "custom") {
+ $options = "$options --set inf.tls.issuer=$sslIssuer"
+ }
+ }
+ if ($customRegistry) {
+ $options = "$options --set inf.registry.server=$registry --set inf.registry.login=$dockerUser --set inf.registry.pwd=$dockerPassword --set inf.registry.secretName=eshop-docker-scret"
+ }
+
+ if ($chart -ne "eshop-common" -or $customRegistry) { # eshop-common is ignored when no secret must be deployed
+ $command = "install $options --name=$appName-$chart $chart"
+ Write-Host "Helm Command: helm $command" -ForegroundColor Gray
+ Invoke-Expression 'cmd /c "helm $command"'
+ }
+}
+
+$dns = $externalDns
+$sslEnabled=$false
+$sslIssuer=""
+
+if ($sslSupport -eq "staging") {
+ $sslEnabled=$true
+ $tlsSecretName="eshop-letsencrypt-staging"
+ $sslIssuer="letsencrypt-staging"
+}
+elseif ($sslSupport -eq "prod") {
+ $sslEnabled=$true
+ $tlsSecretName="eshop-letsencrypt-prod"
+ $sslIssuer="letsencrypt-prod"
+}
+elseif ($sslSupport -eq "custom") {
+ $sslEnabled=$true
+}
+
+$ingressValuesFile="ingress_values.yaml"
+
+if ($useLocalk8s -eq $true) {
+ $ingressValuesFile="ingress_values_dockerk8s.yaml"
+ $dns="localhost"
+}
+
+if ($externalDns -eq "aks") {
+ if ([string]::IsNullOrEmpty($aksName) -or [string]::IsNullOrEmpty($aksRg)) {
+ Write-Host "Error: When using -dns aks, MUST set -aksName and -aksRg too." -ForegroundColor Red
+ exit 1
+ }
+ Write-Host "Getting DNS of AKS of AKS $aksName (in resource group $aksRg)..." -ForegroundColor Green
+ $dns = $(az aks show -n $aksName -g $aksRg --query addonProfiles.httpApplicationRouting.config.HTTPApplicationRoutingZoneName)
+ if ([string]::IsNullOrEmpty($dns)) {
+ Write-Host "Error getting DNS of AKS $aksName (in resource group $aksRg). Please ensure AKS has httpRouting enabled AND Azure CLI is logged & in version 2.0.37 or higher" -ForegroundColor Red
+ exit 1
+ }
+ $dns = $dns -replace '[\"]'
+ Write-Host "DNS base found is $dns. Will use $appName.$dns for the app!" -ForegroundColor Green
+ $dns = "$appName.$dns"
+}
+
+# Initialization & check commands
+if ([string]::IsNullOrEmpty($dns)) {
+ Write-Host "No DNS specified. Ingress resources will be bound to public ip" -ForegroundColor Yellow
+ if ($sslEnabled) {
+ Write-Host "Can't bound SSL to public IP. DNS is mandatory when using TLS" -ForegroundColor Red
+ exit 1
+ }
+}
+
+if ($useLocalk8s -and $sslEnabled) {
+ Write-Host "SSL can'be enabled on local K8s." -ForegroundColor Red
+ exit 1
+}
+
+if ($clean) {
+ Write-Host "Cleaning previous helm releases..." -ForegroundColor Green
+ helm delete --purge $(helm ls -q eshop)
+ Write-Host "Previous releases deleted" -ForegroundColor Green
+}
+
+$useCustomRegistry=$false
+
+if (-not [string]::IsNullOrEmpty($registry)) {
+ $useCustomRegistry=$true
+ if ([string]::IsNullOrEmpty($dockerUser) -or [string]::IsNullOrEmpty($dockerPassword)) {
+ Write-Host "Error: Must use -dockerUser AND -dockerPassword if specifying custom registry" -ForegroundColor Red
+ exit 1
+ }
+}
+
+Write-Host "Begin eShopOnContainers installation using Helm" -ForegroundColor Green
+
+$infras = ("sql-data", "nosql-data", "rabbitmq", "keystore-data", "basket-data")
+$charts = ("eshop-common", "basket-api","catalog-api", "identity-api", "locations-api", "marketing-api", "mobileshoppingagg","ordering-api","ordering-backgroundtasks","ordering-signalrhub", "payment-api", "webmvc", "webshoppingagg", "webspa", "webstatus", "webhooks-api", "webhooks-web")
+$gateways = ("apigwmm", "apigwms", "apigwwm", "apigwws")
+
+if ($deployInfrastructure) {
+ foreach ($infra in $infras) {
+ Write-Host "Installing infrastructure: $infra" -ForegroundColor Green
+ helm install --values app.yaml --values inf.yaml --values $ingressValuesFile --set app.name=$appName --set inf.k8s.dns=$dns --set "ingress.hosts={$dns}" --name="$appName-$infra" $infra
+ }
+}
+else {
+ Write-Host "eShopOnContainers infrastructure (bbdd, redis, ...) charts aren't installed (-deployCharts is false)" -ForegroundColor Yellow
+}
+
+if ($deployCharts) {
+ foreach ($chart in $charts) {
+ if ($chartsToDeploy -eq "*" -or $chartsToDeploy.Contains($chart)) {
+ Write-Host "Installing: $chart" -ForegroundColor Green
+ Install-Chart $chart "-f app.yaml --values inf.yaml -f $ingressValuesFile -f $ingressMeshAnnotationsFile --set app.name=$appName --set inf.k8s.dns=$dns --set ingress.hosts={$dns} --set image.tag=$imageTag --set image.pullPolicy=$imagePullPolicy --set inf.tls.enabled=$sslEnabled --set inf.mesh.enabled=$useMesh --set inf.k8s.local=$useLocalk8s" $useCustomRegistry
+ }
+ }
+
+ foreach ($chart in $gateways) {
+ if ($chartsToDeploy -eq "*" -or $chartsToDeploy.Contains($chart)) {
+ Write-Host "Installing Api Gateway Chart: $chart" -ForegroundColor Green
+ Install-Chart $chart "-f app.yaml -f inf.yaml -f $ingressValuesFile --set app.name=$appName --set inf.k8s.dns=$dns --set image.pullPolicy=$imagePullPolicy --set inf.mesh.enabled=$useMesh --set ingress.hosts={$dns} --set inf.tls.enabled=$sslEnabled" $false
+
+ }
+ }
+}
+else {
+ Write-Host "eShopOnContainers non-infrastructure charts aren't installed (-deployCharts is false)" -ForegroundColor Yellow
+}
+
+Write-Host "helm charts installed." -ForegroundColor Green
diff --git a/deploy/k8s/archived/helm/deploy-all.sh b/deploy/k8s/archived/helm/deploy-all.sh
new file mode 100644
index 000000000..6f6d868aa
--- /dev/null
+++ b/deploy/k8s/archived/helm/deploy-all.sh
@@ -0,0 +1,232 @@
+#!/usr/bin/env bash
+
+# http://redsymbol.net/articles/unofficial-bash-strict-mode
+set -euo pipefail
+
+usage()
+{
+ cat <
+ The name of the AKS cluster. Required when the registry (using the -r parameter) is set to "aks".
+ --aks-rg
+ The resource group for the AKS cluster. Required when the registry (using the -r parameter) is set to "aks".
+ -b | --build-solution
+ Force a solution build before deployment (default: false).
+ -d | --dns | --dns aks
+ Specifies the external DNS/ IP address of the Kubernetes cluster.
+ If 'aks' is set as value, the DNS value is retrieved from the AKS. --aks-name and --aks-rg are needed.
+ When --use-local-k8s is specified the external DNS is automatically set to localhost.
+ -h | --help
+ Displays this help text and exits the script.
+ --image-build
+ Build images (default is to not build all images).
+ --image-push
+ Upload images to the container registry (default is not pushing to the custom registry)
+ -n | --app-name
+ Specifies the name of the application (default: eshop).
+ --namespace
+ Specifies the namespace name to deploy the app. If it doesn't exists it will be created (default: eshop).
+ -p | --docker-password
+ The Docker password used to logon to the custom registry, supplied using the -r parameter.
+ -r | --registry
+ Specifies the container registry to use (required), e.g. myregistry.azurecr.io.
+ --skip-clean
+ Do not clean the Kubernetes cluster (default is to clean the cluster).
+ --skip-infrastructure
+ Do not deploy infrastructure resources (like sql-data, no-sql or redis).
+ This is useful for production environments where infrastructure is hosted outside the Kubernetes cluster.
+ -t | --tag
+ The tag used for the newly created docker images. Default: latest.
+ -u | --docker-username
+ The Docker username used to logon to the custom registry, supplied using the -r parameter.
+ --use-local-k8s
+ Deploy to a locally installed Kubernetes (default: false).
+
+It is assumed that the Kubernetes cluster has been granted access to the container registry.
+If using AKS and ACR see link for more info:
+https://docs.microsoft.com/en-us/azure/container-registry/container-registry-auth-aks
+
+WARNING! THE SCRIPT WILL COMPLETELY DESTROY ALL DEPLOYMENTS AND SERVICES VISIBLE
+FROM THE CURRENT CONFIGURATION CONTEXT AND NAMESPACE.
+It is recommended that you check your selected namespace, 'eshop' by default, is already in use.
+Every deployment and service done in the namespace will be deleted.
+For more information see https://kubernetes.io/docs/tasks/administer-cluster/namespaces/
+
+END
+}
+
+app_name='eshop'
+aks_name=''
+aks_rg=''
+build_images=''
+clean='yes'
+build_solution=''
+container_registry=''
+docker_password=''
+docker_username=''
+dns=''
+image_tag='latest'
+push_images=''
+skip_infrastructure=''
+use_local_k8s=''
+namespace='eshop'
+
+while [[ $# -gt 0 ]]; do
+ case "$1" in
+ --aks-name )
+ aks_name="$2"; shift 2;;
+ --aks-rg )
+ aks_rg="$2"; shift 2;;
+ -b | --build-solution )
+ build_solution='yes'; shift ;;
+ -d | --dns )
+ dns="$2"; shift 2;;
+ -h | --help )
+ usage; exit 1 ;;
+ -n | --app-name )
+ app_name="$2"; shift 2;;
+ -p | --docker-password )
+ docker_password="$2"; shift 2;;
+ -r | --registry )
+ container_registry="$2"; shift 2;;
+ --skip-clean )
+ clean=''; shift ;;
+ --image-build )
+ build_images='yes'; shift ;;
+ --image-push )
+ push_images='yes'; shift ;;
+ --skip-infrastructure )
+ skip_infrastructure='yes'; shift ;;
+ -t | --tag )
+ image_tag="$2"; shift 2;;
+ -u | --docker-username )
+ docker_username="$2"; shift 2;;
+ --use-local-k8s )
+ use_local_k8s='yes'; shift ;;
+ --namespace )
+ namespace="$2"; shift 2;;
+ *)
+ echo "Unknown option $1"
+ usage; exit 2 ;;
+ esac
+done
+
+if [[ $build_solution ]]; then
+ echo "#################### Building $app_name solution ####################"
+ dotnet publish -o obj/Docker/publish ../../eShopOnContainers-ServicesAndWebApps.sln
+fi
+
+export TAG=$image_tag
+
+if [[ $build_images ]]; then
+ echo "#################### Building the $app_name Docker images ####################"
+ docker-compose -p ../.. -f ../../docker-compose.yml build
+
+ # Remove temporary images
+ docker rmi $(docker images -qf "dangling=true")
+fi
+
+use_custom_registry=''
+
+if [[ -n $container_registry ]]; then
+ echo "################ Log into custom registry $container_registry ##################"
+ use_custom_registry='yes'
+ if [[ -z $docker_username ]] || [[ -z $docker_password ]]; then
+ echo "Error: Must use -u (--docker-username) AND -p (--docker-password) if specifying custom registry"
+ exit 1
+ fi
+ docker login -u $docker_username -p $docker_password $container_registry
+fi
+
+if [[ $push_images ]]; then
+ echo "#################### Pushing images to the container registry ####################"
+ services=(basket.api catalog.api identity.api ordering.api marketing.api payment.api locations.api webmvc webspa webstatus)
+
+ if [[ -z "$(docker image ls -q --filter=reference=eshop/$service:$image_tag)" ]]; then
+ image_tag=linux-$image_tag
+ fi
+
+ for service in "${services[@]}"
+ do
+ echo "Pushing image for service $service..."
+ docker tag "eshop/$service:$image_tag" "$container_registry/$service:$image_tag"
+ docker push "$container_registry/$service:$image_tag"
+ done
+fi
+
+ingress_values_file="ingress_values.yaml"
+
+if [[ $use_local_k8s ]]; then
+ ingress_values_file="ingress_values_dockerk8s.yaml"
+ dns="localhost"
+fi
+
+if [[ $dns == "aks" ]]; then
+ echo "#################### Begin AKS discovery based on the --dns aks setting. ####################"
+ if [[ -z $aks_name ]] || [[ -z $aks_rg ]]; then
+ echo "Error: When using -dns aks, MUST set -aksName and -aksRg too."
+ echo ''
+ usage
+ exit 1
+ fi
+
+ echo "Getting AKS cluster $aks_name AKS (in resource group $aks_rg)"
+ # JMESPath queries are case sensitive and httpapplicationrouting can be lowercase sometimes
+ jmespath_dnsqueries=(\
+ addonProfiles.httpApplicationRouting.config.HTTPApplicationRoutingZoneName \
+ addonProfiles.httpapplicationrouting.config.HTTPApplicationRoutingZoneName \
+ )
+ for q in "${jmespath_dnsqueries[@]}"
+ do
+ dns="$(az aks show -n $aks_name -g $aks_rg --query $q -o tsv)"
+ if [[ -n $dns ]]; then break; fi
+ done
+ if [[ -z $dns ]]; then
+ echo "Error: when getting DNS of AKS $aks_name (in resource group $aks_rg). Please ensure AKS has httpRouting enabled AND Azure CLI is logged in and is of version 2.0.37 or higher."
+ exit 1
+ fi
+ echo "DNS base found is $dns. Will use $aks_name.$dns for the app!"
+ dns="$aks_name.$dns"
+fi
+
+# Initialization & check commands
+if [[ -z $dns ]]; then
+ echo "No DNS specified. Ingress resources will be bound to public IP."
+fi
+
+if [[ $clean ]]; then
+ echo "Cleaning previous helm releases..."
+ if [[ -z $(helm ls -q --namespace $namespace) ]]; then
+ echo "No previous releases found"
+ else
+ helm delete --purge $(helm ls -q --namespace $namespace)
+ echo "Previous releases deleted"
+ waitsecs=10; while [ $waitsecs -gt 0 ]; do echo -ne "$waitsecs\033[0K\r"; sleep 1; : $((waitsecs--)); done
+ fi
+fi
+
+echo "#################### Begin $app_name installation using Helm ####################"
+infras=(sql-data nosql-data rabbitmq keystore-data basket-data)
+charts=(eshop-common apigwmm apigwms apigwwm apigwws basket-api catalog-api identity-api locations-api marketing-api mobileshoppingagg ordering-api ordering-backgroundtasks ordering-signalrhub payment-api webmvc webshoppingagg webspa webstatus webhooks-api webhooks-web)
+
+if [[ !$skip_infrastructure ]]; then
+ for infra in "${infras[@]}"
+ do
+ echo "Installing infrastructure: $infra"
+ helm install --namespace $namespace --set "ingress.hosts={$dns}" --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --name="$app_name-$infra" $infra
+ done
+fi
+
+for chart in "${charts[@]}"
+do
+ echo "Installing: $chart"
+ if [[ $use_custom_registry ]]; then
+ helm install --namespace $namespace --set "ingress.hosts={$dns}" --set inf.registry.server=$container_registry --set inf.registry.login=$docker_username --set inf.registry.pwd=$docker_password --set inf.registry.secretName=eshop-docker-scret --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --set image.tag=$image_tag --set image.pullPolicy=Always --name="$app_name-$chart" $chart
+ elif [[ $chart != "eshop-common" ]]; then # eshop-common is ignored when no secret must be deployed
+ helm install --namespace $namespace --set "ingress.hosts={$dns}" --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --set image.tag=$image_tag --set image.pullPolicy=Always --name="$app_name-$chart" $chart
+ fi
+done
+
+echo "FINISHED: Helm charts installed."
diff --git a/deploy/k8s/archived/helm/eshop-common/.helmignore b/deploy/k8s/archived/helm/eshop-common/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/eshop-common/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/eshop-common/Chart.yaml b/deploy/k8s/archived/helm/eshop-common/Chart.yaml
new file mode 100644
index 000000000..cd5e7b2fe
--- /dev/null
+++ b/deploy/k8s/archived/helm/eshop-common/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: eshop-common
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/eshop-common/templates/NOTES.txt b/deploy/k8s/archived/helm/eshop-common/templates/NOTES.txt
new file mode 100644
index 000000000..1cc59f58a
--- /dev/null
+++ b/deploy/k8s/archived/helm/eshop-common/templates/NOTES.txt
@@ -0,0 +1,7 @@
+Common eShop resources installed:
+
+{{- if .Values.inf.registry -}}
+* Docker registry secret ({{ .Values.inf.registry.secretName }})
+{{- end -}}
+
++++ Done +++
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/eshop-common/templates/_helpers.tpl b/deploy/k8s/archived/helm/eshop-common/templates/_helpers.tpl
new file mode 100644
index 000000000..4a3c6324b
--- /dev/null
+++ b/deploy/k8s/archived/helm/eshop-common/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "eshop-common.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 "eshop-common.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 "eshop-common.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/eshop-common/templates/_names.tpl b/deploy/k8s/archived/helm/eshop-common/templates/_names.tpl
new file mode 100644
index 000000000..7cdfb80d6
--- /dev/null
+++ b/deploy/k8s/archived/helm/eshop-common/templates/_names.tpl
@@ -0,0 +1,3 @@
+{{- define "imagePullSecret" }}
+{{- printf "{\"auths\": {\"%s\": {\"auth\": \"%s\"}}}" .Values.inf.registry.server (printf "%s:%s" .Values.inf.registry.login .Values.inf.registry.pwd | b64enc) | b64enc }}
+{{- end }}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/eshop-common/templates/secret.yaml b/deploy/k8s/archived/helm/eshop-common/templates/secret.yaml
new file mode 100644
index 000000000..285ec85e7
--- /dev/null
+++ b/deploy/k8s/archived/helm/eshop-common/templates/secret.yaml
@@ -0,0 +1,9 @@
+{{- if .Values.inf.registry -}}
+apiVersion: v1
+kind: Secret
+metadata:
+ name: {{ .Values.inf.registry.secretName }}
+type: kubernetes.io/dockerconfigjson
+data:
+ .dockerconfigjson: {{ template "imagePullSecret" . }}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/eshop-common/values.yaml b/deploy/k8s/archived/helm/eshop-common/values.yaml
new file mode 100644
index 000000000..e69de29bb
diff --git a/deploy/k8s/archived/helm/identity-api/.helmignore b/deploy/k8s/archived/helm/identity-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/identity-api/Chart.yaml b/deploy/k8s/archived/helm/identity-api/Chart.yaml
new file mode 100644
index 000000000..7b9290ada
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: identity-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/identity-api/templates/NOTES.txt b/deploy/k8s/archived/helm/identity-api/templates/NOTES.txt
new file mode 100644
index 000000000..48fbbe9b4
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/NOTES.txt
@@ -0,0 +1,4 @@
+eShop Identity API installed.
+-----------------------------
+
+Access this API through ingress.
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/identity-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/identity-api/templates/_helpers.tpl
new file mode 100644
index 000000000..fb47187b4
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "identity-api.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 "identity-api.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 "identity-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/identity-api/templates/_names.tpl b/deploy/k8s/archived/helm/identity-api/templates/_names.tpl
new file mode 100644
index 000000000..39ee485ef
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/_names.tpl
@@ -0,0 +1,51 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/identity-api/templates/configmap.yaml b/deploy/k8s/archived/helm/identity-api/templates/configmap.yaml
new file mode 100644
index 000000000..264ceb745
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/configmap.yaml
@@ -0,0 +1,39 @@
+{{- $name := include "identity-api.fullname" . -}}
+{{- $sqlsrv := include "sql-name" . -}}
+{{- $mvc_url := include "url-of" (list .Values.app.ingress.entries.mvc .) -}}
+{{- $spa_url := include "url-of" (list .Values.app.ingress.entries.spa .) -}}
+{{- $locations_url := include "url-of" (list .Values.app.ingress.entries.locations .) -}}
+{{- $marketing_url := include "url-of" (list .Values.app.ingress.entries.marketing .) -}}
+{{- $basket_url := include "url-of" (list .Values.app.ingress.entries.basket .) -}}
+{{- $ordering_url := include "url-of" (list .Values.app.ingress.entries.ordering .) -}}
+{{- $mobileshoppingagg := include "url-of" (list .Values.app.ingress.entries.mobileshoppingagg .) -}}
+{{- $webhoppingagg := include "url-of" (list .Values.app.ingress.entries.webshoppingagg .) -}}
+{{- $xamarincallback := include "url-of" (list "xamarincallback" .) -}}
+{{- $webhooks_url := include "url-of" (list .Values.app.ingress.entries.webhooks .) -}}
+{{- $webhooksweb_url := include "url-of" (list .Values.app.ingress.entries.webhooksweb .) -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "identity-api.name" . }}
+ chart: {{ template "identity-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ identity__ConnectionString: Server={{ $sqlsrv }};Initial Catalog={{ .Values.inf.sql.identity.db }};User Id={{ .Values.inf.sql.common.user }};Password={{ .Values.inf.sql.common.pwd }};
+ identity__keystore: {{ .Values.inf.redis.keystore.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ mvc_e: http://{{ $mvc_url }}
+ spa_e: http://{{ $spa_url }}
+ locations_e: http://{{ $locations_url }}
+ marketing_e: http://{{ $marketing_url }}
+ basket_e: http://{{ $basket_url }}
+ ordering_e: http://{{ $ordering_url }}
+ mobileshoppingagg_e: http://{{ $mobileshoppingagg }}
+ webshoppingagg_e: http://{{ $webhoppingagg }}
+ xamarin_callback_e: http://{{ $xamarincallback }}
+ webhooksapi_e: http://{{ $webhooks_url }}
+ webhooksweb_e: http://{{ $webhooksweb_url }}
+ enableDevspaces: "{{ .Values.enableDevspaces }}"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/identity-api/templates/deployment.yaml b/deploy/k8s/archived/helm/identity-api/templates/deployment.yaml
new file mode 100644
index 000000000..c6ad69067
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/deployment.yaml
@@ -0,0 +1,96 @@
+{{- $name := include "identity-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "identity-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "identity-api.name" . }}
+ chart: {{ template "identity-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "identity-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "identity-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/identity-api/templates/ingress-dockerk8s.yaml b/deploy/k8s/archived/helm/identity-api/templates/ingress-dockerk8s.yaml
new file mode 100644
index 000000000..b6a8980f2
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/ingress-dockerk8s.yaml
@@ -0,0 +1,33 @@
+{{- if .Values.ingress.enabled -}}
+{{- if .Values.inf.k8s.local -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.identity }}
+{{- $name := include "identity-api.fullname" . -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ $name }}-local
+ labels:
+ app: {{ template "identity-api.name" . }}
+ chart: {{ template "identity-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+ rules:
+ - http:
+ paths:
+ - backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ path: {{ $ingressPath }}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/identity-api/templates/ingress.yaml b/deploy/k8s/archived/helm/identity-api/templates/ingress.yaml
new file mode 100644
index 000000000..751636926
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/ingress.yaml
@@ -0,0 +1,46 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.identity }}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "identity-api.fullname" . }}
+ labels:
+ app: {{ template "identity-api.name" . }}
+ chart: {{ template "identity-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/identity-api/templates/service.yaml b/deploy/k8s/archived/helm/identity-api/templates/service.yaml
new file mode 100644
index 000000000..bca200389
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.identity }}
+ labels:
+ app: {{ template "identity-api.name" . }}
+ chart: {{ template "identity-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "identity-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/identity-api/values.yaml b/deploy/k8s/archived/helm/identity-api/values.yaml
new file mode 100644
index 000000000..7b57dfde1
--- /dev/null
+++ b/deploy/k8s/archived/helm/identity-api/values.yaml
@@ -0,0 +1,84 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /identity
+
+image:
+ repository: eshop/identity.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: true
+ annotations: {}
+ hosts:
+ - chart-example.local
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+env:
+ urls:
+ configmap:
+ - name: ConnectionString
+ key: identity__ConnectionString
+ - name: DPConnectionString
+ key: identity__keystore
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: MvcClient
+ key: mvc_e
+ - name: SpaClient
+ key: spa_e
+ - name: LocationApiClient
+ key: locations_e
+ - name: MarketingApiClient
+ key: marketing_e
+ - name: BasketApiClient
+ key: basket_e
+ - name: OrderingApiClient
+ key: ordering_e
+ - name: MobileShoppingAggClient
+ key: mobileshoppingagg_e
+ - name: WebShoppingAggClient
+ key: webshoppingagg_e
+ - name: XamarinCallback
+ key: xamarin_callback_e
+ - name: WebhooksApiClient
+ key: webhooksapi_e
+ - name: WebhooksWebClient
+ key: webhooksweb_e
+ - name: EnableDevspaces
+ key: enableDevspaces
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: IsClusterEnv
+ value: 'True'
+
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
+
+enableDevspaces: "false"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/inf.yaml b/deploy/k8s/archived/helm/inf.yaml
new file mode 100644
index 000000000..938be3d45
--- /dev/null
+++ b/deploy/k8s/archived/helm/inf.yaml
@@ -0,0 +1,56 @@
+# This helm values file defines all infrastructure used by eShopOnContainers.
+# It is used on all charts, so ** MUST BE INCLUDED ** on every deployment
+
+inf:
+ mesh:
+ enabled: false # True to enable Linkerd (set by deploy-all.ps1)
+ tls:
+ enabled: false # True to enable TLS (set by deploy-all.ps1)
+ issuer: "" # cert-manager issuer to use for retrieving certs (set by deploy-all.ps1)
+ sql: # inf.sql defines the sql server databases & logins
+# host: my-sql-server # Uncomment to specify a custom sql-server to be used. By default "sql-data-" will be used
+ common:
+ user: sa # SQL user
+ pwd: Pass@word # SQL pwd
+ pid: Developer
+ catalog: # inf.sql.catalog: settings for the catalog-api sql (user, pwd, db)
+ db: CatalogDb # Catalog API SQL db name
+ ordering: # inf.sql.ordering: settings for the ordering-api sql (user, pwd, db)
+ db: OrderingDb # Ordering API SQL db name
+ identity:
+ db: IdentityDb # Ordering API SQL db name
+ marketing:
+ db: MarketingDb # Marketing API SQL db name
+ webhooks:
+ db: WebhooksDb # Webhooks DB
+ mongo:
+# host: my-nosql-data # Uncomment to use specify custom mongo host. By default nosql-data is used
+ locations:
+ database: LocationsDb
+ marketing:
+ database: MarketingDb
+ redis: # inf.redis defines the redis' connection strings
+ basket:
+ svc: basket-data # Name of k8s svc for basket redis
+ constr: basket-data # Connection string to Redis used by Basket API
+ keystore:
+ svc: keystore-data # Name of k8s svc for keystore-data redis
+ constr: keystore-data # Connection string to Redis used as a Keystore (by Identity API)
+ eventbus:
+ svc: rabbitmq # Name of k8s svc for rabbitmq
+ constr: rabbitmq # Event bus connection string
+ useAzure: false # true if use Azure Service Bus. False if RabbitMQ
+ appinsights:
+ key: "" # App insights to use
+ k8s: # inf.k8s defines Kubernetes cluster global config
+ dns: "" # k8s external DNS. This value or ip value MUST BE PROVIDED
+ local: false # True when deploying on "local K8s" provided by Docker Desktop.
+ misc: # inf.misc contains miscellaneous configuration related to infrastructure
+ useLoadTest: false # If running under loading test or not
+ useAzureStorage: false # If catalog api uses azure storage or not
+# registry: # Uncomment "registry" to specify registry secret
+# secretName: # secretName is the name of the secret inside k8s
+# server: # Registry login server
+# login: # User login
+# pwd: # User pwd
+
diff --git a/deploy/k8s/archived/helm/ingress_values.yaml b/deploy/k8s/archived/helm/ingress_values.yaml
new file mode 100644
index 000000000..5f4d653c0
--- /dev/null
+++ b/deploy/k8s/archived/helm/ingress_values.yaml
@@ -0,0 +1,8 @@
+# This file contains common ingress annotations when using AKS with Http Application Routing
+
+ingress:
+ annotations:
+ kubernetes.io/ingress.class: addon-http-application-routing
+ ingress.kubernetes.io/ssl-redirect: "false"
+ nginx.ingress.kubernetes.io/ssl-redirect: "false"
+
diff --git a/deploy/k8s/archived/helm/ingress_values_dockerk8s.yaml b/deploy/k8s/archived/helm/ingress_values_dockerk8s.yaml
new file mode 100644
index 000000000..f69af8a5b
--- /dev/null
+++ b/deploy/k8s/archived/helm/ingress_values_dockerk8s.yaml
@@ -0,0 +1,7 @@
+# This file contains common ingress annotations when using Kubernetes included in Docker Desktop
+
+ingress:
+ annotations:
+ kubernetes.io/ingress.class: "nginx"
+ ingress.kubernetes.io/ssl-redirect: "false"
+ nginx.ingress.kubernetes.io/ssl-redirect: "false"
diff --git a/deploy/k8s/archived/helm/ingress_values_linkerd.yaml b/deploy/k8s/archived/helm/ingress_values_linkerd.yaml
new file mode 100644
index 000000000..f85a3a57f
--- /dev/null
+++ b/deploy/k8s/archived/helm/ingress_values_linkerd.yaml
@@ -0,0 +1,16 @@
+# This file contains extra annotations to make Linkerd work with ingress.
+# ingress.mesh.annotations are inserted into ingress.annotations of the resource being generated, if mesh is deployed
+#
+# It is designed to work with NGINX ingress controller or the Http Application Routing
+#
+# Check https://linkerd.io/2/tasks/using-ingress/ for more info or other ingress controllers
+#
+# If using your custom file, use -ingressMeshAnnotationsFile parameter in deploy-all.ps1
+
+ingress:
+ mesh:
+ annotations:
+ nginx.ingress.kubernetes.io/configuration-snippet: |
+ proxy_set_header l5d-dst-override $service_name.$namespace.svc.cluster.local:$service_port;
+ proxy_hide_header l5d-remote-ip;
+ proxy_hide_header l5d-server-id;
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/keystore-data/.helmignore b/deploy/k8s/archived/helm/keystore-data/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/keystore-data/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/keystore-data/Chart.yaml b/deploy/k8s/archived/helm/keystore-data/Chart.yaml
new file mode 100644
index 000000000..0cfa515f9
--- /dev/null
+++ b/deploy/k8s/archived/helm/keystore-data/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: keystore-data
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/keystore-data/templates/NOTES.txt b/deploy/k8s/archived/helm/keystore-data/templates/NOTES.txt
new file mode 100644
index 000000000..bec3a1f0f
--- /dev/null
+++ b/deploy/k8s/archived/helm/keystore-data/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Redis for keystore data installed
+----------------------------------------
+
+Redis is not directly exposed outside cluster. If need to access it from outside use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "keystore-data.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/keystore-data/templates/_helpers.tpl b/deploy/k8s/archived/helm/keystore-data/templates/_helpers.tpl
new file mode 100644
index 000000000..18786752f
--- /dev/null
+++ b/deploy/k8s/archived/helm/keystore-data/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "keystore-data.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 "keystore-data.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 "keystore-data.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/keystore-data/templates/deployment.yaml b/deploy/k8s/archived/helm/keystore-data/templates/deployment.yaml
new file mode 100644
index 000000000..34f1fe074
--- /dev/null
+++ b/deploy/k8s/archived/helm/keystore-data/templates/deployment.yaml
@@ -0,0 +1,43 @@
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "keystore-data.fullname" . }}
+ labels:
+ app: {{ template "keystore-data.name" . }}
+ chart: {{ template "keystore-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "keystore-data.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "keystore-data.name" . }}
+ release: {{ .Release.Name }}
+ spec:
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ ports:
+ - name: http
+ containerPort: 6379
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
diff --git a/deploy/k8s/archived/helm/keystore-data/templates/service.yaml b/deploy/k8s/archived/helm/keystore-data/templates/service.yaml
new file mode 100644
index 000000000..38e9a4273
--- /dev/null
+++ b/deploy/k8s/archived/helm/keystore-data/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.inf.redis.keystore.svc }}
+ labels:
+ app: {{ template "keystore-data.name" . }}
+ chart: {{ template "keystore-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "keystore-data.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/keystore-data/values.yaml b/deploy/k8s/archived/helm/keystore-data/values.yaml
new file mode 100644
index 000000000..17cc75ee7
--- /dev/null
+++ b/deploy/k8s/archived/helm/keystore-data/values.yaml
@@ -0,0 +1,19 @@
+replicaCount: 1
+
+image:
+ repository: redis
+ tag: 4.0.10
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 6379
+
+
+resources: {}
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
diff --git a/deploy/k8s/archived/helm/locations-api/.helmignore b/deploy/k8s/archived/helm/locations-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/locations-api/Chart.yaml b/deploy/k8s/archived/helm/locations-api/Chart.yaml
new file mode 100644
index 000000000..5126fe847
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: locations-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/locations-api/templates/NOTES.txt b/deploy/k8s/archived/helm/locations-api/templates/NOTES.txt
new file mode 100644
index 000000000..3b48889bf
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/templates/NOTES.txt
@@ -0,0 +1,9 @@
+eShop Locations API installed.
+------------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "locations-api.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
+
diff --git a/deploy/k8s/archived/helm/locations-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/locations-api/templates/_helpers.tpl
new file mode 100644
index 000000000..086a461ba
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "locations-api.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 "locations-api.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 "locations-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/locations-api/templates/_names.tpl b/deploy/k8s/archived/helm/locations-api/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/locations-api/templates/configmap.yaml b/deploy/k8s/archived/helm/locations-api/templates/configmap.yaml
new file mode 100644
index 000000000..c5d752509
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/templates/configmap.yaml
@@ -0,0 +1,22 @@
+{{- $name := include "locations-api.fullname" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+{{- $mongo := include "mongo-name" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "locations-api.name" . }}
+ chart: {{ template "locations-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
+ all_EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ internalurls__IdentityUrl: http://{{ .Values.app.svc.identity }}
+ urls__IdentityUrl: {{ $identity }}
+ locations__ConnectionString: mongodb://{{ $mongo }}
+ locations__Database: {{ .Values.inf.mongo.locations.database }}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/locations-api/templates/deployment.yaml b/deploy/k8s/archived/helm/locations-api/templates/deployment.yaml
new file mode 100644
index 000000000..9a5bb608c
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/templates/deployment.yaml
@@ -0,0 +1,96 @@
+{{- $name := include "locations-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "locations-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "locations-api.name" . }}
+ chart: {{ template "locations-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "locations-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "locations-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/locations-api/templates/service.yaml b/deploy/k8s/archived/helm/locations-api/templates/service.yaml
new file mode 100644
index 000000000..abd628beb
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.locations }}
+ labels:
+ app: {{ template "locations-api.name" . }}
+ chart: {{ template "locations-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "locations-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/locations-api/values.yaml b/deploy/k8s/archived/helm/locations-api/values.yaml
new file mode 100644
index 000000000..4718f2a0b
--- /dev/null
+++ b/deploy/k8s/archived/helm/locations-api/values.yaml
@@ -0,0 +1,66 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /locations-api
+
+image:
+ repository: eshop/locations.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: false
+ annotations: {}
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ - name: UseLoadTest
+ key: all_EnableLoadTest
+ - name: IdentityUrl
+ key: internalurls__IdentityUrl
+ - name: IdentityUrlExternal
+ key: urls__IdentityUrl
+ - name: ConnectionString
+ key: locations__ConnectionString
+ - name: Database
+ key: locations__Database
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
diff --git a/deploy/k8s/archived/helm/marketing-api/.helmignore b/deploy/k8s/archived/helm/marketing-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/marketing-api/Chart.yaml b/deploy/k8s/archived/helm/marketing-api/Chart.yaml
new file mode 100644
index 000000000..173f94fd6
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: marketing-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/marketing-api/templates/NOTES.txt b/deploy/k8s/archived/helm/marketing-api/templates/NOTES.txt
new file mode 100644
index 000000000..7fa66ed47
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/templates/NOTES.txt
@@ -0,0 +1,9 @@
+eShop Marketing API installed.
+------------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "marketing-api.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
+
diff --git a/deploy/k8s/archived/helm/marketing-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/marketing-api/templates/_helpers.tpl
new file mode 100644
index 000000000..c252aeeac
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "marketing-api.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 "marketing-api.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 "marketing-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/marketing-api/templates/_names.tpl b/deploy/k8s/archived/helm/marketing-api/templates/_names.tpl
new file mode 100644
index 000000000..605e92e7e
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/templates/_names.tpl
@@ -0,0 +1,60 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "protocol" -}}
+{{- if .Values.inf.tls.enabled -}}
+{{- printf "%s" "https" -}}
+{{- else -}}
+{{- printf "%s" "http" -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/marketing-api/templates/configmap.yaml b/deploy/k8s/archived/helm/marketing-api/templates/configmap.yaml
new file mode 100644
index 000000000..e6b495a7a
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/templates/configmap.yaml
@@ -0,0 +1,27 @@
+{{- $name := include "marketing-api.fullname" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+{{- $webshoppingapigw := include "url-of" (list .Values.app.ingress.entries.webshoppingapigw .) -}}
+{{- $mongo := include "mongo-name" . -}}
+{{- $sqlsrv := include "sql-name" . -}}
+{{- $protocol := include "protocol" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "marketing-api.name" . }}
+ chart: {{ template "marketing-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
+ all_EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ internalurls__IdentityUrl: http://{{ .Values.app.svc.identity }}
+ urls__IdentityUrl: {{ $protocol }}://{{ $identity }}
+ marketing__ConnectionString: Server={{ $sqlsrv }};Initial Catalog={{ .Values.inf.sql.marketing.db }};User Id={{ .Values.inf.sql.common.user }};Password={{ .Values.inf.sql.common.pwd }};
+ marketing__MongoConnectionString: mongodb://{{ $mongo }}
+ marketing__MongoDatabase: {{ .Values.inf.mongo.marketing.database }}
+ marketing__PicBaseUrl: {{ $protocol }}://{{ $webshoppingapigw }}/c/api/v1/catalog/items/[0]/pic/
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/marketing-api/templates/deployment.yaml b/deploy/k8s/archived/helm/marketing-api/templates/deployment.yaml
new file mode 100644
index 000000000..60d4cd1a3
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/templates/deployment.yaml
@@ -0,0 +1,96 @@
+{{- $name := include "marketing-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "marketing-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "marketing-api.name" . }}
+ chart: {{ template "marketing-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "marketing-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "marketing-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/marketing-api/templates/service.yaml b/deploy/k8s/archived/helm/marketing-api/templates/service.yaml
new file mode 100644
index 000000000..0e9bfbea2
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.marketing }}
+ labels:
+ app: {{ template "marketing-api.name" . }}
+ chart: {{ template "marketing-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "marketing-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/marketing-api/values.yaml b/deploy/k8s/archived/helm/marketing-api/values.yaml
new file mode 100644
index 000000000..00bebf27f
--- /dev/null
+++ b/deploy/k8s/archived/helm/marketing-api/values.yaml
@@ -0,0 +1,70 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /marketing-api
+
+image:
+ repository: eshop/marketing.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: false
+ annotations: {}
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ - name: UseLoadTest
+ key: all_EnableLoadTest
+ - name: IdentityUrl
+ key: internalurls__IdentityUrl
+ - name: IdentityUrlExternal
+ key: urls__IdentityUrl
+ - name: ConnectionString
+ key: marketing__ConnectionString
+ - name: MongoConnectionString
+ key: marketing__MongoConnectionString
+ - name: MongoDatabase
+ key: marketing__MongoDatabase
+ - name: PicBaseUrl
+ key: marketing__PicBaseUrl
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/.helmignore b/deploy/k8s/archived/helm/mobileshoppingagg/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/Chart.yaml b/deploy/k8s/archived/helm/mobileshoppingagg/Chart.yaml
new file mode 100644
index 000000000..957edd619
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: mobileshoppingagg
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/templates/NOTES.txt b/deploy/k8s/archived/helm/mobileshoppingagg/templates/NOTES.txt
new file mode 100644
index 000000000..61971f717
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Mobile Marketing Aggregator is installed
+----------------------------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "mobileshoppingagg.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/templates/_helpers.tpl b/deploy/k8s/archived/helm/mobileshoppingagg/templates/_helpers.tpl
new file mode 100644
index 000000000..b3aace0e7
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "mobileshoppingagg.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 "mobileshoppingagg.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 "mobileshoppingagg.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/templates/_names.tpl b/deploy/k8s/archived/helm/mobileshoppingagg/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/templates/configmap.yaml b/deploy/k8s/archived/helm/mobileshoppingagg/templates/configmap.yaml
new file mode 100644
index 000000000..1ca69509f
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/templates/configmap.yaml
@@ -0,0 +1,29 @@
+{{- $name := include "mobileshoppingagg.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "mobileshoppingagg.name" . }}
+ chart: {{ template "mobileshoppingagg.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all_EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ mobileshoppingagg__keystore: {{ .Values.inf.redis.keystore.constr }}
+ internalurls__basket: http://{{ .Values.app.svc.basket }}
+ internalurls__catalog: http://{{ .Values.app.svc.catalog }}
+ internalurls__identity: http://{{ .Values.app.svc.identity }}
+ internalurls__ordering: http://{{ .Values.app.svc.ordering }}
+ internalurls__basket__hc: http://{{ .Values.app.svc.basket }}/hc
+ internalurls__catalog__hc: http://{{ .Values.app.svc.catalog }}/hc
+ internalurls__identity__hc: http://{{ .Values.app.svc.identity }}/hc
+ internalurls__ordering__hc: http://{{ .Values.app.svc.ordering }}/hc
+ internalurls__marketing__hc: http://{{ .Values.app.svc.marketing }}/hc
+ internalurls__payment__hc: http://{{ .Values.app.svc.payment }}/hc
+ internalurls__location__hc: http://{{ .Values.app.svc.locations }}/hc
+ internalurls__grpcBasket: "http://{{ .Values.app.svc.basket }}:{{ .Values.service.grpcPort }}"
+ internalurls__grpcCatalog: "http://{{ .Values.app.svc.catalog }}:{{ .Values.service.grpcPort }}"
+ internalurls__grpcOrdering: "http://{{ .Values.app.svc.ordering }}:{{ .Values.service.grpcPort }}"
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/templates/deployment.yaml b/deploy/k8s/archived/helm/mobileshoppingagg/templates/deployment.yaml
new file mode 100644
index 000000000..41e1fa75c
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/templates/deployment.yaml
@@ -0,0 +1,96 @@
+{{- $name := include "mobileshoppingagg.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "mobileshoppingagg.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "mobileshoppingagg.name" . }}
+ chart: {{ template "mobileshoppingagg.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "mobileshoppingagg.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "mobileshoppingagg.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/templates/service.yaml b/deploy/k8s/archived/helm/mobileshoppingagg/templates/service.yaml
new file mode 100644
index 000000000..ef6726e88
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.mobileshoppingagg }}
+ labels:
+ app: {{ template "mobileshoppingagg.name" . }}
+ chart: {{ template "mobileshoppingagg.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "mobileshoppingagg.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/mobileshoppingagg/values.yaml b/deploy/k8s/archived/helm/mobileshoppingagg/values.yaml
new file mode 100644
index 000000000..844a59441
--- /dev/null
+++ b/deploy/k8s/archived/helm/mobileshoppingagg/values.yaml
@@ -0,0 +1,85 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /mobileshoppingagg
+
+image:
+ repository: eshop/mobileshoppingagg
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+ grpcPort: 81
+
+ingress:
+ enabled: false
+ annotations: {}
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: urls__basket
+ key: internalurls__basket
+ - name: urls__catalog
+ key: internalurls__catalog
+ - name: urls__orders
+ key: internalurls__ordering
+ - name: urls__identity
+ key: internalurls__identity
+ - name: CatalogUrlHC
+ key: internalurls__catalog__hc
+ - name: BasketUrlHC
+ key: internalurls__basket__hc
+ - name: IdentityUrlHC
+ key: internalurls__identity__hc
+ - name: OrderingUrlHC
+ key: internalurls__ordering__hc
+ - name: MarketingUrlHC
+ key: internalurls__marketing__hc
+ - name: PaymentUrlHC
+ key: internalurls__payment__hc
+ - name: LocationUrlHC
+ key: internalurls__location__hc
+ - name: urls__grpcBasket
+ key: internalurls__grpcBasket
+ - name: urls__grpcCatalog
+ key: internalurls__grpcCatalog
+ - name: urls__grpcOrdering
+ key: internalurls__grpcOrdering
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: ASPNETCORE_URLS
+ value: http://0.0.0.0:80
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: IsClusterEnv
+ value: 'True'
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
diff --git a/deploy/k8s/archived/helm/nosql-data/.helmignore b/deploy/k8s/archived/helm/nosql-data/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/nosql-data/Chart.yaml b/deploy/k8s/archived/helm/nosql-data/Chart.yaml
new file mode 100644
index 000000000..848a11cbb
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: nosql-data
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/nosql-data/templates/NOTES.txt b/deploy/k8s/archived/helm/nosql-data/templates/NOTES.txt
new file mode 100644
index 000000000..116c3c4e0
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop MongoDb Installed
+-----------------------
+
+MongoDb is not exposed outside the cluster. If need to access it from outside, use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "nosql-data.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/nosql-data/templates/_helpers.tpl b/deploy/k8s/archived/helm/nosql-data/templates/_helpers.tpl
new file mode 100644
index 000000000..99be734f7
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "nosql-data.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 "nosql-data.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 "nosql-data.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/nosql-data/templates/_names.tpl b/deploy/k8s/archived/helm/nosql-data/templates/_names.tpl
new file mode 100644
index 000000000..56fb974fc
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/templates/_names.tpl
@@ -0,0 +1,8 @@
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/nosql-data/templates/deployment.yaml b/deploy/k8s/archived/helm/nosql-data/templates/deployment.yaml
new file mode 100644
index 000000000..9b1f32319
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/templates/deployment.yaml
@@ -0,0 +1,43 @@
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "nosql-data.fullname" . }}
+ labels:
+ app: {{ template "nosql-data.name" . }}
+ chart: {{ template "nosql-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "nosql-data.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "nosql-data.name" . }}
+ release: {{ .Release.Name }}
+ spec:
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ ports:
+ - name: http
+ containerPort: 27017
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
diff --git a/deploy/k8s/archived/helm/nosql-data/templates/service.yaml b/deploy/k8s/archived/helm/nosql-data/templates/service.yaml
new file mode 100644
index 000000000..478cadfea
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ template "mongo-name" . }}
+ labels:
+ app: {{ template "nosql-data.name" . }}
+ chart: {{ template "nosql-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "nosql-data.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/nosql-data/values.yaml b/deploy/k8s/archived/helm/nosql-data/values.yaml
new file mode 100644
index 000000000..1a380e6b4
--- /dev/null
+++ b/deploy/k8s/archived/helm/nosql-data/values.yaml
@@ -0,0 +1,19 @@
+replicaCount: 1
+
+image:
+ repository: mongo
+ tag: 3.6.5-jessie
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 27017
+
+
+resources: {}
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
diff --git a/deploy/k8s/archived/helm/ordering-api/.helmignore b/deploy/k8s/archived/helm/ordering-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/ordering-api/Chart.yaml b/deploy/k8s/archived/helm/ordering-api/Chart.yaml
new file mode 100644
index 000000000..b65ca4b9a
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: ordering-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/ordering-api/templates/NOTES.txt b/deploy/k8s/archived/helm/ordering-api/templates/NOTES.txt
new file mode 100644
index 000000000..43bfd2fdf
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Ordering API installed.
+-----------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "ordering-api.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
diff --git a/deploy/k8s/archived/helm/ordering-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/ordering-api/templates/_helpers.tpl
new file mode 100644
index 000000000..978c08c64
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "ordering-api.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 "ordering-api.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 "ordering-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/ordering-api/templates/_names.tpl b/deploy/k8s/archived/helm/ordering-api/templates/_names.tpl
new file mode 100644
index 000000000..39ee485ef
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/templates/_names.tpl
@@ -0,0 +1,51 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/ordering-api/templates/configmap.yaml b/deploy/k8s/archived/helm/ordering-api/templates/configmap.yaml
new file mode 100644
index 000000000..e64a6c841
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/templates/configmap.yaml
@@ -0,0 +1,19 @@
+{{- $name := include "ordering-api.fullname" . -}}
+{{- $sqlsrv := include "sql-name" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "ordering-api.name" . }}
+ chart: {{ template "ordering-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ ordering__ConnectionString: Server={{ $sqlsrv }};Initial Catalog={{ .Values.inf.sql.ordering.db }};User Id={{ .Values.inf.sql.common.user }};Password={{ .Values.inf.sql.common.pwd }};
+ ordering__EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ urls__IdentityUrl: http://{{ .Values.app.svc.identity }}
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/ordering-api/templates/deployment.yaml b/deploy/k8s/archived/helm/ordering-api/templates/deployment.yaml
new file mode 100644
index 000000000..327040701
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/templates/deployment.yaml
@@ -0,0 +1,99 @@
+{{- $name := include "ordering-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "ordering-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "ordering-api.name" . }}
+ chart: {{ template "ordering-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "ordering-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "ordering-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ - name: grpc
+ containerPort: 81
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/ordering-api/templates/service.yaml b/deploy/k8s/archived/helm/ordering-api/templates/service.yaml
new file mode 100644
index 000000000..7c2cb0945
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/templates/service.yaml
@@ -0,0 +1,23 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.ordering }}
+ labels:
+ app: {{ template "ordering-api.name" . }}
+ chart: {{ template "ordering-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ - port: {{ .Values.service.grpcPort }}
+ targetPort: grpc
+ protocol: TCP
+ name: grpc
+ selector:
+ app: {{ template "ordering-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/ordering-api/values.yaml b/deploy/k8s/archived/helm/ordering-api/values.yaml
new file mode 100644
index 000000000..7eff1a48b
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-api/values.yaml
@@ -0,0 +1,69 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /ordering-api
+
+image:
+ repository: eshop/ordering.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+ grpcPort: 81
+
+ingress:
+ enabled: false
+ annotations: {}
+ hosts:
+ - chart-example.local
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ConnectionString
+ key: ordering__ConnectionString
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ - name: UseLoadTest
+ key: ordering__EnableLoadTest
+ - name: IdentityUrl
+ key: urls__IdentityUrl
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: PORT
+ value: "80"
+ - name: GRPC_PORT
+ value: "81"
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/.helmignore b/deploy/k8s/archived/helm/ordering-backgroundtasks/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/Chart.yaml b/deploy/k8s/archived/helm/ordering-backgroundtasks/Chart.yaml
new file mode 100644
index 000000000..6ad4f47e6
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: ordering-backgroundtasks
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/NOTES.txt b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/NOTES.txt
new file mode 100644
index 000000000..54e1b49ea
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/NOTES.txt
@@ -0,0 +1,3 @@
+eShop Ordering Background Tasks installed.
+------------------------------------------
+
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/_helpers.tpl b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/_helpers.tpl
new file mode 100644
index 000000000..e61b78285
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "ordering-backgroundtasks.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 "ordering-backgroundtasks.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 "ordering-backgroundtasks.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/_names.tpl b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/_names.tpl
new file mode 100644
index 000000000..39ee485ef
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/_names.tpl
@@ -0,0 +1,51 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/configmap.yaml b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/configmap.yaml
new file mode 100644
index 000000000..7ed4a0e8e
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/configmap.yaml
@@ -0,0 +1,21 @@
+{{- $name := include "ordering-backgroundtasks.fullname" . -}}
+{{- $sqlsrv := include "sql-name" . -}}
+{{- $cfgname := printf "cfg-%s" $name | trunc 63 }}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "{{ $cfgname }}"
+ labels:
+ app: {{ template "ordering-backgroundtasks.name" . }}
+ chart: {{ template "ordering-backgroundtasks.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ ordering__ConnectionString: Server={{ $sqlsrv }};Initial Catalog={{ .Values.inf.sql.ordering.db }};User Id={{ .Values.inf.sql.common.user }};Password={{ .Values.inf.sql.common.pwd }};
+ ordering__EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
+ graceperiodmanager__CheckUpdateTime: "{{ .Values.cfg.checkUpdateTime }}"
+ graceperiodmanager__GracePeriodTime: "{{ .Values.cfg.gracePeriodTime }}"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/deployment.yaml b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/deployment.yaml
new file mode 100644
index 000000000..d93c7f764
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/deployment.yaml
@@ -0,0 +1,92 @@
+{{- $name := include "ordering-backgroundtasks.fullname" . -}}
+{{- $cfgname := printf "cfg-%s" $name | trunc 63 }}
+
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "ordering-backgroundtasks.fullname" . }}
+ labels:
+ app: {{ template "ordering-backgroundtasks.name" . }}
+ chart: {{ template "ordering-backgroundtasks.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "ordering-backgroundtasks.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "ordering-backgroundtasks.name" . }}
+ release: {{ .Release.Name }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/service.yaml b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/service.yaml
new file mode 100644
index 000000000..d8fcba036
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.orderingbackgroundtasks }}
+ labels:
+ app: {{ template "ordering-backgroundtasks.name" . }}
+ chart: {{ template "ordering-backgroundtasks.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "ordering-backgroundtasks.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/ordering-backgroundtasks/values.yaml b/deploy/k8s/archived/helm/ordering-backgroundtasks/values.yaml
new file mode 100644
index 000000000..d065f0345
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-backgroundtasks/values.yaml
@@ -0,0 +1,70 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /ordering-backgroundtasks
+
+image:
+ repository: eshop/ordering.backgroundtasks
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: false
+ annotations: {}
+ hosts:
+ - chart-example.local
+ tls: []
+
+cfg:
+ checkUpdateTime: "15000"
+ gracePeriodTime: "1"
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ConnectionString
+ key: ordering__ConnectionString
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ - name: UseLoadTest
+ key: ordering__EnableLoadTest
+ - name: CheckUpdateTime
+ key: graceperiodmanager__CheckUpdateTime
+ - name: GracePeriodTime
+ key: graceperiodmanager__GracePeriodTime
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/.helmignore b/deploy/k8s/archived/helm/ordering-signalrhub/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/Chart.yaml b/deploy/k8s/archived/helm/ordering-signalrhub/Chart.yaml
new file mode 100644
index 000000000..d43e83bf0
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: ordering-signalrhub
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/templates/NOTES.txt b/deploy/k8s/archived/helm/ordering-signalrhub/templates/NOTES.txt
new file mode 100644
index 000000000..fc55c9dfa
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Ordering SignalR Hub installed
+------------------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "ordering-signalrhub.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/templates/_helpers.tpl b/deploy/k8s/archived/helm/ordering-signalrhub/templates/_helpers.tpl
new file mode 100644
index 000000000..2c11ddb51
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "ordering-signalrhub.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 "ordering-signalrhub.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 "ordering-signalrhub.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/templates/_names.tpl b/deploy/k8s/archived/helm/ordering-signalrhub/templates/_names.tpl
new file mode 100644
index 000000000..39ee485ef
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/templates/_names.tpl
@@ -0,0 +1,51 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/templates/configmap.yaml b/deploy/k8s/archived/helm/ordering-signalrhub/templates/configmap.yaml
new file mode 100644
index 000000000..bab4ebc94
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/templates/configmap.yaml
@@ -0,0 +1,18 @@
+{{- $name := include "ordering-signalrhub.fullname" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "ordering-signalrhub.name" . }}
+ chart: {{ template "ordering-signalrhub.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
+ signalr__StoreConnectionString: {{ .Values.inf.redis.keystore.constr }}
+ urls__IdentityUrl: http://{{ $identity }}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/templates/deployment.yaml b/deploy/k8s/archived/helm/ordering-signalrhub/templates/deployment.yaml
new file mode 100644
index 000000000..af3867ea5
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/templates/deployment.yaml
@@ -0,0 +1,70 @@
+{{- $name := include "ordering-signalrhub.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "ordering-signalrhub.fullname" . }}
+ labels:
+ app: {{ template "ordering-signalrhub.name" . }}
+ chart: {{ template "ordering-signalrhub.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "ordering-signalrhub.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "ordering-signalrhub.name" . }}
+ release: {{ .Release.Name }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/templates/service.yaml b/deploy/k8s/archived/helm/ordering-signalrhub/templates/service.yaml
new file mode 100644
index 000000000..501539923
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.orderingsignalrhub }}
+ labels:
+ app: {{ template "ordering-signalrhub.name" . }}
+ chart: {{ template "ordering-signalrhub.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "ordering-signalrhub.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/ordering-signalrhub/values.yaml b/deploy/k8s/archived/helm/ordering-signalrhub/values.yaml
new file mode 100644
index 000000000..19099b147
--- /dev/null
+++ b/deploy/k8s/archived/helm/ordering-signalrhub/values.yaml
@@ -0,0 +1,57 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /ordering-signalrhub
+
+image:
+ repository: eshop/ordering.signalrhub
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: false
+ annotations: {}
+ hosts:
+ - chart-example.local
+ tls: []
+
+cfg:
+ checkUpdateTime: "15000"
+ gracePeriodTime: "1"
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ - name: IdentityUrl
+ key: urls__IdentityUrl
+ - name: SignalrStoreConnectionString
+ key: signalr__StoreConnectionString
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: IsClusterEnv
+ values: 'True'
+
diff --git a/deploy/k8s/archived/helm/payment-api/.helmignore b/deploy/k8s/archived/helm/payment-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/payment-api/Chart.yaml b/deploy/k8s/archived/helm/payment-api/Chart.yaml
new file mode 100644
index 000000000..b7dba9341
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: payment-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/payment-api/templates/NOTES.txt b/deploy/k8s/archived/helm/payment-api/templates/NOTES.txt
new file mode 100644
index 000000000..6d178f344
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/templates/NOTES.txt
@@ -0,0 +1,9 @@
+eShop Payment API installed.
+----------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "payment-api.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
+
diff --git a/deploy/k8s/archived/helm/payment-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/payment-api/templates/_helpers.tpl
new file mode 100644
index 000000000..2f98d7ea2
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "payment-api.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 "payment-api.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 "payment-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/payment-api/templates/_names.tpl b/deploy/k8s/archived/helm/payment-api/templates/_names.tpl
new file mode 100644
index 000000000..39ee485ef
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/templates/_names.tpl
@@ -0,0 +1,51 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/payment-api/templates/configmap.yaml b/deploy/k8s/archived/helm/payment-api/templates/configmap.yaml
new file mode 100644
index 000000000..3bdb95c0f
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/templates/configmap.yaml
@@ -0,0 +1,15 @@
+{{- $name := include "payment-api.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "payment-api.name" . }}
+ chart: {{ template "payment-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/payment-api/templates/deployment.yaml b/deploy/k8s/archived/helm/payment-api/templates/deployment.yaml
new file mode 100644
index 000000000..f83eb37da
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/templates/deployment.yaml
@@ -0,0 +1,96 @@
+{{- $name := include "payment-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "payment-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "payment-api.name" . }}
+ chart: {{ template "payment-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "payment-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "payment-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/payment-api/templates/service.yaml b/deploy/k8s/archived/helm/payment-api/templates/service.yaml
new file mode 100644
index 000000000..14fc7479c
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.payment }}
+ labels:
+ app: {{ template "payment-api.name" . }}
+ chart: {{ template "payment-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "payment-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/payment-api/values.yaml b/deploy/k8s/archived/helm/payment-api/values.yaml
new file mode 100644
index 000000000..341e4e1a9
--- /dev/null
+++ b/deploy/k8s/archived/helm/payment-api/values.yaml
@@ -0,0 +1,56 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /payment-api
+
+image:
+ repository: eshop/payment.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: false
+ annotations: {}
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
diff --git a/deploy/k8s/archived/helm/rabbitmq/.helmignore b/deploy/k8s/archived/helm/rabbitmq/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/rabbitmq/Chart.yaml b/deploy/k8s/archived/helm/rabbitmq/Chart.yaml
new file mode 100644
index 000000000..2d955858e
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: rabbitmq
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/rabbitmq/templates/NOTES.txt b/deploy/k8s/archived/helm/rabbitmq/templates/NOTES.txt
new file mode 100644
index 000000000..49edf7f9c
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop rabbitmq installed
+-------------------------
+
+rabbitmq is not directly exposed outside cluster. If need to access it from outside use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "rabbitmq.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/rabbitmq/templates/_helpers.tpl b/deploy/k8s/archived/helm/rabbitmq/templates/_helpers.tpl
new file mode 100644
index 000000000..bbbb2e33d
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "rabbitmq.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 "rabbitmq.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 "rabbitmq.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/rabbitmq/templates/_names.tpl b/deploy/k8s/archived/helm/rabbitmq/templates/_names.tpl
new file mode 100644
index 000000000..be0a9b800
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/templates/_names.tpl
@@ -0,0 +1,8 @@
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "rabbitmq" -}}
+{{- end -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/rabbitmq/templates/deployment.yaml b/deploy/k8s/archived/helm/rabbitmq/templates/deployment.yaml
new file mode 100644
index 000000000..9819a6455
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/templates/deployment.yaml
@@ -0,0 +1,43 @@
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "rabbitmq.fullname" . }}
+ labels:
+ app: {{ template "rabbitmq.name" . }}
+ chart: {{ template "rabbitmq.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "rabbitmq.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "rabbitmq.name" . }}
+ release: {{ .Release.Name }}
+ spec:
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ ports:
+ - name: http
+ containerPort: 5672
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
diff --git a/deploy/k8s/archived/helm/rabbitmq/templates/service.yaml b/deploy/k8s/archived/helm/rabbitmq/templates/service.yaml
new file mode 100644
index 000000000..5de39e0a8
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.inf.eventbus.svc }}
+ labels:
+ app: {{ template "rabbitmq.name" . }}
+ chart: {{ template "rabbitmq.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "rabbitmq.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/rabbitmq/values.yaml b/deploy/k8s/archived/helm/rabbitmq/values.yaml
new file mode 100644
index 000000000..5e9efd521
--- /dev/null
+++ b/deploy/k8s/archived/helm/rabbitmq/values.yaml
@@ -0,0 +1,19 @@
+replicaCount: 1
+
+image:
+ repository: rabbitmq
+ tag: 3-management
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 5672
+
+
+resources: {}
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
diff --git a/deploy/k8s/archived/helm/sql-data/.helmignore b/deploy/k8s/archived/helm/sql-data/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/sql-data/Chart.yaml b/deploy/k8s/archived/helm/sql-data/Chart.yaml
new file mode 100644
index 000000000..6e5d726c5
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: sql-data
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/sql-data/templates/NOTES.txt b/deploy/k8s/archived/helm/sql-data/templates/NOTES.txt
new file mode 100644
index 000000000..468a155b0
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop SQL Server Installed
+--------------------------
+
+SQL server is not exposed outside the cluster. If need to access it from outside, use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "sql-data.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/sql-data/templates/_helpers.tpl b/deploy/k8s/archived/helm/sql-data/templates/_helpers.tpl
new file mode 100644
index 000000000..ee953f2f8
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "sql-data.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 "sql-data.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 "sql-data.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/sql-data/templates/_names.tpl b/deploy/k8s/archived/helm/sql-data/templates/_names.tpl
new file mode 100644
index 000000000..dc35d62fe
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/templates/_names.tpl
@@ -0,0 +1,8 @@
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/sql-data/templates/deployment.yaml b/deploy/k8s/archived/helm/sql-data/templates/deployment.yaml
new file mode 100644
index 000000000..4b2f589ef
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/templates/deployment.yaml
@@ -0,0 +1,50 @@
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "sql-data.fullname" . }}
+ labels:
+ app: {{ template "sql-data.name" . }}
+ chart: {{ template "sql-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "sql-data.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "sql-data.name" . }}
+ release: {{ .Release.Name }}
+ spec:
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: ACCEPT_EULA
+ value: "Y"
+ - name: MSSQL_PID
+ value: {{ .Values.inf.sql.common.pid }}
+ - name: MSSQL_SA_PASSWORD
+ value: {{ .Values.inf.sql.common.pwd }}
+ ports:
+ - name: http
+ containerPort: 1433
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
diff --git a/deploy/k8s/archived/helm/sql-data/templates/service.yaml b/deploy/k8s/archived/helm/sql-data/templates/service.yaml
new file mode 100644
index 000000000..b9b8d59fc
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ template "sql-name" . }}
+ labels:
+ app: {{ template "sql-data.name" . }}
+ chart: {{ template "sql-data.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "sql-data.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/sql-data/values.yaml b/deploy/k8s/archived/helm/sql-data/values.yaml
new file mode 100644
index 000000000..0ed76556a
--- /dev/null
+++ b/deploy/k8s/archived/helm/sql-data/values.yaml
@@ -0,0 +1,19 @@
+replicaCount: 1
+
+image:
+ repository: microsoft/mssql-server-linux
+ tag: 2017-CU7
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 1433
+
+
+resources: {}
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
diff --git a/deploy/k8s/archived/helm/tls-support/.helmignore b/deploy/k8s/archived/helm/tls-support/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/tls-support/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/tls-support/Chart.yaml b/deploy/k8s/archived/helm/tls-support/Chart.yaml
new file mode 100644
index 000000000..e21e04e95
--- /dev/null
+++ b/deploy/k8s/archived/helm/tls-support/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: tt-ssl
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/tls-support/templates/_helpers.tpl b/deploy/k8s/archived/helm/tls-support/templates/_helpers.tpl
new file mode 100644
index 000000000..5088703f0
--- /dev/null
+++ b/deploy/k8s/archived/helm/tls-support/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "tt-tls.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 "tt-tls.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 "tt-tls.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/tls-support/templates/issuer.yaml b/deploy/k8s/archived/helm/tls-support/templates/issuer.yaml
new file mode 100644
index 000000000..ae9587198
--- /dev/null
+++ b/deploy/k8s/archived/helm/tls-support/templates/issuer.yaml
@@ -0,0 +1,17 @@
+apiVersion: cert-manager.io/v1alpha2
+kind: Issuer
+metadata:
+ name: {{ .Values.issuerName }}
+ namespace: default
+ environment: {{ .Values.environment }}
+ app: {{ .Values.applicationName }}
+spec:
+ acme:
+ server: {{ .Values.server }}
+ email: not@used.com
+ privateKeySecretRef:
+ name: {{ .Values.issuerSecretName }}
+ solvers:
+ - http01:
+ ingress:
+ class: {{ .Values.ingressClass }}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/tls-support/values-prod.yaml b/deploy/k8s/archived/helm/tls-support/values-prod.yaml
new file mode 100644
index 000000000..fb577b9b7
--- /dev/null
+++ b/deploy/k8s/archived/helm/tls-support/values-prod.yaml
@@ -0,0 +1,8 @@
+applicationName: eshop
+issuerName: letsencrypt-prod
+certName: eshop-cert-prod
+environment: prod
+server: https://acme-v02.api.letsencrypt.org/directory
+certSecretName: eshop-letsencrypt-prod
+issuerSecretName: letsencrypt-prod
+ingressClass: addon-http-application-routing
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/tls-support/values-staging.yaml b/deploy/k8s/archived/helm/tls-support/values-staging.yaml
new file mode 100644
index 000000000..89dcd6654
--- /dev/null
+++ b/deploy/k8s/archived/helm/tls-support/values-staging.yaml
@@ -0,0 +1,8 @@
+applicationName: eshop
+issuerName: letsencrypt-staging
+certName: eshop-cert-staging
+environment: staging
+server: https://acme-staging-v02.api.letsencrypt.org/directory
+certSecretName: eshop-letsencrypt-staging
+issuerSecretName: letsencrypt-staging
+ingressClass: addon-http-application-routing
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webhooks-api/.helmignore b/deploy/k8s/archived/helm/webhooks-api/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/webhooks-api/Chart.yaml b/deploy/k8s/archived/helm/webhooks-api/Chart.yaml
new file mode 100644
index 000000000..f8e950782
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: webhooks-api
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/webhooks-api/templates/NOTES.txt b/deploy/k8s/archived/helm/webhooks-api/templates/NOTES.txt
new file mode 100644
index 000000000..818b99d1b
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Ordering API installed.
+-----------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "webhooks-api.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
diff --git a/deploy/k8s/archived/helm/webhooks-api/templates/_helpers.tpl b/deploy/k8s/archived/helm/webhooks-api/templates/_helpers.tpl
new file mode 100644
index 000000000..3742516b7
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "webhooks-api.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 "webhooks-api.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 "webhooks-api.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/webhooks-api/templates/_names.tpl b/deploy/k8s/archived/helm/webhooks-api/templates/_names.tpl
new file mode 100644
index 000000000..752355276
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/templates/_names.tpl
@@ -0,0 +1,60 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "protocol" -}}
+{{- if .Values.inf.tls.enabled -}}
+{{- printf "%s" "https" -}}
+{{- else -}}
+{{- printf "%s" "http" -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webhooks-api/templates/configmap.yaml b/deploy/k8s/archived/helm/webhooks-api/templates/configmap.yaml
new file mode 100644
index 000000000..05b9b7f57
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/templates/configmap.yaml
@@ -0,0 +1,21 @@
+{{- $name := include "webhooks-api.fullname" . -}}
+{{- $sqlsrv := include "sql-name" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+{{- $protocol := include "protocol" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "webhooks-api.name" . }}
+ chart: {{ template "webhooks-api.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ webhooks__ConnectionString: Server={{ $sqlsrv }};Initial Catalog={{ .Values.inf.sql.webhooks.db }};User Id={{ .Values.inf.sql.common.user }};Password={{ .Values.inf.sql.common.pwd }};
+ urls__IdentityUrl: http://{{ $identity }}
+ urls__IdentityUrlExternal: {{ $protocol }}://{{ $identity }}
+ all__EventBusConnection: {{ .Values.inf.eventbus.constr }}
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webhooks-api/templates/deployment.yaml b/deploy/k8s/archived/helm/webhooks-api/templates/deployment.yaml
new file mode 100644
index 000000000..2ecb885bf
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/templates/deployment.yaml
@@ -0,0 +1,75 @@
+{{- $name := include "webhooks-api.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "webhooks-api.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "webhooks-api.name" . }}
+ chart: {{ template "webhooks-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "webhooks-api.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "webhooks-api.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/webhooks-api/templates/ingress.yaml b/deploy/k8s/archived/helm/webhooks-api/templates/ingress.yaml
new file mode 100644
index 000000000..c7c096b77
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/templates/ingress.yaml
@@ -0,0 +1,46 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.webhooks }}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "webhooks-api.fullname" . }}
+ labels:
+ app: {{ template "webhooks-api.name" . }}
+ chart: {{ template "webhooks-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/webhooks-api/templates/service.yaml b/deploy/k8s/archived/helm/webhooks-api/templates/service.yaml
new file mode 100644
index 000000000..d8a02ba65
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.webhooks }}
+ labels:
+ app: {{ template "webhooks-api.name" . }}
+ chart: {{ template "webhooks-api.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "webhooks-api.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/webhooks-api/values.yaml b/deploy/k8s/archived/helm/webhooks-api/values.yaml
new file mode 100644
index 000000000..f6b1957e9
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-api/values.yaml
@@ -0,0 +1,53 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /webhooks-api
+
+image:
+ repository: eshop/webhooks.api
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: true
+ annotations: {}
+ hosts:
+ - chart-example.local
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ConnectionString
+ key: webhooks__ConnectionString
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: EventBusConnection
+ key: all__EventBusConnection
+ - name: AzureServiceBusEnabled
+ key: all__UseAzureServiceBus
+ - name: IdentityUrl
+ key: urls__IdentityUrl
+ - name: IdentityUrlExternal
+ key: urls__IdentityUrlExternal
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+
diff --git a/deploy/k8s/archived/helm/webhooks-web/.helmignore b/deploy/k8s/archived/helm/webhooks-web/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/webhooks-web/Chart.yaml b/deploy/k8s/archived/helm/webhooks-web/Chart.yaml
new file mode 100644
index 000000000..420b4f16d
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: webhooks-web
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/webhooks-web/templates/NOTES.txt b/deploy/k8s/archived/helm/webhooks-web/templates/NOTES.txt
new file mode 100644
index 000000000..b7f7f97ba
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Ordering API installed.
+-----------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "webhooks-web.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
diff --git a/deploy/k8s/archived/helm/webhooks-web/templates/_helpers.tpl b/deploy/k8s/archived/helm/webhooks-web/templates/_helpers.tpl
new file mode 100644
index 000000000..cbc856713
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "webhooks-web.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 "webhooks-web.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 "webhooks-web.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/webhooks-web/templates/_names.tpl b/deploy/k8s/archived/helm/webhooks-web/templates/_names.tpl
new file mode 100644
index 000000000..752355276
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/templates/_names.tpl
@@ -0,0 +1,60 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
+
+
+{{- define "protocol" -}}
+{{- if .Values.inf.tls.enabled -}}
+{{- printf "%s" "https" -}}
+{{- else -}}
+{{- printf "%s" "http" -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webhooks-web/templates/configmap.yaml b/deploy/k8s/archived/helm/webhooks-web/templates/configmap.yaml
new file mode 100644
index 000000000..bd09c7c62
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/templates/configmap.yaml
@@ -0,0 +1,20 @@
+{{- $name := include "webhooks-web.fullname" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+{{- $webhooksweb := include "url-of" (list .Values.app.ingress.entries.webhooksweb .) -}}
+{{- $webhooks := include "url-of" (list .Values.app.ingress.entries.webhooks .) -}}
+{{- $protocol := include "protocol" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "webhooks-web.name" . }}
+ chart: {{ template "webhooks-web.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ urls__webhooks: {{ $protocol }}://{{ $webhooks }}
+ identity_e: {{ $protocol }}://{{ $identity }}
+ webhooksweb_e: {{ $protocol }}://{{ $webhooksweb }}
+ urls_webhooksweb: http://{{ .Values.app.svc.webhooksweb }}
diff --git a/deploy/k8s/archived/helm/webhooks-web/templates/deployment.yaml b/deploy/k8s/archived/helm/webhooks-web/templates/deployment.yaml
new file mode 100644
index 000000000..43d406524
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/templates/deployment.yaml
@@ -0,0 +1,75 @@
+{{- $name := include "webhooks-web.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "webhooks-web.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "webhooks-web.name" . }}
+ chart: {{ template "webhooks-web.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "webhooks-web.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "webhooks-web.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/webhooks-web/templates/ingress.yaml b/deploy/k8s/archived/helm/webhooks-web/templates/ingress.yaml
new file mode 100644
index 000000000..1e5df8c45
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/templates/ingress.yaml
@@ -0,0 +1,45 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "webhooks-web.fullname" . }}
+ labels:
+ app: {{ template "webhooks-web.name" . }}
+ chart: {{ template "webhooks-web.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $.Values.app.svc.webhooksweb }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/webhooks-web/templates/service.yaml b/deploy/k8s/archived/helm/webhooks-web/templates/service.yaml
new file mode 100644
index 000000000..873ebcc0e
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.webhooksweb }}
+ labels:
+ app: {{ template "webhooks-web.name" . }}
+ chart: {{ template "webhooks-web.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "webhooks-web.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/webhooks-web/values.yaml b/deploy/k8s/archived/helm/webhooks-web/values.yaml
new file mode 100644
index 000000000..0e5b04b57
--- /dev/null
+++ b/deploy/k8s/archived/helm/webhooks-web/values.yaml
@@ -0,0 +1,52 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /webhooks-web
+
+image:
+ repository: eshop/webhooks.client
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: true
+ annotations: {}
+ hosts:
+ - chart-example.local
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: WebhooksUrl
+ key: urls__webhooks
+ - name: IdentityUrl
+ key: identity_e
+ - name: CallbackUrl
+ key: webhooksweb_e
+ - name: SelfUrl
+ key: webhooksweb_e
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Production
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: Token
+ value: "WebHooks-Demo-Web" # Can use whatever you want
+
+
diff --git a/deploy/k8s/archived/helm/webmvc/.helmignore b/deploy/k8s/archived/helm/webmvc/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/webmvc/Chart.yaml b/deploy/k8s/archived/helm/webmvc/Chart.yaml
new file mode 100644
index 000000000..c63e8924a
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: webmvc
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/webmvc/templates/NOTES.txt b/deploy/k8s/archived/helm/webmvc/templates/NOTES.txt
new file mode 100644
index 000000000..06e02a45d
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/NOTES.txt
@@ -0,0 +1,2 @@
+eShop WebMVC installed.
+-----------------------
diff --git a/deploy/k8s/archived/helm/webmvc/templates/_helpers.tpl b/deploy/k8s/archived/helm/webmvc/templates/_helpers.tpl
new file mode 100644
index 000000000..2e3bcef56
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "webmvc.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 "webmvc.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 "webmvc.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/webmvc/templates/_names.tpl b/deploy/k8s/archived/helm/webmvc/templates/_names.tpl
new file mode 100644
index 000000000..605e92e7e
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/_names.tpl
@@ -0,0 +1,60 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "protocol" -}}
+{{- if .Values.inf.tls.enabled -}}
+{{- printf "%s" "https" -}}
+{{- else -}}
+{{- printf "%s" "http" -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webmvc/templates/configmap.yaml b/deploy/k8s/archived/helm/webmvc/templates/configmap.yaml
new file mode 100644
index 000000000..2aa06fc7f
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/configmap.yaml
@@ -0,0 +1,26 @@
+{{- $name := include "webmvc.fullname" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+{{- $webshoppingapigw := include "url-of" (list .Values.app.ingress.entries.webshoppingapigw .) -}}
+{{- $mvc := include "url-of" (list .Values.app.ingress.entries.mvc .) -}}
+{{- $protocol := include "protocol" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "webmvc.name" . }}
+ chart: {{ template "webmvc.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
+ all_EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ webmvc__keystore: {{ .Values.inf.redis.keystore.constr }}
+ internalurls__apigwws: http://{{ .Values.app.svc.webshoppingapigw }}
+ internalurls__apigwwm: http://{{ .Values.app.svc.webmarketingapigw }}
+ internalurls__identity__hc: http://{{ .Values.app.svc.identity }}/hc
+ urls__apigwws: {{ $protocol }}://{{ $webshoppingapigw }}
+ urls__mvc: {{ $protocol }}://{{ $mvc }}
+ urls__IdentityUrl: {{ $protocol }}://{{ $identity }}
diff --git a/deploy/k8s/archived/helm/webmvc/templates/deployment.yaml b/deploy/k8s/archived/helm/webmvc/templates/deployment.yaml
new file mode 100644
index 000000000..2889dc757
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/deployment.yaml
@@ -0,0 +1,75 @@
+{{- $name := include "webmvc.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "webmvc.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "webmvc.name" . }}
+ chart: {{ template "webmvc.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "webmvc.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "webmvc.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/webmvc/templates/ingress-dockerk8s.yaml b/deploy/k8s/archived/helm/webmvc/templates/ingress-dockerk8s.yaml
new file mode 100644
index 000000000..72e043039
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/ingress-dockerk8s.yaml
@@ -0,0 +1,33 @@
+{{- if .Values.ingress.enabled -}}
+{{- if .Values.inf.k8s.local -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.mvc }}
+{{- $name := include "webmvc.fullname" . -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ $name }}-local
+ labels:
+ app: {{ template "webmvc.name" . }}
+ chart: {{ template "webmvc.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+ rules:
+ - http:
+ paths:
+ - backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ path: {{ $ingressPath }}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webmvc/templates/ingress.yaml b/deploy/k8s/archived/helm/webmvc/templates/ingress.yaml
new file mode 100644
index 000000000..1899f5a18
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/ingress.yaml
@@ -0,0 +1,46 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+{{- $serviceName := .Values.app.svc.mvc -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "webmvc.fullname" . }}
+ labels:
+ app: {{ template "webmvc.name" . }}
+ chart: {{ template "webmvc.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $serviceName }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/webmvc/templates/service.yaml b/deploy/k8s/archived/helm/webmvc/templates/service.yaml
new file mode 100644
index 000000000..74d87673f
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.mvc }}
+ labels:
+ app: {{ template "webmvc.name" . }}
+ chart: {{ template "webmvc.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "webmvc.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/webmvc/values.yaml b/deploy/k8s/archived/helm/webmvc/values.yaml
new file mode 100644
index 000000000..973f187f5
--- /dev/null
+++ b/deploy/k8s/archived/helm/webmvc/values.yaml
@@ -0,0 +1,61 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /webmvc
+
+image:
+ repository: eshop/webmvc
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: true
+ annotations: {}
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: UseLoadTest
+ key: all_EnableLoadTest
+ - name: DPConnectionString
+ key: webmvc__keystore
+ - name: PurchaseUrl
+ key: internalurls__apigwws
+ - name: ExternalPurchaseUrl
+ key: urls__apigwws
+ - name: CallBackUrl
+ key: urls__mvc
+ - name: IdentityUrl
+ key: urls__IdentityUrl
+ - name: MarketingUrl
+ key: internalurls__apigwwm
+ - name: IdentityUrlHC
+ key: internalurls__identity__hc
+ - name: SignalrHubUrl
+ key: urls__apigwws
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: IsClusterEnv
+ value: 'True'
+
diff --git a/deploy/k8s/archived/helm/webshoppingagg/.helmignore b/deploy/k8s/archived/helm/webshoppingagg/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/webshoppingagg/Chart.yaml b/deploy/k8s/archived/helm/webshoppingagg/Chart.yaml
new file mode 100644
index 000000000..cd7541025
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: webshoppingagg
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/webshoppingagg/templates/NOTES.txt b/deploy/k8s/archived/helm/webshoppingagg/templates/NOTES.txt
new file mode 100644
index 000000000..f55946f36
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/templates/NOTES.txt
@@ -0,0 +1,8 @@
+eShop Web Shopping Aggregator installed.
+----------------------------------------
+
+This API is not directly exposed outside cluster. If need to access it use:
+
+export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "webshoppingagg.name" . }},release={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
+echo "Visit http://127.0.0.1:8080 to use your application"
+kubectl port-forward $POD_NAME 8080:80
diff --git a/deploy/k8s/archived/helm/webshoppingagg/templates/_helpers.tpl b/deploy/k8s/archived/helm/webshoppingagg/templates/_helpers.tpl
new file mode 100644
index 000000000..f13dc791d
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "webshoppingagg.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 "webshoppingagg.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 "webshoppingagg.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/webshoppingagg/templates/_names.tpl b/deploy/k8s/archived/helm/webshoppingagg/templates/_names.tpl
new file mode 100644
index 000000000..d44859fea
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/templates/_names.tpl
@@ -0,0 +1,52 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webshoppingagg/templates/configmap.yaml b/deploy/k8s/archived/helm/webshoppingagg/templates/configmap.yaml
new file mode 100644
index 000000000..d01de8dcd
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/templates/configmap.yaml
@@ -0,0 +1,29 @@
+{{- $name := include "webshoppingagg.fullname" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "webshoppingagg.name" . }}
+ chart: {{ template "webshoppingagg.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all_EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ webshoppingagg__keystore: {{ .Values.inf.redis.keystore.constr }}
+ internalurls__basket: http://{{ .Values.app.svc.basket }}
+ internalurls__catalog: http://{{ .Values.app.svc.catalog }}
+ internalurls__identity: http://{{ .Values.app.svc.identity }}
+ internalurls__ordering: http://{{ .Values.app.svc.ordering }}
+ internalurls__basket__hc: http://{{ .Values.app.svc.basket }}/hc
+ internalurls__catalog__hc: http://{{ .Values.app.svc.catalog }}/hc
+ internalurls__identity__hc: http://{{ .Values.app.svc.identity }}/hc
+ internalurls__ordering__hc: http://{{ .Values.app.svc.ordering }}/hc
+ internalurls__marketing__hc: http://{{ .Values.app.svc.marketing }}/hc
+ internalurls__payment__hc: http://{{ .Values.app.svc.payment }}/hc
+ internalurls__location__hc: http://{{ .Values.app.svc.locations }}/hc
+ internalurls__grpcBasket: "http://{{ .Values.app.svc.basket }}:{{ .Values.service.grpcPort }}"
+ internalurls__grpcCatalog: "http://{{ .Values.app.svc.catalog }}:{{ .Values.service.grpcPort }}"
+ internalurls__grpcOrdering: "http://{{ .Values.app.svc.ordering }}:{{ .Values.service.grpcPort }}"
diff --git a/deploy/k8s/archived/helm/webshoppingagg/templates/deployment.yaml b/deploy/k8s/archived/helm/webshoppingagg/templates/deployment.yaml
new file mode 100644
index 000000000..ab5bfc0c9
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/templates/deployment.yaml
@@ -0,0 +1,95 @@
+{{- $name := include "webshoppingagg.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "webshoppingagg.fullname" . }}
+ labels:
+ app: {{ template "webshoppingagg.name" . }}
+ chart: {{ template "webshoppingagg.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "webshoppingagg.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "webshoppingagg.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ {{ if .Values.probes -}}
+ {{- if .Values.probes.liveness -}}
+ livenessProbe:
+ httpGet:
+ port: {{ .Values.probes.liveness.port }}
+ path: {{ .Values.probes.liveness.path }}
+ initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.liveness.periodSeconds }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.probes -}}
+ {{- if .Values.probes.readiness }}
+ readinessProbe:
+ httpGet:
+ port: {{ .Values.probes.readiness.port }}
+ path: {{ .Values.probes.readiness.path }}
+ initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
+ periodSeconds: {{ .Values.probes.readiness.periodSeconds }}
+ timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
+ {{- end -}}
+ {{- end }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/webshoppingagg/templates/service.yaml b/deploy/k8s/archived/helm/webshoppingagg/templates/service.yaml
new file mode 100644
index 000000000..8f0cb8bd5
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.webshoppingagg }}
+ labels:
+ app: {{ template "webshoppingagg.name" . }}
+ chart: {{ template "webshoppingagg.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "webshoppingagg.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/webshoppingagg/values.yaml b/deploy/k8s/archived/helm/webshoppingagg/values.yaml
new file mode 100644
index 000000000..15501c727
--- /dev/null
+++ b/deploy/k8s/archived/helm/webshoppingagg/values.yaml
@@ -0,0 +1,87 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /webshoppingagg
+
+image:
+ repository: eshop/webshoppingagg
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+ grpcPort: 81
+
+ingress:
+ enabled: false
+ annotations: {}
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: urls__basket
+ key: internalurls__basket
+ - name: urls__catalog
+ key: internalurls__catalog
+ - name: urls__orders
+ key: internalurls__ordering
+ - name: urls__identity
+ key: internalurls__identity
+ - name: CatalogUrlHC
+ key: internalurls__catalog__hc
+ - name: BasketUrlHC
+ key: internalurls__basket__hc
+ - name: IdentityUrlHC
+ key: internalurls__identity__hc
+ - name: OrderingUrlHC
+ key: internalurls__ordering__hc
+ - name: MarketingUrlHC
+ key: internalurls__marketing__hc
+ - name: PaymentUrlHC
+ key: internalurls__payment__hc
+ - name: LocationUrlHC
+ key: internalurls__location__hc
+ - name: urls__grpcBasket
+ key: internalurls__grpcBasket
+ - name: urls__grpcCatalog
+ key: internalurls__grpcCatalog
+ - name: urls__grpcOrdering
+ key: internalurls__grpcOrdering
+
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: ASPNETCORE_URLS
+ value: http://0.0.0.0:80
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: IsClusterEnv
+ value: 'True'
+probes:
+ liveness:
+ path: /liveness
+ initialDelaySeconds: 10
+ periodSeconds: 15
+ port: 80
+ readiness:
+ path: /hc
+ timeoutSeconds: 5
+ initialDelaySeconds: 90
+ periodSeconds: 60
+ port: 80
+
diff --git a/deploy/k8s/archived/helm/webspa/.helmignore b/deploy/k8s/archived/helm/webspa/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/webspa/Chart.yaml b/deploy/k8s/archived/helm/webspa/Chart.yaml
new file mode 100644
index 000000000..c16616489
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: webspa
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/webspa/templates/NOTES.txt b/deploy/k8s/archived/helm/webspa/templates/NOTES.txt
new file mode 100644
index 000000000..c8e1622db
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/templates/NOTES.txt
@@ -0,0 +1,2 @@
+eShop WebSPA installed
+----------------------
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webspa/templates/_helpers.tpl b/deploy/k8s/archived/helm/webspa/templates/_helpers.tpl
new file mode 100644
index 000000000..585f9f001
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "webspa.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 "webspa.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 "webspa.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/webspa/templates/_names.tpl b/deploy/k8s/archived/helm/webspa/templates/_names.tpl
new file mode 100644
index 000000000..605e92e7e
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/templates/_names.tpl
@@ -0,0 +1,60 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "protocol" -}}
+{{- if .Values.inf.tls.enabled -}}
+{{- printf "%s" "https" -}}
+{{- else -}}
+{{- printf "%s" "http" -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webspa/templates/configmap.yaml b/deploy/k8s/archived/helm/webspa/templates/configmap.yaml
new file mode 100644
index 000000000..ecdbf8b63
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/templates/configmap.yaml
@@ -0,0 +1,27 @@
+{{- $name := include "webspa.fullname" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+{{- $webshoppingapigw := include "url-of" (list .Values.app.ingress.entries.webshoppingapigw .) -}}
+{{- $webmarketingapigw := include "url-of" (list .Values.app.ingress.entries.webmarketingapigw .) -}}
+{{- $spa := include "url-of" (list .Values.app.ingress.entries.spa .) -}}
+{{- $mongo := include "mongo-name" . -}}
+{{- $protocol := include "protocol" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "webspa.name" . }}
+ chart: {{ template "webspa.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all_EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ webspa__keystore: {{ .Values.inf.redis.keystore.constr }}
+ internalurls__apigwws: http://{{ .Values.app.svc.webshoppingapigw }}
+ internalurls__identity__hc: http://{{ .Values.app.svc.identity }}/hc
+ urls__apigwws: {{ $protocol }}://{{ $webshoppingapigw }}
+ urls__spa: {{ $protocol }}://{{ $spa }}
+ urls__IdentityUrl: {{ $protocol }}://{{ $identity }}
+ urls__apigwwm: {{ $protocol }}://{{ $webmarketingapigw }}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webspa/templates/deployment.yaml b/deploy/k8s/archived/helm/webspa/templates/deployment.yaml
new file mode 100644
index 000000000..20dc696bf
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/templates/deployment.yaml
@@ -0,0 +1,75 @@
+{{- $name := include "webspa.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "webspa.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "webspa.name" . }}
+ chart: {{ template "webspa.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "webspa.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "webspa.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/webspa/templates/ingress.yaml b/deploy/k8s/archived/helm/webspa/templates/ingress.yaml
new file mode 100644
index 000000000..2b9fdd703
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/templates/ingress.yaml
@@ -0,0 +1,45 @@
+{{- if .Values.ingress.enabled -}}
+{{- $ingressPath := include "pathBase" . -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "webspa.fullname" . }}
+ labels:
+ app: {{ template "webspa.name" . }}
+ chart: {{ template "webspa.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $.Values.app.svc.spa }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/webspa/templates/service.yaml b/deploy/k8s/archived/helm/webspa/templates/service.yaml
new file mode 100644
index 000000000..2eab5d02e
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.spa }}
+ labels:
+ app: {{ template "webspa.name" . }}
+ chart: {{ template "webspa.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "webspa.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/webspa/values.yaml b/deploy/k8s/archived/helm/webspa/values.yaml
new file mode 100644
index 000000000..e1547ed39
--- /dev/null
+++ b/deploy/k8s/archived/helm/webspa/values.yaml
@@ -0,0 +1,61 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /
+
+image:
+ repository: eshop/webspa
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: true
+ annotations: {}
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: UseLoadTest
+ key: all_EnableLoadTest
+ - name: DPConnectionString
+ key: webspa__keystore
+ - name: PurchaseUrl
+ key: urls__apigwws
+ - name: CallBackUrl
+ key: urls__spa
+ - name: IdentityUrl
+ key: urls__IdentityUrl
+ - name: MarketingUrl
+ key: urls__apigwwm
+ - name: IdentityUrlHC
+ key: internalurls__identity__hc
+ - name: SignalrHubUrl
+ key: urls__apigwws
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: ASPNETCORE_URLS
+ value: http://0.0.0.0:80
+ - name: OrchestratorType
+ value: 'K8S'
+ - name: IsClusterEnv
+ value: 'True'
+
diff --git a/deploy/k8s/archived/helm/webstatus/.helmignore b/deploy/k8s/archived/helm/webstatus/.helmignore
new file mode 100644
index 000000000..f0c131944
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/.helmignore
@@ -0,0 +1,21 @@
+# Patterns to ignore when building packages.
+# This supports shell glob matching, relative path matching, and
+# negation (prefixed with !). Only one pattern per line.
+.DS_Store
+# Common VCS dirs
+.git/
+.gitignore
+.bzr/
+.bzrignore
+.hg/
+.hgignore
+.svn/
+# Common backup files
+*.swp
+*.bak
+*.tmp
+*~
+# Various IDEs
+.project
+.idea/
+*.tmproj
diff --git a/deploy/k8s/archived/helm/webstatus/Chart.yaml b/deploy/k8s/archived/helm/webstatus/Chart.yaml
new file mode 100644
index 000000000..9ee2783f4
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/Chart.yaml
@@ -0,0 +1,5 @@
+apiVersion: v1
+appVersion: "1.0"
+description: A Helm chart for Kubernetes
+name: webstatus
+version: 0.1.0
diff --git a/deploy/k8s/archived/helm/webstatus/templates/NOTES.txt b/deploy/k8s/archived/helm/webstatus/templates/NOTES.txt
new file mode 100644
index 000000000..5d9d4570d
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/templates/NOTES.txt
@@ -0,0 +1,2 @@
+eShop WebStatus installed.
+--------------------------
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webstatus/templates/_helpers.tpl b/deploy/k8s/archived/helm/webstatus/templates/_helpers.tpl
new file mode 100644
index 000000000..65b290af7
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/templates/_helpers.tpl
@@ -0,0 +1,32 @@
+{{/* vim: set filetype=mustache: */}}
+{{/*
+Expand the name of the chart.
+*/}}
+{{- define "webstatus.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 "webstatus.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 "webstatus.chart" -}}
+{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
+{{- end -}}
diff --git a/deploy/k8s/archived/helm/webstatus/templates/_names.tpl b/deploy/k8s/archived/helm/webstatus/templates/_names.tpl
new file mode 100644
index 000000000..49455d135
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/templates/_names.tpl
@@ -0,0 +1,50 @@
+{{- define "suffix-name" -}}
+{{- if .Values.app.name -}}
+{{- .Values.app.name -}}
+{{- else -}}
+{{- .Release.Name -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "sql-name" -}}
+{{- if .Values.inf.sql.host -}}
+{{- .Values.inf.sql.host -}}
+{{- else -}}
+{{- printf "%s" "sql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "mongo-name" -}}
+{{- if .Values.inf.mongo.host -}}
+{{- .Values.inf.mongo.host -}}
+{{- else -}}
+{{- printf "%s" "nosql-data" -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "url-of" -}}
+{{- $name := first .}}
+{{- $ctx := last .}}
+{{- if eq $name "" -}}
+{{- $ctx.Values.inf.k8s.dns -}}
+{{- else -}}
+{{- printf "%s/%s" $ctx.Values.inf.k8s.dns $name -}} {{/*Value is just / */}}
+{{- end -}}
+{{- end -}}
+
+{{- define "pathBase" -}}
+{{- if .Values.inf.k8s.suffix -}}
+{{- $suffix := include "suffix-name" . -}}
+{{- printf "%s-%s" .Values.pathBase $suffix -}}
+{{- else -}}
+{{- .Values.pathBase -}}
+{{- end -}}
+{{- end -}}
+
+{{- define "fqdn-image" -}}
+{{- if .Values.inf.registry -}}
+{{- printf "%s/%s" .Values.inf.registry.server .Values.image.repository -}}
+{{- else -}}
+{{- .Values.image.repository -}}
+{{- end -}}
+{{- end -}}
\ No newline at end of file
diff --git a/deploy/k8s/archived/helm/webstatus/templates/configmap.yaml b/deploy/k8s/archived/helm/webstatus/templates/configmap.yaml
new file mode 100644
index 000000000..bf40d2a7d
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/templates/configmap.yaml
@@ -0,0 +1,54 @@
+{{- $name := include "webstatus.fullname" . -}}
+{{- $identity := include "url-of" (list .Values.app.ingress.entries.identity .) -}}
+{{- $webshoppingapigw := include "url-of" (list .Values.app.ingress.entries.webshoppingapigw .) -}}
+{{- $mvc := include "url-of" (list .Values.app.ingress.entries.mvc .) -}}
+{{- $mongo := include "mongo-name" . -}}
+
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ name: "cfg-{{ $name }}"
+ labels:
+ app: {{ template "webstatus.name" . }}
+ chart: {{ template "webstatus.chart" .}}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+data:
+ all__InstrumentationKey: "{{ .Values.inf.appinsights.key }}"
+ all__UseAzureServiceBus: "{{ .Values.inf.eventbus.useAzure }}"
+ all_EnableLoadTest: "{{ .Values.inf.misc.useLoadTest }}"
+ webstatus__keystore: {{ .Values.inf.redis.keystore.constr }}
+ name__mvc__hc: WebMVC HTTP Check
+ internalurls__mvc__hc: http://{{ .Values.app.svc.mvc }}/hc
+ name__spa__hc: WebSPA HTTP Check
+ internalurls__spa__hc: http://{{ .Values.app.svc.spa }}/hc
+ name__apigwws__hc: Web Shopping API GW HTTP Check
+ internalurls__apigwws__hc: http://{{ .Values.app.svc.webshoppingapigw }}:8001/ready
+ name__apigwwm__hc: Web Marketing API GW HTTP Check
+ internalurls__apigwwm__hc: http://{{ .Values.app.svc.webmarketingapigw }}:8001/ready
+ name__apigwms__hc: Mobile Shopping API GW HTTP Check
+ internalurls__apigwms__hc: http://{{ .Values.app.svc.mobileshoppingapigw }}:8001/ready
+ name__apigwmm__hc: Mobile Marketing API GW HTTP Check
+ internalurls__apigwmm__hc: http://{{ .Values.app.svc.mobilemarketingapigw }}:8001/ready
+ name__apigwwsagg__hc: Web Shopping Aggregator GW HTTP Check
+ internalurls__apigwwsagg__hc: http://{{ .Values.app.svc.webshoppingagg }}/hc
+ name__apigwmsagg__hc: Mobile Shopping Aggregator HTTP Check
+ internalurls__apigwmsagg__hc: http://{{ .Values.app.svc.mobileshoppingagg }}/hc
+ name__ordering__hc: Ordering HTTP Check
+ internalurls__ordering__hc: http://{{ .Values.app.svc.ordering }}/hc
+ name__orderingbackground__hc: Ordering HTTP Background Check
+ internalurls__orderingbackground__hc: http://{{ .Values.app.svc.orderingbackgroundtasks }}/hc
+ name__basket__hc: Basket HTTP Check
+ internalurls__basket__hc: http://{{ .Values.app.svc.basket }}/hc
+ name__catalog__hc: Catalog HTTP Check
+ internalurls__catalog__hc: http://{{ .Values.app.svc.catalog }}/hc
+ name__identity__hc: Identity HTTP Check
+ internalurls__identity__hc: http://{{ .Values.app.svc.identity }}/hc
+ name__marketing__hc: Marketing HTTP Check
+ internalurls__marketing__hc: http://{{ .Values.app.svc.marketing }}/hc
+ name__locations__hc: Locations HTTP Check
+ internalurls__locations__hc: http://{{ .Values.app.svc.locations }}/hc
+ name__payment__hc: Payment HTTP Check
+ internalurls__payment__hc: http://{{ .Values.app.svc.payment }}/hc
+ name__signalrhub__hc: Ordering SignalR Hub HTTP Check
+ internalurls__signalrhub__hc: http://{{ .Values.app.svc.orderingsignalrhub }}/hc
diff --git a/deploy/k8s/archived/helm/webstatus/templates/deployment.yaml b/deploy/k8s/archived/helm/webstatus/templates/deployment.yaml
new file mode 100644
index 000000000..70b953577
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/templates/deployment.yaml
@@ -0,0 +1,75 @@
+{{- $name := include "webstatus.fullname" . -}}
+{{- $cfgname := printf "%s-%s" "cfg" $name -}}
+apiVersion: apps/v1beta2
+kind: Deployment
+metadata:
+ name: {{ template "webstatus.fullname" . }}
+ labels:
+ ufo: {{ $cfgname}}
+ app: {{ template "webstatus.name" . }}
+ chart: {{ template "webstatus.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ replicas: {{ .Values.replicaCount }}
+ selector:
+ matchLabels:
+ app: {{ template "webstatus.name" . }}
+ release: {{ .Release.Name }}
+ template:
+ metadata:
+ labels:
+ app: {{ template "webstatus.name" . }}
+ release: {{ .Release.Name }}
+ {{ if .Values.inf.mesh.enabled -}}
+ annotations:
+ linkerd.io/inject: enabled
+ {{- end }}
+ spec:
+ {{ if .Values.inf.registry -}}
+ imagePullSecrets:
+ - name: {{ .Values.inf.registry.secretName }}
+ {{- end }}
+ containers:
+ - name: {{ .Chart.Name }}
+ image: "{{ template "fqdn-image" . }}:{{ .Values.image.tag }}"
+ imagePullPolicy: {{ .Values.image.pullPolicy }}
+ env:
+ - name: PATH_BASE
+ value: {{ include "pathBase" . }}
+ - name: k8sname
+ value: {{ .Values.clusterName }}
+ {{- if .Values.env.values -}}
+ {{- range .Values.env.values }}
+ - name: {{ .name }}
+ value: {{ .value | quote }}
+ {{- end -}}
+ {{- end -}}
+ {{- if .Values.env.configmap -}}
+ {{- range .Values.env.configmap }}
+ - name: {{ .name }}
+ valueFrom:
+ configMapKeyRef:
+ name: {{ $cfgname }}
+ key: {{ .key }}
+ {{- end -}}
+ {{- end }}
+ ports:
+ - name: http
+ containerPort: 80
+ protocol: TCP
+ resources:
+{{ toYaml .Values.resources | indent 12 }}
+ {{- with .Values.nodeSelector }}
+ nodeSelector:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.affinity }}
+ affinity:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+ {{- with .Values.tolerations }}
+ tolerations:
+{{ toYaml . | indent 8 }}
+ {{- end }}
+
diff --git a/deploy/k8s/archived/helm/webstatus/templates/ingress.yaml b/deploy/k8s/archived/helm/webstatus/templates/ingress.yaml
new file mode 100644
index 000000000..9902b86b5
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/templates/ingress.yaml
@@ -0,0 +1,46 @@
+{{- if .Values.ingress.enabled -}}
+{{- $fullName := include "webstatus.fullname" . -}}
+{{- $ingressPath := include "pathBase" . -}}
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ name: {{ template "webstatus.fullname" . }}
+ labels:
+ app: {{ template "webstatus.name" . }}
+ chart: {{ template "webstatus.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+{{- with .Values.ingress.annotations }}
+ annotations:
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- if and .Values.inf.tls.enabled .Values.inf.tls.issuer }}
+ cert-manager.io/issuer: {{ .Values.inf.tls.issuer }}
+{{- end }}
+{{- if .Values.inf.mesh.enabled }}
+{{- with .Values.ingress.mesh.annotations }}
+{{ toYaml . | indent 4 }}
+{{- end }}
+{{- end }}
+spec:
+{{- if .Values.ingress.tls }}
+ tls:
+ {{- range .Values.ingress.tls }}
+ - hosts:
+ {{- range .hosts }}
+ - {{ . }}
+ {{- end }}
+ secretName: {{ .secretName }}
+ {{- end }}
+{{- end }}
+ rules:
+ {{- range .Values.ingress.hosts }}
+ - host: {{ . }}
+ http:
+ paths:
+ - path: {{ $ingressPath }}
+ backend:
+ serviceName: {{ $.Values.app.svc.status }}
+ servicePort: http
+ {{- end }}
+{{- end }}
diff --git a/deploy/k8s/archived/helm/webstatus/templates/service.yaml b/deploy/k8s/archived/helm/webstatus/templates/service.yaml
new file mode 100644
index 000000000..37fff50c6
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/templates/service.yaml
@@ -0,0 +1,19 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: {{ .Values.app.svc.status }}
+ labels:
+ app: {{ template "webstatus.name" . }}
+ chart: {{ template "webstatus.chart" . }}
+ release: {{ .Release.Name }}
+ heritage: {{ .Release.Service }}
+spec:
+ type: {{ .Values.service.type }}
+ ports:
+ - port: {{ .Values.service.port }}
+ targetPort: http
+ protocol: TCP
+ name: http
+ selector:
+ app: {{ template "webstatus.name" . }}
+ release: {{ .Release.Name }}
diff --git a/deploy/k8s/archived/helm/webstatus/values.yaml b/deploy/k8s/archived/helm/webstatus/values.yaml
new file mode 100644
index 000000000..e5a23ec85
--- /dev/null
+++ b/deploy/k8s/archived/helm/webstatus/values.yaml
@@ -0,0 +1,95 @@
+replicaCount: 1
+clusterName: eshop-aks
+pathBase: /webstatus
+
+image:
+ repository: eshop/webstatus
+ tag: latest
+ pullPolicy: IfNotPresent
+
+service:
+ type: ClusterIP
+ port: 80
+
+ingress:
+ enabled: true
+ annotations: {
+
+ }
+ tls: []
+
+resources: {}
+
+
+nodeSelector: {}
+
+tolerations: []
+
+affinity: {}
+
+# env defines the environment variables that will be declared in the pod
+env:
+ urls:
+ # configmap declares variables which value is taken from the config map defined in template configmap.yaml (name is name of var and key the key in configmap).
+ configmap:
+ - name: ApplicationInsights__InstrumentationKey
+ key: all__InstrumentationKey
+ - name: HealthChecks-UI__HealthChecks__0__Name
+ key: name__mvc__hc
+ - name: HealthChecks-UI__HealthChecks__0__Uri
+ key: internalurls__mvc__hc
+ - name: HealthChecks-UI__HealthChecks__1__Name
+ key: name__spa__hc
+ - name: HealthChecks-UI__HealthChecks__1__Uri
+ key: internalurls__spa__hc
+ - name: HealthChecks-UI__HealthChecks__2__Name
+ key: name__apigwwsagg__hc
+ - name: HealthChecks-UI__HealthChecks__2__Uri
+ key: internalurls__apigwwsagg__hc
+ - name: HealthChecks-UI__HealthChecks__3__Name
+ key: name__apigwmsagg__hc
+ - name: HealthChecks-UI__HealthChecks__3__Uri
+ key: internalurls__apigwmsagg__hc
+ - name: HealthChecks-UI__HealthChecks__4__Name
+ key: name__ordering__hc
+ - name: HealthChecks-UI__HealthChecks__4__Uri
+ key: internalurls__ordering__hc
+ - name: HealthChecks-UI__HealthChecks__5__Name
+ key: name__basket__hc
+ - name: HealthChecks-UI__HealthChecks__5__Uri
+ key: internalurls__basket__hc
+ - name: HealthChecks-UI__HealthChecks__6__Name
+ key: name__catalog__hc
+ - name: HealthChecks-UI__HealthChecks__6__Uri
+ key: internalurls__catalog__hc
+ - name: HealthChecks-UI__HealthChecks__7__Name
+ key: name__identity__hc
+ - name: HealthChecks-UI__HealthChecks__7__Uri
+ key: internalurls__identity__hc
+ - name: HealthChecks-UI__HealthChecks__8__Name
+ key: name__marketing__hc
+ - name: HealthChecks-UI__HealthChecks__8__Uri
+ key: internalurls__marketing__hc
+ - name: HealthChecks-UI__HealthChecks__9__Name
+ key: name__locations__hc
+ - name: HealthChecks-UI__HealthChecks__9__Uri
+ key: internalurls__locations__hc
+ - name: HealthChecks-UI__HealthChecks__10__Name
+ key: name__payment__hc
+ - name: HealthChecks-UI__HealthChecks__10__Uri
+ key: internalurls__payment__hc
+ - name: HealthChecks-UI__HealthChecks__11__Name
+ key: name__signalrhub__hc
+ - name: HealthChecks-UI__HealthChecks__11__Uri
+ key: internalurls__signalrhub__hc
+ - name: HealthChecks-UI__HealthChecks__12__Name
+ key: name__orderingbackground__hc
+ - name: HealthChecks-UI__HealthChecks__12__Uri
+ key: internalurls__orderingbackground__hc
+
+ # values define environment variables with a fixed value (no configmap involved) (name is name of var, and value is its value)
+ values:
+ - name: ASPNETCORE_ENVIRONMENT
+ value: Development
+ - name: OrchestratorType
+ value: 'K8S'
diff --git a/deploy/k8s/archived/linkerd/basket-api-sp.yaml b/deploy/k8s/archived/linkerd/basket-api-sp.yaml
new file mode 100644
index 000000000..6b23bdb9f
--- /dev/null
+++ b/deploy/k8s/archived/linkerd/basket-api-sp.yaml
@@ -0,0 +1,42 @@
+apiVersion: linkerd.io/v1alpha2
+kind: ServiceProfile
+metadata:
+ creationTimestamp: null
+ name: basket-api.default.svc.cluster.local
+ namespace: default
+spec:
+ routes:
+ - condition:
+ method: GET
+ pathRegex: /basket-api/api/v1/basket/[^/]*
+ name: GET Basket {id}
+ isRetryable: true
+ - condition:
+ method: GET
+ pathRegex: /hc
+ name: GET /hc
+ isRetryable: false
+ - condition:
+ method: GET
+ pathRegex: /liveness
+ name: GET /liveness
+ isRetryable: false
+ - condition:
+ method: POST
+ pathRegex: /BasketApi\.Basket/GetBasketById
+ name: POST /BasketApi.Basket/GetBasketById
+ isRetryable: true
+ - condition:
+ method: POST
+ pathRegex: /BasketApi\.Basket/UpdateBasket
+ name: POST /BasketApi.Basket/UpdateBasket
+ isRetryable: true
+ - condition:
+ method: POST
+ pathRegex: /basket-api/api/v1/basket/checkout
+ name: POST /v1/basket/checkout
+ isRetryable: true
+ retryBudget:
+ retryRatio: 0.2
+ minRetriesPerSecond: 10
+ ttl: 10s
\ No newline at end of file
diff --git a/deploy/k8s/archived/linkerd/catalog-api-sp.yaml b/deploy/k8s/archived/linkerd/catalog-api-sp.yaml
new file mode 100644
index 000000000..6e9afa472
--- /dev/null
+++ b/deploy/k8s/archived/linkerd/catalog-api-sp.yaml
@@ -0,0 +1,47 @@
+apiVersion: linkerd.io/v1alpha2
+kind: ServiceProfile
+metadata:
+ creationTimestamp: null
+ name: catalog-api.default.svc.cluster.local
+ namespace: default
+spec:
+ routes:
+ - condition:
+ method: GET
+ pathRegex: /catalog-api/api/v1/catalog/catalogbrands
+ name: GET /v1/catalog/catalogbrands
+ isRetryable: true
+ - condition:
+ method: GET
+ pathRegex: /catalog-api/api/v1/catalog/catalogtypes
+ name: GET /v1/catalog/catalogtypes
+ isRetryable: true
+ - condition:
+ method: GET
+ pathRegex: /catalog-api/api/v1/catalog/items
+ name: GET /v1/catalog/items
+ isRetryable: true
+ - condition:
+ method: GET
+ pathRegex: /api/v1/catalog/items/[^/]*/pic/
+ name: GET /v1/catalog/items/{id}/pic/
+ isRetryable: false
+ - condition:
+ method: GET
+ pathRegex: /hc
+ name: GET /hc
+ isRetryable: false
+ - condition:
+ method: GET
+ pathRegex: /liveness
+ isRetryable: false
+ name: GET /liveness
+ - condition:
+ method: POST
+ pathRegex: /CatalogApi\.Catalog/GetItemsByIds
+ name: POST /CatalogApi.Catalog/GetItemsByIds
+ isRetryable: true
+ retryBudget:
+ retryRatio: 0.2
+ minRetriesPerSecond: 10
+ ttl: 10s
\ No newline at end of file
diff --git a/deploy/k8s/archived/nginx-ingress/local-cm.yaml b/deploy/k8s/archived/nginx-ingress/local-cm.yaml
new file mode 100644
index 000000000..02906afc1
--- /dev/null
+++ b/deploy/k8s/archived/nginx-ingress/local-cm.yaml
@@ -0,0 +1,11 @@
+apiVersion: v1
+kind: ConfigMap
+metadata:
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+ name: nginx-configuration
+ namespace: ingress-nginx
+data:
+ proxy-buffer-size: "128k"
+ proxy-buffers: "4 256k"
\ No newline at end of file
diff --git a/deploy/k8s/archived/nginx-ingress/local-dockerk8s/identityapi-cm-fix.yaml b/deploy/k8s/archived/nginx-ingress/local-dockerk8s/identityapi-cm-fix.yaml
new file mode 100644
index 000000000..3a3fcf5a5
--- /dev/null
+++ b/deploy/k8s/archived/nginx-ingress/local-dockerk8s/identityapi-cm-fix.yaml
@@ -0,0 +1,3 @@
+data:
+ mvc_e: http://10.0.75.1/webmvc
+
\ No newline at end of file
diff --git a/deploy/k8s/archived/nginx-ingress/local-dockerk8s/mvc-cm-fix.yaml b/deploy/k8s/archived/nginx-ingress/local-dockerk8s/mvc-cm-fix.yaml
new file mode 100644
index 000000000..1475deec1
--- /dev/null
+++ b/deploy/k8s/archived/nginx-ingress/local-dockerk8s/mvc-cm-fix.yaml
@@ -0,0 +1,3 @@
+data:
+ urls__IdentityUrl: http://10.0.75.1/identity
+ urls__mvc: http://10.0.75.1/webmvc
diff --git a/deploy/k8s/archived/nginx-ingress/local-dockerk8s/mvc-fix.yaml b/deploy/k8s/archived/nginx-ingress/local-dockerk8s/mvc-fix.yaml
new file mode 100644
index 000000000..b9ecd4cba
--- /dev/null
+++ b/deploy/k8s/archived/nginx-ingress/local-dockerk8s/mvc-fix.yaml
@@ -0,0 +1,39 @@
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ annotations:
+ ingress.kubernetes.io/ssl-redirect: "false"
+ kubernetes.io/ingress.class: nginx
+ nginx.ingress.kubernetes.io/ssl-redirect: "false"
+ labels:
+ app: webmvc
+ name: eshop-webmvc-loopback
+ namespace: default
+spec:
+ rules:
+ - http:
+ paths:
+ - backend:
+ serviceName: webmvc
+ servicePort: http
+ path: /webmvc
+---
+apiVersion: extensions/v1beta1
+kind: Ingress
+metadata:
+ annotations:
+ ingress.kubernetes.io/ssl-redirect: "false"
+ kubernetes.io/ingress.class: nginx
+ nginx.ingress.kubernetes.io/ssl-redirect: "false"
+ labels:
+ app: identity-api
+ name: eshop-identity-api-loopback
+ namespace: default
+spec:
+ rules:
+ - http:
+ paths:
+ - backend:
+ serviceName: identity
+ servicePort: http
+ path: /identity
\ No newline at end of file
diff --git a/deploy/k8s/archived/nginx-ingress/local-svc.yaml b/deploy/k8s/archived/nginx-ingress/local-svc.yaml
new file mode 100644
index 000000000..945441ab8
--- /dev/null
+++ b/deploy/k8s/archived/nginx-ingress/local-svc.yaml
@@ -0,0 +1,21 @@
+kind: Service
+apiVersion: v1
+metadata:
+ name: ingress-nginx
+ namespace: ingress-nginx
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+spec:
+ externalTrafficPolicy: Local
+ type: LoadBalancer
+ selector:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+ ports:
+ - name: http
+ port: 80
+ targetPort: http
+ - name: https
+ port: 443
+ targetPort: https
\ No newline at end of file
diff --git a/deploy/k8s/archived/nginx-ingress/mandatory.yaml b/deploy/k8s/archived/nginx-ingress/mandatory.yaml
new file mode 100644
index 000000000..56b1cc3b5
--- /dev/null
+++ b/deploy/k8s/archived/nginx-ingress/mandatory.yaml
@@ -0,0 +1,238 @@
+apiVersion: v1
+kind: Namespace
+metadata:
+ name: ingress-nginx
+
+---
+
+kind: ConfigMap
+apiVersion: v1
+metadata:
+ name: nginx-configuration
+ namespace: ingress-nginx
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+
+---
+
+apiVersion: v1
+kind: ServiceAccount
+metadata:
+ name: nginx-ingress-serviceaccount
+ namespace: ingress-nginx
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+
+---
+apiVersion: rbac.authorization.k8s.io/v1beta1
+kind: ClusterRole
+metadata:
+ name: nginx-ingress-clusterrole
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+rules:
+ - apiGroups:
+ - ""
+ resources:
+ - configmaps
+ - endpoints
+ - nodes
+ - pods
+ - secrets
+ verbs:
+ - list
+ - watch
+ - apiGroups:
+ - ""
+ resources:
+ - nodes
+ verbs:
+ - get
+ - apiGroups:
+ - ""
+ resources:
+ - services
+ verbs:
+ - get
+ - list
+ - watch
+ - apiGroups:
+ - "extensions"
+ resources:
+ - ingresses
+ verbs:
+ - get
+ - list
+ - watch
+ - apiGroups:
+ - ""
+ resources:
+ - events
+ verbs:
+ - create
+ - patch
+ - apiGroups:
+ - "extensions"
+ resources:
+ - ingresses/status
+ verbs:
+ - update
+
+---
+apiVersion: rbac.authorization.k8s.io/v1beta1
+kind: Role
+metadata:
+ name: nginx-ingress-role
+ namespace: ingress-nginx
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+rules:
+ - apiGroups:
+ - ""
+ resources:
+ - configmaps
+ - pods
+ - secrets
+ - namespaces
+ verbs:
+ - get
+ - apiGroups:
+ - ""
+ resources:
+ - configmaps
+ resourceNames:
+ # Defaults to "-"
+ # Here: "-"
+ # This has to be adapted if you change either parameter
+ # when launching the nginx-ingress-controller.
+ - "ingress-controller-leader-nginx"
+ verbs:
+ - get
+ - update
+ - apiGroups:
+ - ""
+ resources:
+ - configmaps
+ verbs:
+ - create
+ - apiGroups:
+ - ""
+ resources:
+ - endpoints
+ verbs:
+ - get
+
+---
+apiVersion: rbac.authorization.k8s.io/v1beta1
+kind: RoleBinding
+metadata:
+ name: nginx-ingress-role-nisa-binding
+ namespace: ingress-nginx
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+roleRef:
+ apiGroup: rbac.authorization.k8s.io
+ kind: Role
+ name: nginx-ingress-role
+subjects:
+ - kind: ServiceAccount
+ name: nginx-ingress-serviceaccount
+ namespace: ingress-nginx
+
+---
+apiVersion: rbac.authorization.k8s.io/v1beta1
+kind: ClusterRoleBinding
+metadata:
+ name: nginx-ingress-clusterrole-nisa-binding
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+roleRef:
+ apiGroup: rbac.authorization.k8s.io
+ kind: ClusterRole
+ name: nginx-ingress-clusterrole
+subjects:
+ - kind: ServiceAccount
+ name: nginx-ingress-serviceaccount
+ namespace: ingress-nginx
+
+---
+
+apiVersion: extensions/v1beta1
+kind: Deployment
+metadata:
+ name: nginx-ingress-controller
+ namespace: ingress-nginx
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+spec:
+ replicas: 1
+ selector:
+ matchLabels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+ template:
+ metadata:
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+ annotations:
+ prometheus.io/port: "10254"
+ prometheus.io/scrape: "true"
+ spec:
+ serviceAccountName: nginx-ingress-serviceaccount
+ containers:
+ - name: nginx-ingress-controller
+ image: quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.20.0
+ args:
+ - /nginx-ingress-controller
+ - --configmap=$(POD_NAMESPACE)/nginx-configuration
+ - --publish-service=$(POD_NAMESPACE)/ingress-nginx
+ - --annotations-prefix=nginx.ingress.kubernetes.io
+ securityContext:
+ capabilities:
+ drop:
+ - ALL
+ add:
+ - NET_BIND_SERVICE
+ # www-data -> 33
+ runAsUser: 33
+ env:
+ - name: POD_NAME
+ valueFrom:
+ fieldRef:
+ fieldPath: metadata.name
+ - name: POD_NAMESPACE
+ valueFrom:
+ fieldRef:
+ fieldPath: metadata.namespace
+ ports:
+ - name: http
+ containerPort: 80
+ - name: https
+ containerPort: 443
+ livenessProbe:
+ failureThreshold: 3
+ httpGet:
+ path: /healthz
+ port: 10254
+ scheme: HTTP
+ initialDelaySeconds: 10
+ periodSeconds: 10
+ successThreshold: 1
+ timeoutSeconds: 1
+ readinessProbe:
+ failureThreshold: 3
+ httpGet:
+ path: /healthz
+ port: 10254
+ scheme: HTTP
+ periodSeconds: 10
+ successThreshold: 1
+ timeoutSeconds: 1
diff --git a/deploy/k8s/archived/nginx-ingress/service-nodeport.yaml b/deploy/k8s/archived/nginx-ingress/service-nodeport.yaml
new file mode 100644
index 000000000..dd82ed3ed
--- /dev/null
+++ b/deploy/k8s/archived/nginx-ingress/service-nodeport.yaml
@@ -0,0 +1,22 @@
+apiVersion: v1
+kind: Service
+metadata:
+ name: ingress-nginx
+ namespace: ingress-nginx
+ labels:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
+spec:
+ type: NodePort
+ ports:
+ - name: http
+ port: 80
+ targetPort: 80
+ protocol: TCP
+ - name: https
+ port: 443
+ targetPort: 443
+ protocol: TCP
+ selector:
+ app.kubernetes.io/name: ingress-nginx
+ app.kubernetes.io/part-of: ingress-nginx
diff --git a/deploy/k8s/archived/nodeports/rabbitmq-admin.yaml b/deploy/k8s/archived/nodeports/rabbitmq-admin.yaml
new file mode 100644
index 000000000..30d2facf1
--- /dev/null
+++ b/deploy/k8s/archived/nodeports/rabbitmq-admin.yaml
@@ -0,0 +1,12 @@
+kind: Service
+apiVersion: v1
+metadata:
+ name: rabbitmq-admin
+spec:
+ type: NodePort
+ selector:
+ app: rabbitmq
+ ports:
+ - port: 15672
+ nodePort: 31672
+ name: rabbitmq-port
diff --git a/deploy/k8s/archived/nodeports/sql-service.yaml b/deploy/k8s/archived/nodeports/sql-service.yaml
new file mode 100644
index 000000000..7b0233b68
--- /dev/null
+++ b/deploy/k8s/archived/nodeports/sql-service.yaml
@@ -0,0 +1,12 @@
+kind: Service
+apiVersion: v1
+metadata:
+ name: sql-service
+spec:
+ type: NodePort
+ selector:
+ app: sql-data
+ ports:
+ - port: 1433
+ nodePort: 31433
+ name: sql-port
diff --git a/deploy/k8s/helm/apigwmm/templates/deployment.yaml b/deploy/k8s/helm/apigwmm/templates/deployment.yaml
index f93706bb9..70b4ffa8f 100644
--- a/deploy/k8s/helm/apigwmm/templates/deployment.yaml
+++ b/deploy/k8s/helm/apigwmm/templates/deployment.yaml
@@ -1,7 +1,7 @@
{{- $name := include "apigwmm.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "apigwmm.fullname" . }}
diff --git a/deploy/k8s/helm/apigwms/templates/deployment.yaml b/deploy/k8s/helm/apigwms/templates/deployment.yaml
index 2c5703103..c62751f1c 100644
--- a/deploy/k8s/helm/apigwms/templates/deployment.yaml
+++ b/deploy/k8s/helm/apigwms/templates/deployment.yaml
@@ -1,7 +1,7 @@
{{- $name := include "apigwms.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "apigwms.fullname" . }}
diff --git a/deploy/k8s/helm/apigwwm/templates/deployment.yaml b/deploy/k8s/helm/apigwwm/templates/deployment.yaml
index 6ceb1fa1b..8c8619f8a 100644
--- a/deploy/k8s/helm/apigwwm/templates/deployment.yaml
+++ b/deploy/k8s/helm/apigwwm/templates/deployment.yaml
@@ -1,7 +1,7 @@
{{- $name := include "apigwwm.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "apigwwm.fullname" . }}
diff --git a/deploy/k8s/helm/apigwws/templates/deployment.yaml b/deploy/k8s/helm/apigwws/templates/deployment.yaml
index 3aedde6dd..bbe7fedf8 100644
--- a/deploy/k8s/helm/apigwws/templates/deployment.yaml
+++ b/deploy/k8s/helm/apigwws/templates/deployment.yaml
@@ -1,7 +1,7 @@
{{- $name := include "apigwws.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
{{- $envoycfgname := printf "%s-%s" "envoy" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "apigwws.fullname" . }}
diff --git a/deploy/k8s/helm/basket-api/templates/deployment.yaml b/deploy/k8s/helm/basket-api/templates/deployment.yaml
index dc90666f5..b9fd26204 100644
--- a/deploy/k8s/helm/basket-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/basket-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "basket-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "basket-api.fullname" . }}
diff --git a/deploy/k8s/helm/basket-data/templates/deployment.yaml b/deploy/k8s/helm/basket-data/templates/deployment.yaml
index 8ccceceeb..00f3a8cd0 100644
--- a/deploy/k8s/helm/basket-data/templates/deployment.yaml
+++ b/deploy/k8s/helm/basket-data/templates/deployment.yaml
@@ -1,4 +1,4 @@
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "basket-data.fullname" . }}
diff --git a/deploy/k8s/helm/catalog-api/templates/deployment.yaml b/deploy/k8s/helm/catalog-api/templates/deployment.yaml
index 33a0ad5b4..266d89407 100644
--- a/deploy/k8s/helm/catalog-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/catalog-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "catalog-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "catalog-api.fullname" . }}
diff --git a/deploy/k8s/helm/deploy-all-mac.ps1 b/deploy/k8s/helm/deploy-all-mac.ps1
new file mode 100644
index 000000000..c74b7e05e
--- /dev/null
+++ b/deploy/k8s/helm/deploy-all-mac.ps1
@@ -0,0 +1,156 @@
+Param(
+ [parameter(Mandatory=$false)][string]$registry,
+ [parameter(Mandatory=$false)][string]$dockerUser,
+ [parameter(Mandatory=$false)][string]$dockerPassword,
+ [parameter(Mandatory=$false)][string]$externalDns,
+ [parameter(Mandatory=$false)][string]$appName="eshop",
+ [parameter(Mandatory=$false)][bool]$deployInfrastructure=$true,
+ [parameter(Mandatory=$false)][bool]$deployCharts=$true,
+ [parameter(Mandatory=$false)][bool]$clean=$true,
+ [parameter(Mandatory=$false)][string]$aksName="",
+ [parameter(Mandatory=$false)][string]$aksRg="",
+ [parameter(Mandatory=$false)][string]$imageTag="latest",
+ [parameter(Mandatory=$false)][bool]$useLocalk8s=$false,
+ [parameter(Mandatory=$false)][bool]$useMesh=$false,
+ [parameter(Mandatory=$false)][string][ValidateSet('Always','IfNotPresent','Never', IgnoreCase=$false)]$imagePullPolicy="Always",
+ [parameter(Mandatory=$false)][string][ValidateSet('prod','staging','none','custom', IgnoreCase=$false)]$sslSupport = "none",
+ [parameter(Mandatory=$false)][string]$tlsSecretName = "eshop-tls-custom",
+ [parameter(Mandatory=$false)][string]$chartsToDeploy="*",
+ [parameter(Mandatory=$false)][string]$ingressMeshAnnotationsFile="ingress_values_linkerd.yaml"
+ )
+
+function Install-Chart {
+ Param([string]$chart,[string]$initialOptions, [bool]$customRegistry)
+ $options=$initialOptions
+ if ($sslEnabled) {
+ $options = "$options --set ingress.tls[0].secretName=$tlsSecretName --set ingress.tls[0].hosts=`{$dns`}"
+ if ($sslSupport -ne "custom") {
+ $options = "$options --set inf.tls.issuer=$sslIssuer"
+ }
+ }
+ if ($customRegistry) {
+ $options = "$options --set inf.registry.server=$registry --set inf.registry.login=$dockerUser --set inf.registry.pwd=$dockerPassword --set inf.registry.secretName=eshop-docker-scret"
+ }
+
+ if ($chart -ne "eshop-common" -or $customRegistry) { # eshop-common is ignored when no secret must be deployed
+
+ $command = "helm install $appName-$chart $options $chart"
+ Write-Host "Helm Command: $command" -ForegroundColor Gray
+ Invoke-Expression $command
+ }
+}
+
+$dns = $externalDns
+$sslEnabled=$false
+$sslIssuer=""
+
+if ($sslSupport -eq "staging") {
+ $sslEnabled=$true
+ $tlsSecretName="eshop-letsencrypt-staging"
+ $sslIssuer="letsencrypt-staging"
+}
+elseif ($sslSupport -eq "prod") {
+ $sslEnabled=$true
+ $tlsSecretName="eshop-letsencrypt-prod"
+ $sslIssuer="letsencrypt-prod"
+}
+elseif ($sslSupport -eq "custom") {
+ $sslEnabled=$true
+}
+
+$ingressValuesFile="ingress_values.yaml"
+
+if ($useLocalk8s -eq $true) {
+ $ingressValuesFile="ingress_values_dockerk8s.yaml"
+ $dns="localhost"
+}
+
+if ($externalDns -eq "aks") {
+ if ([string]::IsNullOrEmpty($aksName) -or [string]::IsNullOrEmpty($aksRg)) {
+ Write-Host "Error: When using -dns aks, MUST set -aksName and -aksRg too." -ForegroundColor Red
+ exit 1
+ }
+ Write-Host "Getting DNS of AKS of AKS $aksName (in resource group $aksRg)..." -ForegroundColor Green
+ $dns = $(az aks show -n $aksName -g $aksRg --query addonProfiles.httpApplicationRouting.config.HTTPApplicationRoutingZoneName)
+ if ([string]::IsNullOrEmpty($dns)) {
+ Write-Host "Error getting DNS of AKS $aksName (in resource group $aksRg). Please ensure AKS has httpRouting enabled AND Azure CLI is logged & in version 2.0.37 or higher" -ForegroundColor Red
+ exit 1
+ }
+ $dns = $dns -replace '[\"]'
+ Write-Host "DNS base found is $dns. Will use $appName.$dns for the app!" -ForegroundColor Green
+ $dns = "$appName.$dns"
+}
+
+# Initialization & check commands
+if ([string]::IsNullOrEmpty($dns)) {
+ Write-Host "No DNS specified. Ingress resources will be bound to public ip" -ForegroundColor Yellow
+ if ($sslEnabled) {
+ Write-Host "Can't bound SSL to public IP. DNS is mandatory when using TLS" -ForegroundColor Red
+ exit 1
+ }
+}
+
+if ($useLocalk8s -and $sslEnabled) {
+ Write-Host "SSL can'be enabled on local K8s." -ForegroundColor Red
+ exit 1
+}
+
+if ($clean) {
+ $listOfReleases=$(helm ls --filter eshop -q)
+ if ([string]::IsNullOrEmpty($listOfReleases)) {
+ Write-Host "No previous releases found!" -ForegroundColor Green
+ }else{
+ Write-Host "Previous releases found" -ForegroundColor Green
+ Write-Host "Cleaning previous helm releases..." -ForegroundColor Green
+ helm uninstall $listOfReleases
+ Write-Host "Previous releases deleted" -ForegroundColor Green
+ }
+}
+
+$useCustomRegistry=$false
+
+if (-not [string]::IsNullOrEmpty($registry)) {
+ $useCustomRegistry=$true
+ if ([string]::IsNullOrEmpty($dockerUser) -or [string]::IsNullOrEmpty($dockerPassword)) {
+ Write-Host "Error: Must use -dockerUser AND -dockerPassword if specifying custom registry" -ForegroundColor Red
+ exit 1
+ }
+}
+
+Write-Host "Begin eShopOnContainers installation using Helm" -ForegroundColor Green
+
+$infras = ("sql-data", "nosql-data", "rabbitmq", "keystore-data", "basket-data")
+$charts = ("eshop-common", "basket-api","catalog-api", "identity-api", "locations-api", "marketing-api", "mobileshoppingagg","ordering-api","ordering-backgroundtasks","ordering-signalrhub", "payment-api", "webmvc", "webshoppingagg", "webspa", "webstatus", "webhooks-api", "webhooks-web")
+$gateways = ("apigwmm", "apigwms", "apigwwm", "apigwws")
+
+if ($deployInfrastructure) {
+ foreach ($infra in $infras) {
+ Write-Host "Installing infrastructure: $infra" -ForegroundColor Green
+ helm install "$appName-$infra" --values app.yaml --values inf.yaml --values $ingressValuesFile --set app.name=$appName --set inf.k8s.dns=$dns --set "ingress.hosts={$dns}" $infra
+ }
+}
+else {
+ Write-Host "eShopOnContainers infrastructure (bbdd, redis, ...) charts aren't installed (-deployCharts is false)" -ForegroundColor Yellow
+}
+
+if ($deployCharts) {
+ foreach ($chart in $charts) {
+ if ($chartsToDeploy -eq "*" -or $chartsToDeploy.Contains($chart)) {
+ Write-Host "Installing: $chart" -ForegroundColor Green
+ Install-Chart $chart "--values app.yaml --values inf.yaml --values $ingressValuesFile --values $ingressMeshAnnotationsFile --set app.name=$appName --set inf.k8s.dns=$dns --set ingress.hosts=``{$dns``} --set image.tag=$imageTag --set image.pullPolicy=$imagePullPolicy --set inf.tls.enabled=$sslEnabled --set inf.mesh.enabled=$useMesh --set inf.k8s.local=$useLocalk8s" $useCustomRegistry
+ }
+ }
+
+ foreach ($chart in $gateways) {
+ if ($chartsToDeploy -eq "*" -or $chartsToDeploy.Contains($chart)) {
+ Write-Host "Installing Api Gateway Chart: $chart" -ForegroundColor Green
+ Install-Chart $chart "--values app.yaml --values inf.yaml --values $ingressValuesFile --set app.name=$appName --set inf.k8s.dns=$dns --set image.pullPolicy=$imagePullPolicy --set inf.mesh.enabled=$useMesh --set ingress.hosts=``{$dns``} --set inf.tls.enabled=$sslEnabled" $false
+
+ }
+ }
+}
+else {
+ Write-Host "eShopOnContainers non-infrastructure charts aren't installed (-deployCharts is false)" -ForegroundColor Yellow
+}
+
+Write-Host "helm charts installed." -ForegroundColor Green
diff --git a/deploy/k8s/helm/deploy-all.ps1 b/deploy/k8s/helm/deploy-all.ps1
index 1711c0c2c..da0424195 100644
--- a/deploy/k8s/helm/deploy-all.ps1
+++ b/deploy/k8s/helm/deploy-all.ps1
@@ -33,7 +33,7 @@ function Install-Chart {
}
if ($chart -ne "eshop-common" -or $customRegistry) { # eshop-common is ignored when no secret must be deployed
- $command = "install $options --name=$appName-$chart $chart"
+ $command = "install $appName-$chart $options $chart"
Write-Host "Helm Command: helm $command" -ForegroundColor Gray
Invoke-Expression 'cmd /c "helm $command"'
}
@@ -94,10 +94,16 @@ if ($useLocalk8s -and $sslEnabled) {
exit 1
}
-if ($clean) {
- Write-Host "Cleaning previous helm releases..." -ForegroundColor Green
- helm delete --purge $(helm ls -q eshop)
- Write-Host "Previous releases deleted" -ForegroundColor Green
+if ($clean) {
+ $listOfReleases=$(helm ls --filter eshop -q)
+ if ([string]::IsNullOrEmpty($listOfReleases)) {
+ Write-Host "No previous releases found!" -ForegroundColor Green
+ }else{
+ Write-Host "Previous releases found" -ForegroundColor Green
+ Write-Host "Cleaning previous helm releases..." -ForegroundColor Green
+ helm uninstall $listOfReleases
+ Write-Host "Previous releases deleted" -ForegroundColor Green
+ }
}
$useCustomRegistry=$false
@@ -119,7 +125,7 @@ $gateways = ("apigwmm", "apigwms", "apigwwm", "apigwws")
if ($deployInfrastructure) {
foreach ($infra in $infras) {
Write-Host "Installing infrastructure: $infra" -ForegroundColor Green
- helm install --values app.yaml --values inf.yaml --values $ingressValuesFile --set app.name=$appName --set inf.k8s.dns=$dns --set "ingress.hosts={$dns}" --name="$appName-$infra" $infra
+ helm install "$appName-$infra" --values app.yaml --values inf.yaml --values $ingressValuesFile --set app.name=$appName --set inf.k8s.dns=$dns --set "ingress.hosts={$dns}" $infra
}
}
else {
diff --git a/deploy/k8s/helm/deploy-all.sh b/deploy/k8s/helm/deploy-all.sh
index 6f6d868aa..bf07105ef 100644
--- a/deploy/k8s/helm/deploy-all.sh
+++ b/deploy/k8s/helm/deploy-all.sh
@@ -201,7 +201,7 @@ if [[ $clean ]]; then
if [[ -z $(helm ls -q --namespace $namespace) ]]; then
echo "No previous releases found"
else
- helm delete --purge $(helm ls -q --namespace $namespace)
+ helm uninstall $(helm ls -q --namespace $namespace)
echo "Previous releases deleted"
waitsecs=10; while [ $waitsecs -gt 0 ]; do echo -ne "$waitsecs\033[0K\r"; sleep 1; : $((waitsecs--)); done
fi
@@ -215,7 +215,7 @@ if [[ !$skip_infrastructure ]]; then
for infra in "${infras[@]}"
do
echo "Installing infrastructure: $infra"
- helm install --namespace $namespace --set "ingress.hosts={$dns}" --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --name="$app_name-$infra" $infra
+ helm install "$app_name-$infra" --namespace $namespace --set "ingress.hosts={$dns}" --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns $infra
done
fi
@@ -223,9 +223,9 @@ for chart in "${charts[@]}"
do
echo "Installing: $chart"
if [[ $use_custom_registry ]]; then
- helm install --namespace $namespace --set "ingress.hosts={$dns}" --set inf.registry.server=$container_registry --set inf.registry.login=$docker_username --set inf.registry.pwd=$docker_password --set inf.registry.secretName=eshop-docker-scret --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --set image.tag=$image_tag --set image.pullPolicy=Always --name="$app_name-$chart" $chart
+ helm install "$app_name-$chart" --namespace $namespace --set "ingress.hosts={$dns}" --set inf.registry.server=$container_registry --set inf.registry.login=$docker_username --set inf.registry.pwd=$docker_password --set inf.registry.secretName=eshop-docker-scret --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --set image.tag=$image_tag --set image.pullPolicy=Always $chart
elif [[ $chart != "eshop-common" ]]; then # eshop-common is ignored when no secret must be deployed
- helm install --namespace $namespace --set "ingress.hosts={$dns}" --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --set image.tag=$image_tag --set image.pullPolicy=Always --name="$app_name-$chart" $chart
+ helm install "$app_name-$chart" --namespace $namespace --set "ingress.hosts={$dns}" --values app.yaml --values inf.yaml --values $ingress_values_file --set app.name=$app_name --set inf.k8s.dns=$dns --set image.tag=$image_tag --set image.pullPolicy=Always $chart
fi
done
diff --git a/deploy/k8s/helm/identity-api/templates/deployment.yaml b/deploy/k8s/helm/identity-api/templates/deployment.yaml
index c6ad69067..f2e7d6078 100644
--- a/deploy/k8s/helm/identity-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/identity-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "identity-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "identity-api.fullname" . }}
diff --git a/deploy/k8s/helm/keystore-data/templates/deployment.yaml b/deploy/k8s/helm/keystore-data/templates/deployment.yaml
index 34f1fe074..d3604c212 100644
--- a/deploy/k8s/helm/keystore-data/templates/deployment.yaml
+++ b/deploy/k8s/helm/keystore-data/templates/deployment.yaml
@@ -1,4 +1,4 @@
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "keystore-data.fullname" . }}
diff --git a/deploy/k8s/helm/locations-api/templates/deployment.yaml b/deploy/k8s/helm/locations-api/templates/deployment.yaml
index 9a5bb608c..1dba5d166 100644
--- a/deploy/k8s/helm/locations-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/locations-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "locations-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "locations-api.fullname" . }}
diff --git a/deploy/k8s/helm/marketing-api/templates/deployment.yaml b/deploy/k8s/helm/marketing-api/templates/deployment.yaml
index 60d4cd1a3..6b833eb8c 100644
--- a/deploy/k8s/helm/marketing-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/marketing-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "marketing-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "marketing-api.fullname" . }}
diff --git a/deploy/k8s/helm/mobileshoppingagg/templates/deployment.yaml b/deploy/k8s/helm/mobileshoppingagg/templates/deployment.yaml
index 41e1fa75c..eb0f4f536 100644
--- a/deploy/k8s/helm/mobileshoppingagg/templates/deployment.yaml
+++ b/deploy/k8s/helm/mobileshoppingagg/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "mobileshoppingagg.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "mobileshoppingagg.fullname" . }}
diff --git a/deploy/k8s/helm/nosql-data/templates/deployment.yaml b/deploy/k8s/helm/nosql-data/templates/deployment.yaml
index 9b1f32319..c1f5c9a8e 100644
--- a/deploy/k8s/helm/nosql-data/templates/deployment.yaml
+++ b/deploy/k8s/helm/nosql-data/templates/deployment.yaml
@@ -1,4 +1,4 @@
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "nosql-data.fullname" . }}
diff --git a/deploy/k8s/helm/ordering-api/templates/deployment.yaml b/deploy/k8s/helm/ordering-api/templates/deployment.yaml
index 327040701..4e25dcbb6 100644
--- a/deploy/k8s/helm/ordering-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/ordering-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "ordering-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "ordering-api.fullname" . }}
diff --git a/deploy/k8s/helm/ordering-backgroundtasks/templates/deployment.yaml b/deploy/k8s/helm/ordering-backgroundtasks/templates/deployment.yaml
index d93c7f764..cbb06ffdc 100644
--- a/deploy/k8s/helm/ordering-backgroundtasks/templates/deployment.yaml
+++ b/deploy/k8s/helm/ordering-backgroundtasks/templates/deployment.yaml
@@ -1,7 +1,7 @@
{{- $name := include "ordering-backgroundtasks.fullname" . -}}
{{- $cfgname := printf "cfg-%s" $name | trunc 63 }}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "ordering-backgroundtasks.fullname" . }}
diff --git a/deploy/k8s/helm/ordering-signalrhub/templates/deployment.yaml b/deploy/k8s/helm/ordering-signalrhub/templates/deployment.yaml
index af3867ea5..87fd51da6 100644
--- a/deploy/k8s/helm/ordering-signalrhub/templates/deployment.yaml
+++ b/deploy/k8s/helm/ordering-signalrhub/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "ordering-signalrhub.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "ordering-signalrhub.fullname" . }}
diff --git a/deploy/k8s/helm/payment-api/templates/deployment.yaml b/deploy/k8s/helm/payment-api/templates/deployment.yaml
index f83eb37da..df0bbe7d1 100644
--- a/deploy/k8s/helm/payment-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/payment-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "payment-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "payment-api.fullname" . }}
diff --git a/deploy/k8s/helm/rabbitmq/templates/deployment.yaml b/deploy/k8s/helm/rabbitmq/templates/deployment.yaml
index 9819a6455..1e81d34c5 100644
--- a/deploy/k8s/helm/rabbitmq/templates/deployment.yaml
+++ b/deploy/k8s/helm/rabbitmq/templates/deployment.yaml
@@ -1,4 +1,4 @@
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "rabbitmq.fullname" . }}
diff --git a/deploy/k8s/helm/sql-data/templates/deployment.yaml b/deploy/k8s/helm/sql-data/templates/deployment.yaml
index 4b2f589ef..bc94d2e9e 100644
--- a/deploy/k8s/helm/sql-data/templates/deployment.yaml
+++ b/deploy/k8s/helm/sql-data/templates/deployment.yaml
@@ -1,4 +1,4 @@
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "sql-data.fullname" . }}
diff --git a/deploy/k8s/helm/webhooks-api/templates/deployment.yaml b/deploy/k8s/helm/webhooks-api/templates/deployment.yaml
index 2ecb885bf..16aeecd91 100644
--- a/deploy/k8s/helm/webhooks-api/templates/deployment.yaml
+++ b/deploy/k8s/helm/webhooks-api/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "webhooks-api.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "webhooks-api.fullname" . }}
diff --git a/deploy/k8s/helm/webhooks-web/templates/deployment.yaml b/deploy/k8s/helm/webhooks-web/templates/deployment.yaml
index 43d406524..7ee3572f5 100644
--- a/deploy/k8s/helm/webhooks-web/templates/deployment.yaml
+++ b/deploy/k8s/helm/webhooks-web/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "webhooks-web.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "webhooks-web.fullname" . }}
diff --git a/deploy/k8s/helm/webmvc/templates/deployment.yaml b/deploy/k8s/helm/webmvc/templates/deployment.yaml
index 2889dc757..2e1162be1 100644
--- a/deploy/k8s/helm/webmvc/templates/deployment.yaml
+++ b/deploy/k8s/helm/webmvc/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "webmvc.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "webmvc.fullname" . }}
diff --git a/deploy/k8s/helm/webshoppingagg/templates/deployment.yaml b/deploy/k8s/helm/webshoppingagg/templates/deployment.yaml
index ab5bfc0c9..3e82f1a0e 100644
--- a/deploy/k8s/helm/webshoppingagg/templates/deployment.yaml
+++ b/deploy/k8s/helm/webshoppingagg/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "webshoppingagg.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "webshoppingagg.fullname" . }}
diff --git a/deploy/k8s/helm/webspa/templates/deployment.yaml b/deploy/k8s/helm/webspa/templates/deployment.yaml
index 20dc696bf..4cffcdb8f 100644
--- a/deploy/k8s/helm/webspa/templates/deployment.yaml
+++ b/deploy/k8s/helm/webspa/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "webspa.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "webspa.fullname" . }}
diff --git a/deploy/k8s/helm/webstatus/templates/deployment.yaml b/deploy/k8s/helm/webstatus/templates/deployment.yaml
index 70b953577..33ab7e056 100644
--- a/deploy/k8s/helm/webstatus/templates/deployment.yaml
+++ b/deploy/k8s/helm/webstatus/templates/deployment.yaml
@@ -1,6 +1,6 @@
{{- $name := include "webstatus.fullname" . -}}
{{- $cfgname := printf "%s-%s" "cfg" $name -}}
-apiVersion: apps/v1beta2
+apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "webstatus.fullname" . }}
diff --git a/deploy/k8s/nginx-ingress/mandatory.yaml b/deploy/k8s/nginx-ingress/mandatory.yaml
index 56b1cc3b5..2e63edd59 100644
--- a/deploy/k8s/nginx-ingress/mandatory.yaml
+++ b/deploy/k8s/nginx-ingress/mandatory.yaml
@@ -163,7 +163,7 @@ subjects:
---
-apiVersion: extensions/v1beta1
+apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-ingress-controller
diff --git a/deploy/windows/add-firewall-rules-for-sts-auth-thru-docker.ps1 b/deploy/windows/add-firewall-rules-for-sts-auth-thru-docker.ps1
index 271b6a77d..9aad3e45c 100644
--- a/deploy/windows/add-firewall-rules-for-sts-auth-thru-docker.ps1
+++ b/deploy/windows/add-firewall-rules-for-sts-auth-thru-docker.ps1
@@ -1,26 +1,53 @@
-param([switch]$Elevated)
+param(
+ [string]$Name = "eShopOnContainers",
+ [string]$InboundDisplayName = "eShopOnContainers-Inbound",
+ [string]$OutboundDisplayName = "eShopOnContainers-Outbound",
+ [switch]$Elevated
+ )
+
function Check-Admin {
-$currentUser = New-Object Security.Principal.WindowsPrincipal $([Security.Principal.WindowsIdentity]::GetCurrent())
-$currentUser.IsInRole([Security.Principal.WindowsBuiltinRole]::Administrator)
+ $currentUser = New-Object Security.Principal.WindowsPrincipal $([Security.Principal.WindowsIdentity]::GetCurrent())
+ $currentUser.IsInRole([Security.Principal.WindowsBuiltinRole]::Administrator)
}
-if ((Check-Admin) -eq $false) {
-if ($elevated)
-{
-# could not elevate, quit
+function Add-InboundRule {
+ New-NetFirewallRule -DisplayName $InboundDisplayName -Confirm -Description "$Name Inbound Rule for port range 5100-5150" -LocalAddress Any -LocalPort 5100-5150 -Protocol tcp -RemoteAddress Any -RemotePort Any -Direction Inbound
}
-
-else {
-
-Start-Process powershell.exe -Verb RunAs -ArgumentList ('-noprofile -noexit -file "{0}" -elevated' -f ($myinvocation.MyCommand.Definition))
+function Add-OutboundRule {
+ New-NetFirewallRule -DisplayName $OutboundDisplayName -Confirm -Description "$Name Outbound Rule for port range 5100-5150" -LocalAddress Any -LocalPort 5100-5150 -Protocol tcp -RemoteAddress Any -RemotePort Any -Direction Outbound
}
-exit
+
+if ((Check-Admin) -eq $false) {
+ if ($elevated)
+ {
+ # could not elevate, quit
+ }
+ else {
+ Start-Process powershell.exe -Verb RunAs -ArgumentList ('-noprofile -noexit -file "{0}" -elevated' -f ($myinvocation.MyCommand.Definition))
+ }
+ exit
}
+
try {
- Get-NetFirewallRule -DisplayName EshopDocker -ErrorAction Stop
- Write-Host "Rule found"
+ $rules = $(Get-NetFirewallRule -DisplayName $Name-* -ErrorAction Stop | Out-String)
+ if (!$rules.Contains($InboundDisplayName) -and !$rules.Contains($OutboundDisplayName))
+ {
+ Add-InboundRule
+ Add-OutboundRule
+ }
+ elseif (!$rules.Contains($InboundDisplayName))
+ {
+ Add-InboundRule
+ }
+ elseif (!$rules.Contains($OutboundDisplayName))
+ {
+ Add-OutboundRule
+ }
+ else{
+ Write-Host "Rules found!"
+ }
+}
+catch [Exception] {
+ Add-InboundRule
+ Add-OutboundRule
}
- catch [Exception] {
- New-NetFirewallRule -DisplayName eShopOnContainers-Inbound -Confirm -Description "eShopOnContainers Inbound Rule for port range 5100-5150" -LocalAddress Any -LocalPort 5100-5150 -Protocol tcp -RemoteAddress Any -RemotePort Any -Direction Inbound
- New-NetFirewallRule -DisplayName eShopOnContainers-Outbound -Confirm -Description "eShopOnContainers Outbound Rule for port range 5100-5150" -LocalAddress Any -LocalPort 5100-5150 -Protocol tcp -RemoteAddress Any -RemotePort Any -Direction Outbound
-}
\ No newline at end of file
diff --git a/img/architecture-book-cover-large-we.png b/img/architecture-book-cover-large-we.png
new file mode 100644
index 000000000..23c8de231
Binary files /dev/null and b/img/architecture-book-cover-large-we.png differ
diff --git a/img/devops-book-cover-large-we.png b/img/devops-book-cover-large-we.png
new file mode 100644
index 000000000..10c30876b
Binary files /dev/null and b/img/devops-book-cover-large-we.png differ
diff --git a/img/xamarin-enterprise-patterns-ebook-cover-large-we.png b/img/xamarin-enterprise-patterns-ebook-cover-large-we.png
new file mode 100644
index 000000000..28fdcc390
Binary files /dev/null and b/img/xamarin-enterprise-patterns-ebook-cover-large-we.png differ
diff --git a/src/.env b/src/.env
index c802f18eb..96b801650 100644
--- a/src/.env
+++ b/src/.env
@@ -5,9 +5,9 @@
# The IP below should be swapped to your real IP or DNS name, like 192.168.88.248, etc. if testing from remote browsers or mobile devices
# Use this values to run the app locally in Windows
-ESHOP_EXTERNAL_DNS_NAME_OR_IP=docker.for.win.localhost
-ESHOP_STORAGE_CATALOG_URL=http://docker.for.win.localhost:5202/c/api/v1/catalog/items/[0]/pic/
-ESHOP_STORAGE_MARKETING_URL=http://docker.for.win.localhost:5110/api/v1/campaigns/[0]/pic/
+ESHOP_EXTERNAL_DNS_NAME_OR_IP=host.docker.internal
+ESHOP_STORAGE_CATALOG_URL=http://host.docker.internal:5202/c/api/v1/catalog/items/[0]/pic/
+ESHOP_STORAGE_MARKETING_URL=http://host.docker.internal:5110/api/v1/campaigns/[0]/pic/
# Use this values to run the app locally in Mac
# ESHOP_EXTERNAL_DNS_NAME_OR_IP=docker.for.mac.localhost
diff --git a/src/ApiGateways/Envoy/config/webmarketing/envoy.yaml b/src/ApiGateways/Envoy/config/webmarketing/envoy.yaml
index c6f3421de..11ef504da 100644
--- a/src/ApiGateways/Envoy/config/webmarketing/envoy.yaml
+++ b/src/ApiGateways/Envoy/config/webmarketing/envoy.yaml
@@ -36,6 +36,19 @@ static_resources:
route:
auto_host_rewrite: true
cluster: marketing
+ - name: "l-short"
+ match:
+ prefix: "/l/"
+ route:
+ auto_host_rewrite: true
+ prefix_rewrite: "/locations-api/"
+ cluster: locations
+ - name: "l-long"
+ match:
+ prefix: "/locations-api/"
+ route:
+ auto_host_rewrite: true
+ cluster: locations
http_filters:
- name: envoy.router
access_log:
diff --git a/src/ApiGateways/Envoy/config/webshopping/envoy.yaml b/src/ApiGateways/Envoy/config/webshopping/envoy.yaml
index 1ae8c45a1..688fb740c 100644
--- a/src/ApiGateways/Envoy/config/webshopping/envoy.yaml
+++ b/src/ApiGateways/Envoy/config/webshopping/envoy.yaml
@@ -56,6 +56,9 @@ static_resources:
auto_host_rewrite: true
cluster: signalr-hub
timeout: 300s
+ upgrade_configs:
+ upgrade_type: "websocket"
+ enabled: true
- name: "b-short"
match:
prefix: "/b/"
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Config/UrlsConfig.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Config/UrlsConfig.cs
index c0bb9502e..90fa010cd 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Config/UrlsConfig.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Config/UrlsConfig.cs
@@ -1,7 +1,4 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
+using System.Collections.Generic;
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Config
{
@@ -10,12 +7,14 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Config
public class CatalogOperations
{
public static string GetItemById(int id) => $"/api/v1/catalog/items/{id}";
+
public static string GetItemsById(IEnumerable ids) => $"/api/v1/catalog/items?ids={string.Join(',', ids)}";
}
public class BasketOperations
{
public static string GetItemById(string id) => $"/api/v1/basket/{id}";
+
public static string UpdateBasket() => "/api/v1/basket";
}
@@ -25,10 +24,15 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Config
}
public string Basket { get; set; }
+
public string Catalog { get; set; }
+
public string Orders { get; set; }
+
public string GrpcBasket { get; set; }
+
public string GrpcCatalog { get; set; }
+
public string GrpcOrdering { get; set; }
}
}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Controllers/HomeController.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Controllers/HomeController.cs
index 48a71480a..e72e23ca7 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Controllers/HomeController.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Controllers/HomeController.cs
@@ -1,8 +1,4 @@
using Microsoft.AspNetCore.Mvc;
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Controllers
{
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs
index 3b8298bfe..e975edb23 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs
@@ -1,10 +1,11 @@
-namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Filters
+using Microsoft.AspNetCore.Authorization;
+using Microsoft.OpenApi.Models;
+using Swashbuckle.AspNetCore.SwaggerGen;
+using System.Collections.Generic;
+using System.Linq;
+
+namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Filters
{
- using Microsoft.AspNetCore.Authorization;
- using Microsoft.OpenApi.Models;
- using Swashbuckle.AspNetCore.SwaggerGen;
- using System.Collections.Generic;
- using System.Linq;
namespace Basket.API.Infrastructure.Filters
{
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs
index f81842c09..d0271d84b 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs
@@ -1,13 +1,9 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
-
-namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
+namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
{
public class AddBasketItemRequest
{
public int CatalogItemId { get; set; }
+
public string BasketId { get; set; }
public int Quantity { get; set; }
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/BasketData.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/BasketData.cs
index 426b8d2b5..7a43d58e5 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/BasketData.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/BasketData.cs
@@ -2,6 +2,7 @@
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
{
+
public class BasketData
{
public string BuyerId { get; set; }
@@ -10,7 +11,6 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
public BasketData()
{
-
}
public BasketData(string buyerId)
@@ -19,15 +19,4 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
}
}
- public class BasketDataItem
- {
- public string Id { get; set; }
- public int ProductId { get; set; }
- public string ProductName { get; set; }
- public decimal UnitPrice { get; set; }
- public decimal OldUnitPrice { get; set; }
- public int Quantity { get; set; }
- public string PictureUrl { get; set; }
-
- }
}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/BasketDataItem.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/BasketDataItem.cs
new file mode 100644
index 000000000..3ff91df4f
--- /dev/null
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/BasketDataItem.cs
@@ -0,0 +1,21 @@
+namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
+{
+
+ public class BasketDataItem
+ {
+ public string Id { get; set; }
+
+ public int ProductId { get; set; }
+
+ public string ProductName { get; set; }
+
+ public decimal UnitPrice { get; set; }
+
+ public decimal OldUnitPrice { get; set; }
+
+ public int Quantity { get; set; }
+
+ public string PictureUrl { get; set; }
+ }
+
+}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderData.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderData.cs
index e63b453a4..44749ff6c 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderData.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderData.cs
@@ -3,23 +3,39 @@ using System.Collections.Generic;
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
{
+
public class OrderData
{
public string OrderNumber { get; set; }
+
public DateTime Date { get; set; }
+
public string Status { get; set; }
+
public decimal Total { get; set; }
+
public string Description { get; set; }
+
public string City { get; set; }
+
public string Street { get; set; }
+
public string State { get; set; }
+
public string Country { get; set; }
+
public string ZipCode { get; set; }
+
public string CardNumber { get; set; }
+
public string CardHolderName { get; set; }
+
public bool IsDraft { get; set; }
+
public DateTime CardExpiration { get; set; }
+
public string CardExpirationShort { get; set; }
+
public string CardSecurityNumber { get; set; }
public int CardTypeId { get; set; }
@@ -28,4 +44,5 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
public List OrderItems { get; } = new List();
}
+
}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderItemData.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderItemData.cs
index 023cf20e5..b3832fa21 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderItemData.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/OrderItemData.cs
@@ -1,12 +1,19 @@
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
{
+
public class OrderItemData
{
public int ProductId { get; set; }
+
public string ProductName { get; set; }
+
public decimal UnitPrice { get; set; }
+
public decimal Discount { get; set; }
+
public int Units { get; set; }
+
public string PictureUrl { get; set; }
}
+
}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketItemData.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketItemData.cs
new file mode 100644
index 000000000..f8ec70d5f
--- /dev/null
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketItemData.cs
@@ -0,0 +1,16 @@
+namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
+{
+
+ public class UpdateBasketItemData
+ {
+ public string BasketItemId { get; set; }
+
+ public int NewQty { get; set; }
+
+ public UpdateBasketItemData()
+ {
+ NewQty = 0;
+ }
+ }
+
+}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs
index 35b3e76c0..c5a6ccb3e 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs
@@ -2,6 +2,7 @@
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
{
+
public class UpdateBasketItemsRequest
{
@@ -15,14 +16,4 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
}
}
- public class UpdateBasketItemData
- {
- public string BasketItemId { get; set; }
- public int NewQty { get; set; }
-
- public UpdateBasketItemData()
- {
- NewQty = 0;
- }
- }
}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs
index b377921be..a1c255551 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs
@@ -2,6 +2,7 @@
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
{
+
public class UpdateBasketRequest
{
public string BuyerId { get; set; }
@@ -9,10 +10,4 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
public IEnumerable Items { get; set; }
}
- public class UpdateBasketRequestItemData
- {
- public string Id { get; set; } // Basket id
- public int ProductId { get; set; } // Catalog item id
- public int Quantity { get; set; } // Quantity
- }
}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketRequestItemData.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketRequestItemData.cs
new file mode 100644
index 000000000..af28e0157
--- /dev/null
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Models/UpdateBasketRequestItemData.cs
@@ -0,0 +1,13 @@
+namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models
+{
+
+ public class UpdateBasketRequestItemData
+ {
+ public string Id { get; set; } // Basket id
+
+ public int ProductId { get; set; } // Catalog item id
+
+ public int Quantity { get; set; } // Quantity
+ }
+
+}
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Program.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Program.cs
index f536ec19a..2fc86c51f 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Program.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Program.cs
@@ -1,10 +1,8 @@
using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
-using Microsoft.AspNetCore.Server.Kestrel.Core;
using Microsoft.Extensions.Configuration;
using Serilog;
using System.IO;
-using System.Net;
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator
{
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/BasketService.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/BasketService.cs
index 609b6cdd9..8bd4c8948 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/BasketService.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/BasketService.cs
@@ -1,14 +1,12 @@
using Grpc.Net.Client;
+using GrpcBasket;
using Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Config;
using Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
-using System;
using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;
-using GrpcBasket;
-using Grpc.Core;
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Services
{
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/CatalogService.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/CatalogService.cs
index 2cf160d80..f98b90989 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/CatalogService.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/CatalogService.cs
@@ -1,5 +1,4 @@
using CatalogApi;
-using Grpc.Net.Client;
using Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Config;
using Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models;
using Microsoft.Extensions.Options;
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/GrpcCallerService.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/GrpcCallerService.cs
index fe857c6cc..55f3df3ee 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/GrpcCallerService.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/GrpcCallerService.cs
@@ -1,9 +1,8 @@
-using System.Net.Http;
-using System.Threading.Tasks;
-using System;
-using Grpc.Core;
-using Serilog;
+using Grpc.Core;
using Grpc.Net.Client;
+using Serilog;
+using System;
+using System.Threading.Tasks;
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Services
{
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/OrderingService.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/OrderingService.cs
index a48c942de..d34a5338a 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/OrderingService.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Services/OrderingService.cs
@@ -1,4 +1,4 @@
-using Grpc.Net.Client;
+using GrpcOrdering;
using Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Config;
using Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Models;
using Microsoft.Extensions.Logging;
@@ -6,7 +6,6 @@ using Microsoft.Extensions.Options;
using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;
-using GrpcOrdering;
namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator.Services
{
diff --git a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Startup.cs b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Startup.cs
index 7a48e93ed..6523cafe9 100644
--- a/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Startup.cs
+++ b/src/ApiGateways/Mobile.Bff.Shopping/aggregator/Startup.cs
@@ -64,9 +64,6 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator
{
app.UseDeveloperExceptionPage();
}
-
-
- app.UseCors("CorsPolicy");
app.UseSwagger().UseSwaggerUI(c =>
{
@@ -79,6 +76,7 @@ namespace Microsoft.eShopOnContainers.Mobile.Shopping.HttpAggregator
});
app.UseRouting();
+ app.UseCors("CorsPolicy");
app.UseAuthentication();
app.UseAuthorization();
app.UseEndpoints(endpoints =>
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Config/UrlsConfig.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Config/UrlsConfig.cs
index dccccab35..b16530e1b 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Config/UrlsConfig.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Config/UrlsConfig.cs
@@ -1,17 +1,18 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
+using System.Collections.Generic;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config
{
+
public class UrlsConfig
{
+
public class CatalogOperations
{
// grpc call under REST must go trough port 80
public static string GetItemById(int id) => $"/api/v1/catalog/items/{id}";
+
public static string GetItemById(string ids) => $"/api/v1/catalog/items/ids/{string.Join(',', ids)}";
+
// REST call standard must go through port 5000
public static string GetItemsById(IEnumerable ids) => $":5000/api/v1/catalog/items?ids={string.Join(',', ids)}";
}
@@ -19,6 +20,7 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config
public class BasketOperations
{
public static string GetItemById(string id) => $"/api/v1/basket/{id}";
+
public static string UpdateBasket() => "/api/v1/basket";
}
@@ -28,10 +30,16 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config
}
public string Basket { get; set; }
+
public string Catalog { get; set; }
+
public string Orders { get; set; }
+
public string GrpcBasket { get; set; }
+
public string GrpcCatalog { get; set; }
+
public string GrpcOrdering { get; set; }
}
+
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/BasketController.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/BasketController.cs
index dd5d4e85c..9471c6e09 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/BasketController.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/BasketController.cs
@@ -3,12 +3,9 @@ using Microsoft.AspNetCore.Mvc;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Services;
using System;
-using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Threading.Tasks;
-using Serilog;
-using Newtonsoft.Json;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Controllers
{
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/HomeController.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/HomeController.cs
index 58ed48d1a..e742e2bd6 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/HomeController.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/HomeController.cs
@@ -1,8 +1,4 @@
using Microsoft.AspNetCore.Mvc;
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Controllers
{
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/OrderController.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/OrderController.cs
index 4b88c45b6..e528b478f 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/OrderController.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Controllers/OrderController.cs
@@ -2,9 +2,6 @@
using Microsoft.AspNetCore.Mvc;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Services;
-using System;
-using System.Collections.Generic;
-using System.Linq;
using System.Net;
using System.Threading.Tasks;
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs
index 45c191104..c273fd19e 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Filters/AuthorizeCheckOperationFilter.cs
@@ -1,11 +1,11 @@
-namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Filters
-{
- using Microsoft.AspNetCore.Authorization;
- using Microsoft.OpenApi.Models;
- using Swashbuckle.AspNetCore.SwaggerGen;
- using System.Collections.Generic;
- using System.Linq;
+using Microsoft.AspNetCore.Authorization;
+using Microsoft.OpenApi.Models;
+using Swashbuckle.AspNetCore.SwaggerGen;
+using System.Collections.Generic;
+using System.Linq;
+namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Filters
+{
namespace Basket.API.Infrastructure.Filters
{
public class AuthorizeCheckOperationFilter : IOperationFilter
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs
index 88aff245f..e9a6492c0 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/AddBasketItemRequest.cs
@@ -1,13 +1,10 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
-
-namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
+namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
{
+
public class AddBasketItemRequest
{
public int CatalogItemId { get; set; }
+
public string BasketId { get; set; }
public int Quantity { get; set; }
@@ -17,4 +14,5 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
Quantity = 1;
}
}
+
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/BasketData.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/BasketData.cs
index 507c7cdb7..18e855837 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/BasketData.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/BasketData.cs
@@ -2,6 +2,7 @@
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
{
+
public class BasketData
{
public string BuyerId { get; set; }
@@ -10,7 +11,6 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
public BasketData()
{
-
}
public BasketData(string buyerId)
@@ -19,15 +19,4 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
}
}
- public class BasketDataItem
- {
- public string Id { get; set; }
- public int ProductId { get; set; }
- public string ProductName { get; set; }
- public decimal UnitPrice { get; set; }
- public decimal OldUnitPrice { get; set; }
- public int Quantity { get; set; }
- public string PictureUrl { get; set; }
-
- }
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/BasketDataItem.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/BasketDataItem.cs
new file mode 100644
index 000000000..05fed054e
--- /dev/null
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/BasketDataItem.cs
@@ -0,0 +1,21 @@
+namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
+{
+
+ public class BasketDataItem
+ {
+ public string Id { get; set; }
+
+ public int ProductId { get; set; }
+
+ public string ProductName { get; set; }
+
+ public decimal UnitPrice { get; set; }
+
+ public decimal OldUnitPrice { get; set; }
+
+ public int Quantity { get; set; }
+
+ public string PictureUrl { get; set; }
+ }
+
+}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/CatalogItem.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/CatalogItem.cs
index 43e8e1cd1..68c856970 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/CatalogItem.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/CatalogItem.cs
@@ -1,5 +1,6 @@
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
{
+
public class CatalogItem
{
public int Id { get; set; }
@@ -10,4 +11,5 @@
public string PictureUri { get; set; }
}
+
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderData.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderData.cs
index e9d5982b9..c4536d697 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderData.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderData.cs
@@ -1,27 +1,41 @@
using System;
using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
{
+
public class OrderData
{
public string OrderNumber { get; set; }
+
public DateTime Date { get; set; }
+
public string Status { get; set; }
+
public decimal Total { get; set; }
+
public string Description { get; set; }
+
public string City { get; set; }
+
public string Street { get; set; }
+
public string State { get; set; }
+
public string Country { get; set; }
+
public string ZipCode { get; set; }
+
public string CardNumber { get; set; }
+
public string CardHolderName { get; set; }
+
public bool IsDraft { get; set; }
+
public DateTime CardExpiration { get; set; }
+
public string CardExpirationShort { get; set; }
+
public string CardSecurityNumber { get; set; }
public int CardTypeId { get; set; }
@@ -30,4 +44,5 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
public List OrderItems { get; } = new List();
}
+
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderItemData.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderItemData.cs
index 1a40cb8cb..0c2082fa2 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderItemData.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/OrderItemData.cs
@@ -1,17 +1,19 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
-
-namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
+namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
{
+
public class OrderItemData
{
public int ProductId { get; set; }
+
public string ProductName { get; set; }
+
public decimal UnitPrice { get; set; }
+
public decimal Discount { get; set; }
+
public int Units { get; set; }
+
public string PictureUrl { get; set; }
}
+
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketItemData.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketItemData.cs
new file mode 100644
index 000000000..b75784aa2
--- /dev/null
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketItemData.cs
@@ -0,0 +1,16 @@
+namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
+{
+
+ public class UpdateBasketItemData
+ {
+ public string BasketItemId { get; set; }
+
+ public int NewQty { get; set; }
+
+ public UpdateBasketItemData()
+ {
+ NewQty = 0;
+ }
+ }
+
+}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs
index b41c069bc..3e356dfe1 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketItemsRequest.cs
@@ -1,13 +1,10 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
+using System.Collections.Generic;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
{
+
public class UpdateBasketItemsRequest
{
-
public string BasketId { get; set; }
public ICollection Updates { get; set; }
@@ -18,14 +15,4 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
}
}
- public class UpdateBasketItemData
- {
- public string BasketItemId { get; set; }
- public int NewQty { get; set; }
-
- public UpdateBasketItemData()
- {
- NewQty = 0;
- }
- }
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs
index 9beeeade4..070016f70 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketRequest.cs
@@ -1,10 +1,8 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
+using System.Collections.Generic;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
{
+
public class UpdateBasketRequest
{
public string BuyerId { get; set; }
@@ -12,10 +10,4 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
public IEnumerable Items { get; set; }
}
- public class UpdateBasketRequestItemData
- {
- public string Id { get; set; } // Basket id
- public int ProductId { get; set; } // Catalog item id
- public int Quantity { get; set; } // Quantity
- }
}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketRequestItemData.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketRequestItemData.cs
new file mode 100644
index 000000000..90800374d
--- /dev/null
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Models/UpdateBasketRequestItemData.cs
@@ -0,0 +1,11 @@
+namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models
+{
+ public class UpdateBasketRequestItemData
+ {
+ public string Id { get; set; } // Basket id
+
+ public int ProductId { get; set; } // Catalog item id
+
+ public int Quantity { get; set; } // Quantity
+ }
+}
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/BasketService.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/BasketService.cs
index b289e98d6..7e85132cd 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/BasketService.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/BasketService.cs
@@ -1,12 +1,11 @@
-using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config;
+using GrpcBasket;
+using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
-using System.Threading.Tasks;
-using Grpc.Net.Client;
using System.Linq;
-using GrpcBasket;
using System.Net.Http;
+using System.Threading.Tasks;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Services
{
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/CatalogService.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/CatalogService.cs
index c10094928..059e1d046 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/CatalogService.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/CatalogService.cs
@@ -1,15 +1,13 @@
-using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config;
+using CatalogApi;
+using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using System.Collections.Generic;
+using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;
-using CatalogApi;
-using Grpc.Net.Client;
-using System;
using static CatalogApi.Catalog;
-using System.Linq;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Services
{
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/GrpcCallerService.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/GrpcCallerService.cs
index 43138f987..2039c7c4f 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/GrpcCallerService.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/GrpcCallerService.cs
@@ -1,8 +1,8 @@
-using System.Threading.Tasks;
-using System;
-using Grpc.Core;
-using Serilog;
+using Grpc.Core;
using Grpc.Net.Client;
+using Serilog;
+using System;
+using System.Threading.Tasks;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Services
{
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/OrderingService.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/OrderingService.cs
index 8075a507c..b460f4864 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/OrderingService.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Services/OrderingService.cs
@@ -1,14 +1,11 @@
-using Grpc.Net.Client;
+using GrpcOrdering;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Models;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
-using System;
using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;
-using GrpcOrdering;
-using Grpc.Core;
namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Services
{
diff --git a/src/ApiGateways/Web.Bff.Shopping/aggregator/Startup.cs b/src/ApiGateways/Web.Bff.Shopping/aggregator/Startup.cs
index 27ee6db3e..1ea6c0f4f 100644
--- a/src/ApiGateways/Web.Bff.Shopping/aggregator/Startup.cs
+++ b/src/ApiGateways/Web.Bff.Shopping/aggregator/Startup.cs
@@ -5,7 +5,6 @@ using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Diagnostics.HealthChecks;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
-using Microsoft.AspNetCore.Mvc;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Config;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Filters.Basket.API.Infrastructure.Filters;
using Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator.Infrastructure;
@@ -64,9 +63,7 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator
{
app.UseDeveloperExceptionPage();
}
-
-
- app.UseCors("CorsPolicy");
+
app.UseHttpsRedirection();
app.UseSwagger().UseSwaggerUI(c =>
@@ -80,6 +77,7 @@ namespace Microsoft.eShopOnContainers.Web.Shopping.HttpAggregator
});
app.UseRouting();
+ app.UseCors("CorsPolicy");
app.UseAuthentication();
app.UseAuthorization();
diff --git a/src/BuildingBlocks/EventBus/EventBusRabbitMQ/EventBusRabbitMQ.cs b/src/BuildingBlocks/EventBus/EventBusRabbitMQ/EventBusRabbitMQ.cs
index 5623549d5..6ee3032a8 100644
--- a/src/BuildingBlocks/EventBus/EventBusRabbitMQ/EventBusRabbitMQ.cs
+++ b/src/BuildingBlocks/EventBus/EventBusRabbitMQ/EventBusRabbitMQ.cs
@@ -21,12 +21,12 @@ namespace Microsoft.eShopOnContainers.BuildingBlocks.EventBusRabbitMQ
public class EventBusRabbitMQ : IEventBus, IDisposable
{
const string BROKER_NAME = "eshop_event_bus";
+ const string AUTOFAC_SCOPE_NAME = "eshop_event_bus";
private readonly IRabbitMQPersistentConnection _persistentConnection;
private readonly ILogger _logger;
private readonly IEventBusSubscriptionsManager _subsManager;
private readonly ILifetimeScope _autofac;
- private readonly string AUTOFAC_SCOPE_NAME = "eshop_event_bus";
private readonly int _retryCount;
private IModel _consumerChannel;
@@ -86,7 +86,6 @@ namespace Microsoft.eShopOnContainers.BuildingBlocks.EventBusRabbitMQ
using (var channel = _persistentConnection.CreateModel())
{
-
_logger.LogTrace("Declaring RabbitMQ exchange to publish event: {EventId}", @event.Id);
channel.ExchangeDeclare(exchange: BROKER_NAME, type: "direct");
diff --git a/src/Services/Basket/Basket.API/Startup.cs b/src/Services/Basket/Basket.API/Startup.cs
index d9554bcb8..e8576b238 100644
--- a/src/Services/Basket/Basket.API/Startup.cs
+++ b/src/Services/Basket/Basket.API/Startup.cs
@@ -209,11 +209,11 @@ namespace Microsoft.eShopOnContainers.Services.Basket.API
});
app.UseRouting();
+ app.UseCors("CorsPolicy");
ConfigureAuth(app);
app.UseStaticFiles();
-
- app.UseCors("CorsPolicy");
+
app.UseEndpoints(endpoints =>
{
endpoints.MapGrpcService();
diff --git a/src/Services/Catalog/Catalog.API/Grpc/CatalogService.cs b/src/Services/Catalog/Catalog.API/Grpc/CatalogService.cs
index 13c7c8d2e..ef22b5be2 100644
--- a/src/Services/Catalog/Catalog.API/Grpc/CatalogService.cs
+++ b/src/Services/Catalog/Catalog.API/Grpc/CatalogService.cs
@@ -68,11 +68,10 @@ namespace Catalog.API.Grpc
{
var items = await GetItemsByIdsAsync(request.Ids);
- if (!items.Any())
- {
- context.Status = new Status(StatusCode.NotFound, $"ids value invalid. Must be comma-separated list of numbers");
- }
- context.Status = new Status(StatusCode.OK, string.Empty);
+ context.Status = !items.Any() ?
+ new Status(StatusCode.NotFound, $"ids value invalid. Must be comma-separated list of numbers") :
+ new Status(StatusCode.OK, string.Empty);
+
return this.MapToResponse(items);
}
@@ -104,7 +103,7 @@ namespace Catalog.API.Grpc
private PaginatedItemsResponse MapToResponse(List items)
{
- return this.MapToResponse(items, items.Count(), 1, items.Count());
+ return this.MapToResponse(items, items.Count, 1, items.Count);
}
private PaginatedItemsResponse MapToResponse(List items, long count, int pageIndex, int pageSize)
diff --git a/src/Services/Catalog/Catalog.API/Startup.cs b/src/Services/Catalog/Catalog.API/Startup.cs
index 53a9554be..836b6a7b8 100644
--- a/src/Services/Catalog/Catalog.API/Startup.cs
+++ b/src/Services/Catalog/Catalog.API/Startup.cs
@@ -82,9 +82,9 @@ namespace Microsoft.eShopOnContainers.Services.Catalog.API
{
c.SwaggerEndpoint($"{ (!string.IsNullOrEmpty(pathBase) ? pathBase : string.Empty) }/swagger/v1/swagger.json", "Catalog.API V1");
});
-
- app.UseCors("CorsPolicy");
+
app.UseRouting();
+ app.UseCors("CorsPolicy");
app.UseEndpoints(endpoints =>
{
endpoints.MapDefaultControllerRoute();
diff --git a/src/Services/Location/Locations.API/Startup.cs b/src/Services/Location/Locations.API/Startup.cs
index 4f79b8977..ca6a57e6e 100644
--- a/src/Services/Location/Locations.API/Startup.cs
+++ b/src/Services/Location/Locations.API/Startup.cs
@@ -168,9 +168,8 @@ namespace Microsoft.eShopOnContainers.Services.Locations.API
app.UsePathBase(pathBase);
}
- app.UseCors("CorsPolicy");
-
app.UseRouting();
+ app.UseCors("CorsPolicy");
ConfigureAuth(app);
app.UseEndpoints(endpoints =>
diff --git a/src/Services/Location/Locations.API/appsettings.json b/src/Services/Location/Locations.API/appsettings.json
index 7fbe98b3e..3ee24b242 100644
--- a/src/Services/Location/Locations.API/appsettings.json
+++ b/src/Services/Location/Locations.API/appsettings.json
@@ -23,7 +23,7 @@
"UseVault": false,
"Vault": {
"Name": "eshop",
- "ClientId": "your-clien-id",
+ "ClientId": "your-client-id",
"ClientSecret": "your-client-secret"
}
-}
\ No newline at end of file
+}
diff --git a/src/Services/Marketing/Marketing.API/Startup.cs b/src/Services/Marketing/Marketing.API/Startup.cs
index 4c2c2a710..a7386a532 100644
--- a/src/Services/Marketing/Marketing.API/Startup.cs
+++ b/src/Services/Marketing/Marketing.API/Startup.cs
@@ -163,10 +163,9 @@
{
app.UsePathBase(pathBase);
}
-
- app.UseCors("CorsPolicy");
+
app.UseRouting();
-
+ app.UseCors("CorsPolicy");
ConfigureAuth(app);
app.UseEndpoints(endpoints =>
diff --git a/src/Services/Ordering/Ordering.API/Startup.cs b/src/Services/Ordering/Ordering.API/Startup.cs
index 3ccf16d54..a8da9a35c 100644
--- a/src/Services/Ordering/Ordering.API/Startup.cs
+++ b/src/Services/Ordering/Ordering.API/Startup.cs
@@ -89,8 +89,6 @@
app.UsePathBase(pathBase);
}
- app.UseCors("CorsPolicy");
-
app.UseSwagger()
.UseSwaggerUI(c =>
{
@@ -100,6 +98,7 @@
});
app.UseRouting();
+ app.UseCors("CorsPolicy");
ConfigureAuth(app);
app.UseEndpoints(endpoints =>
diff --git a/src/Services/Ordering/Ordering.Domain/AggregatesModel/OrderAggregate/Address.cs b/src/Services/Ordering/Ordering.Domain/AggregatesModel/OrderAggregate/Address.cs
index b552f5546..e2c78094d 100644
--- a/src/Services/Ordering/Ordering.Domain/AggregatesModel/OrderAggregate/Address.cs
+++ b/src/Services/Ordering/Ordering.Domain/AggregatesModel/OrderAggregate/Address.cs
@@ -23,7 +23,7 @@ namespace Microsoft.eShopOnContainers.Services.Ordering.Domain.AggregatesModel.O
ZipCode = zipcode;
}
- protected override IEnumerable