Skip to content

Commit

Permalink
feat(helm): configure MIW Helm chart to use pgadmin4 subchart
Browse files Browse the repository at this point in the history
  • Loading branch information
pmoscode committed Dec 12, 2023
1 parent 09239de commit a43669f
Show file tree
Hide file tree
Showing 10 changed files with 106 additions and 7 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/chart-verification.yml
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ jobs:
with:
image: jnorwood/helm-docs:v1.11.3
options: -v ${{ github.workspace }}/charts:/helm-docs
run: helm-docs
run: helm-docs -i managed-identity-wallet/.helmdocsignore

- name: Verify that no changes are required
run: |
Expand Down Expand Up @@ -133,7 +133,7 @@ jobs:
- name: Install Helm unittest plugin
run: |
helm plugin install https://github.com/helm-unittest/helm-unittest.git
helm plugin install https://github.com/helm-unittest/helm-unittest.git --version 0.3.5
- name: Run Helm unittests
run: task helm:unittest
Expand Down
1 change: 1 addition & 0 deletions charts/managed-identity-wallet/.helmdocsignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
charts/
2 changes: 1 addition & 1 deletion charts/managed-identity-wallet/.helmignore
Original file line number Diff line number Diff line change
Expand Up @@ -24,5 +24,5 @@
tests/
values-*.yaml
README.md.gotmpl
.helmdocsignore
ci/
argocd/
7 changes: 5 additions & 2 deletions charts/managed-identity-wallet/Chart.lock
Original file line number Diff line number Diff line change
Expand Up @@ -8,5 +8,8 @@ dependencies:
- name: postgresql
repository: https://charts.bitnami.com/bitnami
version: 11.9.13
digest: sha256:d26187a3896751774a3c7646c6a12186aae20fbde5a705ca458c1aeac9bf361c
generated: "2023-12-11T11:38:02.235024+01:00"
- name: pgadmin4
repository: file://charts/pgadmin4
version: 1.19.0
digest: sha256:30c1e41f2c5f35829f68dd52ecc80005b4edf726d9e472801f6bfb834b8be512
generated: "2023-11-22T12:12:48.461495+01:00"
5 changes: 5 additions & 0 deletions charts/managed-identity-wallet/Chart.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -58,3 +58,8 @@ dependencies:
version: 11.9.13
repository: https://charts.bitnami.com/bitnami
condition: postgresql.internal.enabled
- name: pgadmin4
repository: file://charts/pgadmin4 # https://helm.runix.net
# License: https://github.com/rowanruseler/helm-charts/blob/main/LICENSE
version: 1.19.0
condition: pgadmin4.enabled
10 changes: 10 additions & 0 deletions charts/managed-identity-wallet/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command document

| Repository | Name | Version |
|------------|------|---------|
| file://charts/pgadmin4 | pgadmin4 | 1.19.0 |
| https://charts.bitnami.com/bitnami | common | 2.x.x |
| https://charts.bitnami.com/bitnami | keycloak | 15.1.6 |
| https://charts.bitnami.com/bitnami | postgresql | 11.9.13 |
Expand Down Expand Up @@ -142,6 +143,15 @@ See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command document
| miw.ssi.vcExpiryDate | string | `""` | Verifiable Credential expiry date. Format 'dd-MM-yyyy'. If empty it is set to 31-12-<current year> |
| nameOverride | string | `""` | String to partially override common.names.fullname template (will maintain the release name) |
| nodeSelector | object | `{"kubernetes.io/os":"linux"}` | NodeSelector configuration |
| pgadmin4.enabled | bool | `true` | Enable to deploy pgAdmin |
| pgadmin4.env.email | string | `"[email protected]"` | Preset the admin user email |
| pgadmin4.env.password | string | `"very-secret-password"` | preset password (there is no auto-generated password) |
| pgadmin4.extraServerDefinitions.enabled | bool | `true` | enable the predefined server for pgadmin |
| pgadmin4.extraServerDefinitions.servers | object | `{}` | See [here](https://github.com/rowanruseler/helm-charts/blob/9b970b2e419c2300dfbb3f827a985157098a0287/charts/pgadmin4/values.yaml#L84) how to configure the predefined servers |
| pgadmin4.ingress.annotations | object | `{}` | |
| pgadmin4.ingress.enabled | bool | `false` | Enagle pgAdmin ingress |
| pgadmin4.ingress.hosts | list | `[]` | See [here](https://github.com/rowanruseler/helm-charts/blob/9b970b2e419c2300dfbb3f827a985157098a0287/charts/pgadmin4/values.yaml#L104) how to configure the ingress host(s) |
| pgadmin4.ingress.tls | list | `[]` | See [here](https://github.com/rowanruseler/helm-charts/blob/9b970b2e419c2300dfbb3f827a985157098a0287/charts/pgadmin4/values.yaml#L109) how to configure tls for the ingress host(s) |
| podAnnotations | object | `{}` | PodAnnotation configuration |
| podSecurityContext | object | `{}` | PodSecurityContext |
| postgresql.auth.database | string | `"miw_app"` | Postgresql database to create |
Expand Down
6 changes: 6 additions & 0 deletions charts/managed-identity-wallet/templates/_helpers.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -79,3 +79,9 @@ Create the name of the service account to use
{{- default "default" .Values.serviceAccount.name }}
{{- end }}
{{- end }}

{{- define "managed-identity-wallet.pgadminServerDefinitions" -}}
{
"Servers": {{ .Values.pgadmin4.extraServerDefinitions.servers | toJson }}
}
{{- end -}}
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# /********************************************************************************
# * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation
# *
# * See the NOTICE file(s) distributed with this work for additional
# * information regarding copyright ownership.
# *
# * This program and the accompanying materials are made available under the
# * terms of the Apache License, Version 2.0 which is available at
# * https://www.apache.org/licenses/LICENSE-2.0.
# *
# * Unless required by applicable law or agreed to in writing, software
# * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# * License for the specific language governing permissions and limitations
# * under the License.
# *
# * SPDX-License-Identifier: Apache-2.0
# ********************************************************************************/

{{- if and .Values.pgadmin4.enabled .Values.pgadmin4.extraServerDefinitions.enabled }}
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ .Release.Name }}-pgadmin4-server-definitions
labels:
{{- include "pgadmin.labels" . | nindent 4 }}
data:
servers.json: |-
{{- include "common.tplvalues.render" (dict "value" (include "managed-identity-wallet.pgadminServerDefinitions" .) "context" $) | nindent 4 }}
{{- end }}
46 changes: 45 additions & 1 deletion charts/managed-identity-wallet/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ secrets: {}
envs: {}

serviceAccount:
# -- Enable creation of ServiceAccount
# -- Enable creation of ServiceAccount
create: true
# -- Annotations to add to the ServiceAccount
annotations: {}
Expand Down Expand Up @@ -259,3 +259,47 @@ postgresql:
resourcePolicy: "keep"
# -- PVC Storage Request for the backup data volume
size: "8Gi"

# For more information on how to configure the pgadmin chart see https://artifacthub.io/packages/helm/runix/pgadmin4.
# (Here we're using a stripped-down version of the pgadmin chart, to just )
pgadmin4:
# -- Enable to deploy pgAdmin
enabled: true
env:
# -- Preset the admin user email
email: [email protected]
# -- preset password (there is no auto-generated password)
password: very-secret-password
# @ignore
variables:
- name: PGADMIN_SERVER_JSON_FILE
value: /pgadmin4/servers.json
ingress:
# -- Enagle pgAdmin ingress
enabled: false
annotations: {}
# -- See [here](https://github.com/rowanruseler/helm-charts/blob/9b970b2e419c2300dfbb3f827a985157098a0287/charts/pgadmin4/values.yaml#L104) how to configure the ingress host(s)
hosts: []
# -- See [here](https://github.com/rowanruseler/helm-charts/blob/9b970b2e419c2300dfbb3f827a985157098a0287/charts/pgadmin4/values.yaml#L109) how to configure tls for the ingress host(s)
tls: []
extraServerDefinitions:
# -- enable the predefined server for pgadmin
enabled: true
# -- See [here](https://github.com/rowanruseler/helm-charts/blob/9b970b2e419c2300dfbb3f827a985157098a0287/charts/pgadmin4/values.yaml#L84) how to configure the predefined servers
servers:
# @ignore
miw-internal-postgresql:
Name: "MIW internal Postgresql DB"
Group: "Servers"
Port: 5432
Username: "miw"
Host: "{{ .Release.Name }}-postgresql"
SSLMode: "prefer"
MaintenanceDB: "postgres"
# @ignore
extraConfigmapMounts:
- name: server-definitions
configMap: "{{ .Release.Name }}-pgadmin4-server-definitions"
subPath: servers.json
mountPath: "/pgadmin4/servers.json"
readOnly: true
2 changes: 1 addition & 1 deletion dev-assets/tasks/helm.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -30,4 +30,4 @@ tasks:
desc: Rebuilds the readme of the Helm chart
dir: charts/managed-identity-wallet
cmds:
- helm-docs .
- helm-docs -i charts/managed-identity-wallet/.helmdocsignore .

0 comments on commit a43669f

Please sign in to comment.