Skip to content

Commit

Permalink
feat: namada indexer helm chart
Browse files Browse the repository at this point in the history
  • Loading branch information
chliddle committed Dec 11, 2024
1 parent 0f34eb0 commit 7a5b09a
Show file tree
Hide file tree
Showing 16 changed files with 780 additions and 6 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,10 @@ jobs:
version: v3.10.0

- name: Run Helm lint
run: helm lint ${{ matrix.chart_dir }} -f ${{ matrix.chart_dir }}/examples/values.yaml
run: helm lint ${{ matrix.chart_dir }} -f ${{ matrix.chart_dir }}/values.yaml

- name: Run Helm template
run: helm template ${{ matrix.chart_dir }} -f ${{ matrix.chart_dir }}/examples/values.yaml
run: helm template ${{ matrix.chart_dir }} -f ${{ matrix.chart_dir }}/values.yaml

- name: Install chart dependencies
run: |
Expand Down
6 changes: 3 additions & 3 deletions charts/cosmos-operator-rpc-node/templates/rpc_node.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -77,8 +77,8 @@ spec:
image: "{{ .Values.image }}:{{ .Values.imageTag }}"
{{ if .Values.resources }}
resources:
{{ toYaml .Values.resources | nindent 6 }}
{{ end }}
{{- toYaml .Values.resources | nindent 6 }}
{{- end }}
{{ if .Values.nodeSelectorLabel }}
nodeSelector:
{{ toYaml .Values.nodeSelectorLabel | nindent 6 }}
Expand All @@ -94,7 +94,7 @@ spec:
operator: In
values:
- {{ .Release.Name }}
topologyKey: "kubernetes.io/hostname"
topologyKey: "kubernetes.io/hostname"
{{- end }}
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
Expand Down
2 changes: 1 addition & 1 deletion charts/cosmos-operator-rpc-node/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ volumeRetainPolicy: "Retain"
resources: {}

# Note: Optional additional configuration for the pod template
initContainers: []
initContainers: {}
cosmosNodeLabels: {}
cosmosNodeAnnotations: {}
priorityClassName: ""
Expand Down
32 changes: 32 additions & 0 deletions charts/namada-indexer/.helmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
# Patterns to ignore when building packages.
# This supports shell glob matching, relative path matching, and
# negation (prefixed with !). Only one pattern per line.

# # Ignore all .tgz files except in charts directory
# /charts/*.tgz
# !charts/*.tgz

# Common VCS dirs
.git/
.gitignore
.bzr/
.bzrignore
.hg/
.hgignore
.svn/

# Common backup files
*.swp
*.bak
*.tmp
*.orig
*~

# Various IDEs
.project
.idea/
*.tmproj
.vscode/

# Project specific
.releaserc.js
17 changes: 17 additions & 0 deletions charts/namada-indexer/.releaserc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
const chartName = 'namada-indexer';
const chartPath = __dirname;

module.exports = {
extends: '../.github/chart-release.config.js',
tagFormat: 'namada-indexer-v${version}',
plugins: [
'@semantic-release/commit-analyzer',
'@semantic-release/release-notes-generator',
'@semantic-release/changelog',
'@semantic-release/git',
'@semantic-release/github',
['@semantic-release/exec', {
prepareCmd: 'sed -i "s/^version:.*$/version: ${nextRelease.version}/" Chart.yaml && helm package . --version ${nextRelease.version} --app-version ${nextRelease.version} && mv *.tgz ../'
}]
]
};
9 changes: 9 additions & 0 deletions charts/namada-indexer/Chart.lock
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
dependencies:
- name: postgres-operator
repository: https://opensource.zalando.com/postgres-operator/charts/postgres-operator
version: 1.13.0
- name: redis
repository: https://charts.bitnami.com/bitnami
version: 20.5.0
digest: sha256:8336dfdf07439b8fb5ff7e54910d67b4833b1a02394bfddb438241eb827c9a17
generated: "2024-12-11T14:02:20.240034Z"
16 changes: 16 additions & 0 deletions charts/namada-indexer/Chart.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
apiVersion: v2
name: namada-indexer
description: A Helm chart for deploying a namada indexer
type: application
version: 0.0.0-development
appVersion: "1.0"

dependencies:
- name: postgres-operator
version: "1.13.0"
repository: "https://opensource.zalando.com/postgres-operator/charts/postgres-operator"
condition: postgresOperator.install.enabled
- name: redis
version: "20.5.0"
repository: "https://charts.bitnami.com/bitnami"
condition: redis.install.enabled
60 changes: 60 additions & 0 deletions charts/namada-indexer/cleanup.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
#!/bin/bash

NAMESPACE="namada-indexer"
RELEASE_NAME="namada-indexer"

echo "🗑️ Cleaning up resources in namespace: $NAMESPACE"

# Delete Helm release
echo "Removing Helm release..."
helm uninstall $RELEASE_NAME -n $NAMESPACE

# Delete PostgreSQL resources
echo "Removing PostgreSQL resources..."
kubectl delete postgresql -n $NAMESPACE --all
kubectl delete deployment -n $NAMESPACE -l application=db-connection-pooler
kubectl delete statefulset -n $NAMESPACE --all

# Delete PostgreSQL Services
echo "Removing PostgreSQL Services..."
kubectl delete svc -n $NAMESPACE \
namada-indexer-db \
namada-indexer-db-config \
namada-indexer-db-repl \
namada-indexer-db-pooler \
namada-indexer-db-repl-pooler \
namada-indexer-db-pooler-repl

# Delete Other Services
echo "Removing Other Services..."
kubectl delete svc -n $NAMESPACE -l app.kubernetes.io/instance=$RELEASE_NAME

# Delete PVCs
echo "Removing PVCs..."
kubectl delete pvc -n $NAMESPACE --all

# Delete ConfigMaps
echo "Removing ConfigMaps..."
kubectl delete configmap -n $NAMESPACE -l app.kubernetes.io/instance=$RELEASE_NAME

# Delete PostgreSQL Operator Secrets
echo "Removing PostgreSQL Operator Secrets..."
kubectl delete secret -n $NAMESPACE \
namada.namada-indexer-db.credentials.postgresql.acid.zalan.do \
pooler.namada-indexer-db.credentials.postgresql.acid.zalan.do \
postgres.namada-indexer-db.credentials.postgresql.acid.zalan.do \
standby.namada-indexer-db.credentials.postgresql.acid.zalan.do

# Delete Other Secrets
echo "Removing Other Secrets..."
kubectl delete secret -n $NAMESPACE -l app.kubernetes.io/instance=$RELEASE_NAME

# Delete Ingress
echo "Removing Ingress..."
kubectl delete ingress -n $NAMESPACE -l app.kubernetes.io/instance=$RELEASE_NAME

# Optional: Delete the namespace itself (uncomment if needed)
# echo "Removing namespace..."
# kubectl delete namespace $NAMESPACE

echo "✅ Cleanup completed!"
160 changes: 160 additions & 0 deletions charts/namada-indexer/templates/_helpers.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,160 @@
{{- define "namada-indexer.name" -}}
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
{{- end -}}

{{- define "namada-indexer.fullname" -}}
{{- if .Values.fullnameOverride -}}
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" -}}
{{- else -}}
{{- .Release.Name | trunc 63 | trimSuffix "-" -}}
{{- end -}}
{{- end -}}

{{- define "namada-indexer.chart" -}}
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
{{- end -}}

{{/*
Common labels
*/}}
{{- define "namada-indexer.labels" -}}
helm.sh/chart: {{ include "namada-indexer.chart" . }}
{{ include "namada-indexer.selectorLabels" . }}
{{- if .Chart.AppVersion }}
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
{{- end }}
app.kubernetes.io/managed-by: {{ .Release.Service }}
{{- end }}

{{/*
Selector labels
*/}}
{{- define "namada-indexer.selectorLabels" -}}
app.kubernetes.io/name: {{ include "namada-indexer.name" . }}
app.kubernetes.io/instance: {{ .Release.Name }}
{{- end -}}

{{/*
Create the name of the service account to use
*/}}
{{- define "namada-indexer.serviceAccountName" -}}
{{- if .Values.serviceAccount.create }}
{{- default (include "namada-indexer.fullname" .) .Values.serviceAccount.name }}
{{- else }}
{{- default "default" .Values.serviceAccount.name }}
{{- end }}
{{- end }}

{{/*
Container configuration helper
*/}}
{{- define "namada-indexer.containerConfig" -}}
{{- $ := index . 0 -}}
{{- $container := index . 1 -}}
{{- with $container -}}
{{- if .command }}
command:
{{- toYaml .command | nindent 2 }}
{{- end }}
{{- if .args }}
args:
{{- toYaml .args | nindent 2 }}
{{- end }}
{{- if .ports }}
ports:
{{- toYaml .ports | nindent 2 }}
{{- end }}
{{- if .livenessProbe }}
livenessProbe:
{{- toYaml .livenessProbe | nindent 2 }}
{{- end }}
{{- end }}
{{- if $.Values.containerDefaults }}
resources:
{{- toYaml $.Values.containerDefaults.resources | nindent 2 }}
envFrom:
{{- toYaml $.Values.containerDefaults.envFrom | nindent 2 }}
env:
{{- end }}
{{- end }}

{{/*
Database configuration helper
*/}}
{{- define "namada-indexer.dbConfig" -}}
{{- if .Values.postgresOperator.enabled }}
DB_HOST: "{{ include "namada-indexer.fullname" . }}-db.{{ .Release.Namespace }}.svc.cluster.local"
SECRET_NAME: "namada.{{ .Release.Namespace }}-db.credentials.postgresql.acid.zalan.do"
{{- else if .Values.externalPostgres.enabled }}
DB_HOST: {{ .Values.externalPostgres.host | quote }}
SECRET_NAME: {{ .Values.externalPostgres.credentialSecret.name | quote }}
{{- end }}
{{- end }}

{{/*
Database environment variables
*/}}
{{- define "namada-indexer.dbEnv" -}}
{{- if .Values.postgresOperator.enabled }}
- name: DB_USER
valueFrom:
secretKeyRef:
name: namada.{{ .Release.Name }}-db.credentials.postgresql.acid.zalan.do
key: username
- name: DB_PASSWORD
valueFrom:
secretKeyRef:
name: namada.{{ .Release.Name }}-db.credentials.postgresql.acid.zalan.do
key: password
{{- else if .Values.externalPostgres.enabled }}
- name: DB_USER
valueFrom:
secretKeyRef:
name: {{ .Values.externalPostgres.credentialSecret.name }}
key: {{ .Values.externalPostgres.credentialSecret.usernameKey | default "username" }}
- name: DB_PASSWORD
valueFrom:
secretKeyRef:
name: {{ .Values.externalPostgres.credentialSecret.name }}
key: {{ .Values.externalPostgres.credentialSecret.passwordKey | default "password" }}
{{- end }}
{{- end }}

{{/*
Database configuration validation
*/}}
{{- define "namada-indexer.validateDbConfig" -}}
{{- if and .Values.postgresOperator.enabled .Values.externalPostgres.enabled }}
{{- fail "Cannot enable both postgresOperator and externalPostgres at the same time" }}
{{- end }}
{{- if not (or .Values.postgresOperator.enabled .Values.externalPostgres.enabled) }}
{{- fail "Either postgresOperator or externalPostgres must be enabled" }}
{{- end }}
{{- end }}

{{/*
Redis configuration helper
*/}}
{{- define "namada-indexer.redisConfig" -}}
{{- if .Values.redis.install.enabled }}
REDIS_HOST: "{{ .Release.Name }}-redis-master.{{ .Release.Namespace }}.svc.cluster.local"
REDIS_PORT: "6379"
REDIS_SECRET_NAME: "{{ .Release.Name }}-redis"
{{- else if .Values.externalRedis.enabled }}
REDIS_HOST: {{ .Values.externalRedis.host | quote }}
REDIS_PORT: {{ .Values.externalRedis.port | quote }}
REDIS_SECRET_NAME: {{ .Values.externalRedis.credentialSecret.name | quote }}
{{- end }}
{{- end }}

{{/*
Redis configuration validation
*/}}
{{- define "namada-indexer.validateRedisConfig" -}}
{{- if and .Values.redis.install.enabled .Values.externalRedis.enabled }}
{{- fail "Cannot enable both redis.install and externalRedis at the same time" }}
{{- end }}
{{- if not (or .Values.redis.install.enabled .Values.externalRedis.enabled) }}
{{- fail "Either redis.install or externalRedis must be enabled" }}
{{- end }}
{{- end }}
21 changes: 21 additions & 0 deletions charts/namada-indexer/templates/configmap.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{{- $dbConfig := include "namada-indexer.dbConfig" . | fromYaml }}
{{- $redisConfig := include "namada-indexer.redisConfig" . | fromYaml }}
{{- range $name, $configmap := .Values.configmaps }}
---
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ include "namada-indexer.fullname" $ }}-{{ $name }}
labels:
{{- include "namada-indexer.labels" $ | nindent 4 }}
data:
{{- if $dbConfig }}
{{- toYaml $dbConfig | nindent 2 }}
{{- end }}
{{- if $redisConfig }}
{{- toYaml $redisConfig | nindent 2 }}
{{- end }}
{{- range $key, $value := $configmap.data }}
{{ $key }}: {{ $value | quote }}
{{- end }}
{{- end }}
Loading

0 comments on commit 7a5b09a

Please sign in to comment.