Add Hermes Helm chart
Some checks failed
Build Skills Index / build-index (push) Has been cancelled
Build Skills Index / deploy-with-index (push) Has been cancelled
Lint (ruff + ty) / ruff + ty diff (push) Has been cancelled
Lint (ruff + ty) / ruff enforcement (blocking) (push) Has been cancelled
Lint (ruff + ty) / Windows footguns (blocking) (push) Has been cancelled
Nix / nix (macos-latest) (push) Has been cancelled
Nix / nix (ubuntu-latest) (push) Has been cancelled
Tests / test (1) (push) Has been cancelled
Tests / test (2) (push) Has been cancelled
Tests / test (3) (push) Has been cancelled
Tests / test (4) (push) Has been cancelled
Tests / test (5) (push) Has been cancelled
Tests / test (6) (push) Has been cancelled
Tests / e2e (push) Has been cancelled
OSV-Scanner / Scan lockfiles (push) Has been cancelled
Tests / save-durations (push) Has been cancelled
Some checks failed
Build Skills Index / build-index (push) Has been cancelled
Build Skills Index / deploy-with-index (push) Has been cancelled
Lint (ruff + ty) / ruff + ty diff (push) Has been cancelled
Lint (ruff + ty) / ruff enforcement (blocking) (push) Has been cancelled
Lint (ruff + ty) / Windows footguns (blocking) (push) Has been cancelled
Nix / nix (macos-latest) (push) Has been cancelled
Nix / nix (ubuntu-latest) (push) Has been cancelled
Tests / test (1) (push) Has been cancelled
Tests / test (2) (push) Has been cancelled
Tests / test (3) (push) Has been cancelled
Tests / test (4) (push) Has been cancelled
Tests / test (5) (push) Has been cancelled
Tests / test (6) (push) Has been cancelled
Tests / e2e (push) Has been cancelled
OSV-Scanner / Scan lockfiles (push) Has been cancelled
Tests / save-durations (push) Has been cancelled
This commit is contained in:
6
charts/hermes/Chart.yaml
Normal file
6
charts/hermes/Chart.yaml
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
apiVersion: v2
|
||||||
|
name: hermes
|
||||||
|
description: Helm chart for Hermes Agent
|
||||||
|
type: application
|
||||||
|
version: 0.1.0
|
||||||
|
appVersion: latest
|
||||||
47
charts/hermes/README.md
Normal file
47
charts/hermes/README.md
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
# Hermes Helm Chart
|
||||||
|
|
||||||
|
This chart deploys the Hermes Agent image from the private Gitea registry.
|
||||||
|
|
||||||
|
The current `git.openputer.com/common/hermes:latest` image is amd64-only, so
|
||||||
|
the default values schedule pods on amd64 nodes.
|
||||||
|
|
||||||
|
## Registry Secret
|
||||||
|
|
||||||
|
Create the registry pull secret in the target namespace before installing:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
kubectl create namespace hermes
|
||||||
|
kubectl create secret docker-registry gitea-registry \
|
||||||
|
--namespace hermes \
|
||||||
|
--docker-server=git.openputer.com \
|
||||||
|
--docker-username='<username>' \
|
||||||
|
--docker-password='<token-or-password>'
|
||||||
|
```
|
||||||
|
|
||||||
|
## Install
|
||||||
|
|
||||||
|
```sh
|
||||||
|
helm upgrade --install hermes ./charts/hermes \
|
||||||
|
--namespace hermes \
|
||||||
|
--create-namespace
|
||||||
|
```
|
||||||
|
|
||||||
|
## Check
|
||||||
|
|
||||||
|
```sh
|
||||||
|
kubectl get pods -n hermes
|
||||||
|
kubectl logs -n hermes deploy/hermes
|
||||||
|
```
|
||||||
|
|
||||||
|
## Dashboard
|
||||||
|
|
||||||
|
The dashboard is disabled by default. If you enable it, keep it behind
|
||||||
|
authentication or a private tunnel.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
helm upgrade --install hermes ./charts/hermes \
|
||||||
|
--namespace hermes \
|
||||||
|
--set env.HERMES_DASHBOARD=1 \
|
||||||
|
--set env.HERMES_DASHBOARD_HOST=0.0.0.0 \
|
||||||
|
--set service.enabled=true
|
||||||
|
```
|
||||||
29
charts/hermes/templates/_helpers.tpl
Normal file
29
charts/hermes/templates/_helpers.tpl
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
{{- define "hermes.name" -}}
|
||||||
|
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "hermes.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 -}}
|
||||||
|
|
||||||
|
{{- define "hermes.labels" -}}
|
||||||
|
helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
|
||||||
|
app.kubernetes.io/name: {{ include "hermes.name" . }}
|
||||||
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
|
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
|
||||||
|
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "hermes.selectorLabels" -}}
|
||||||
|
app.kubernetes.io/name: {{ include "hermes.name" . }}
|
||||||
|
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||||
|
{{- end -}}
|
||||||
60
charts/hermes/templates/deployment.yaml
Normal file
60
charts/hermes/templates/deployment.yaml
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: {{ include "hermes.fullname" . }}
|
||||||
|
labels:
|
||||||
|
{{- include "hermes.labels" . | nindent 4 }}
|
||||||
|
spec:
|
||||||
|
replicas: {{ .Values.replicaCount }}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
{{- include "hermes.selectorLabels" . | nindent 6 }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
{{- include "hermes.selectorLabels" . | nindent 8 }}
|
||||||
|
spec:
|
||||||
|
{{- with .Values.imagePullSecrets }}
|
||||||
|
imagePullSecrets:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.nodeSelector }}
|
||||||
|
nodeSelector:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.affinity }}
|
||||||
|
affinity:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.tolerations }}
|
||||||
|
tolerations:
|
||||||
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
containers:
|
||||||
|
- name: hermes
|
||||||
|
image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
|
||||||
|
imagePullPolicy: {{ .Values.image.pullPolicy }}
|
||||||
|
args:
|
||||||
|
{{- toYaml .Values.command | nindent 12 }}
|
||||||
|
env:
|
||||||
|
- name: HERMES_HOME
|
||||||
|
value: /opt/data
|
||||||
|
{{- range $name, $value := .Values.env }}
|
||||||
|
- name: {{ $name }}
|
||||||
|
value: {{ $value | quote }}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .Values.resources }}
|
||||||
|
resources:
|
||||||
|
{{- toYaml . | nindent 12 }}
|
||||||
|
{{- end }}
|
||||||
|
volumeMounts:
|
||||||
|
- name: hermes-data
|
||||||
|
mountPath: /opt/data
|
||||||
|
volumes:
|
||||||
|
- name: hermes-data
|
||||||
|
{{- if .Values.persistence.enabled }}
|
||||||
|
persistentVolumeClaim:
|
||||||
|
claimName: {{ include "hermes.fullname" . }}-data
|
||||||
|
{{- else }}
|
||||||
|
emptyDir: {}
|
||||||
|
{{- end }}
|
||||||
17
charts/hermes/templates/pvc.yaml
Normal file
17
charts/hermes/templates/pvc.yaml
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
{{- if .Values.persistence.enabled }}
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolumeClaim
|
||||||
|
metadata:
|
||||||
|
name: {{ include "hermes.fullname" . }}-data
|
||||||
|
labels:
|
||||||
|
{{- include "hermes.labels" . | nindent 4 }}
|
||||||
|
spec:
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteOnce
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: {{ .Values.persistence.size }}
|
||||||
|
{{- if .Values.persistence.storageClassName }}
|
||||||
|
storageClassName: {{ .Values.persistence.storageClassName }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
16
charts/hermes/templates/service.yaml
Normal file
16
charts/hermes/templates/service.yaml
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
{{- if .Values.service.enabled }}
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: {{ include "hermes.fullname" . }}
|
||||||
|
labels:
|
||||||
|
{{- include "hermes.labels" . | nindent 4 }}
|
||||||
|
spec:
|
||||||
|
type: {{ .Values.service.type }}
|
||||||
|
selector:
|
||||||
|
{{- include "hermes.selectorLabels" . | nindent 4 }}
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
port: {{ .Values.service.port }}
|
||||||
|
targetPort: {{ .Values.service.targetPort }}
|
||||||
|
{{- end }}
|
||||||
35
charts/hermes/values.yaml
Normal file
35
charts/hermes/values.yaml
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
image:
|
||||||
|
repository: git.openputer.com/common/hermes
|
||||||
|
tag: latest
|
||||||
|
pullPolicy: IfNotPresent
|
||||||
|
|
||||||
|
imagePullSecrets:
|
||||||
|
- name: gitea-registry
|
||||||
|
|
||||||
|
replicaCount: 1
|
||||||
|
|
||||||
|
command:
|
||||||
|
- gateway
|
||||||
|
- run
|
||||||
|
|
||||||
|
env: {}
|
||||||
|
|
||||||
|
persistence:
|
||||||
|
enabled: true
|
||||||
|
size: 10Gi
|
||||||
|
storageClassName: ""
|
||||||
|
|
||||||
|
service:
|
||||||
|
enabled: false
|
||||||
|
type: ClusterIP
|
||||||
|
port: 9119
|
||||||
|
targetPort: 9119
|
||||||
|
|
||||||
|
resources: {}
|
||||||
|
|
||||||
|
nodeSelector:
|
||||||
|
kubernetes.io/arch: amd64
|
||||||
|
|
||||||
|
tolerations: []
|
||||||
|
|
||||||
|
affinity: {}
|
||||||
Reference in New Issue
Block a user