feat: add the vikunja todo app

This commit is contained in:
Tommy 2024-04-11 21:39:13 +02:00
parent 5d8761acf8
commit 6f9073832c
No known key found for this signature in database
9 changed files with 206 additions and 2 deletions

View file

@ -52,9 +52,11 @@ Below you'll find an overview of the charts and an intro to get you started.
🚧 [[charts/paperless-ngx][paperless-ngx]]: Document management system that transforms your physical documents into a searchable online archive.
🚧 [[charts/maubot][Maubot]]: A Matrix bot system.
🚧 [[charts/vikunja][Vikunja]]: Todo app with web and dav support.
🚧 [[charts/nfty-sh][nfty.sh]]: A push notification server for clients and phones.
🚧 [[charts/maubot][Maubot]]: Matrix bot system.
🚧 [[charts/nfty-sh][nfty.sh]]: Push notification server for clients and phones.
🚧 [[charts/ollama-web][OLLAMA Web]]: User-friendly WebUI for LLMs (Formerly Ollama WebUI). A simplified chart of the original and wip, but it works.

18
charts/vikunja/Chart.yaml Normal file
View file

@ -0,0 +1,18 @@
apiVersion: v2
name: vikunja
description: |
Todo app with web and dav support
appVersion: 0.23.0
type: application
version: 0.1.0
maintainers:
- name: Tommy Skaug
email: tommy@skaug.me
keywords:
- vikunja
- todo
- task
- project-management
sources:
- https://vikunja.io/
- https://hub.docker.com/r/vikunja/vikunja

View file

@ -0,0 +1,30 @@
# Define a template for the chart's full name.
{{/*
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).
*/}}
{{- define "vikunja.fullname" -}}
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
{{- end }}
# Define a template for standard labels.
{{/*
Common labels
*/}}
{{- define "vikunja.labels" -}}
helm.sh/chart: {{ include "vikunja.chart" . }}
app.kubernetes.io/name: {{ include "vikunja.fullname" . }}
app.kubernetes.io/instance: {{ .Release.Name }}
app.kubernetes.io/version: {{ .Chart.Version | quote }}
app.kubernetes.io/managed-by: {{ .Release.Service }}
{{- end }}
# Define a template for the chart name and version.
{{/*
Generate basic labels
*/}}
{{- define "vikunja.chart" -}}
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" -}}
{{- end }}
# Optionally, add more helper templates as needed.

View file

@ -0,0 +1,20 @@
apiVersion: batch/v1
kind: Job
metadata:
name: {{ include "vikunja.fullname" . }}-db-init
labels:
{{- include "vikunja.labels" . | nindent 4 }}
annotations:
"helm.sh/hook": pre-install
"helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded
spec:
template:
spec:
restartPolicy: Never
containers:
- name: general-db-init
image: "{{ .Values.initContainers.dbInit.image.repository }}:{{ .Values.initContainers.dbInit.image.tag }}"
envFrom:
- secretRef:
name: {{ .Values.postgres.secretName }}
backoffLimit: 3

View file

@ -0,0 +1,48 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ include "vikunja.fullname" . }}
labels:
{{- include "vikunja.labels" . | nindent 4 }}
spec:
replicas: 1
selector:
matchLabels:
app: {{ include "vikunja.fullname" . }}
template:
metadata:
labels:
app: {{ include "vikunja.fullname" . }}
spec:
serviceAccountName: {{ include "vikunja.fullname" . }}
containers:
- name: {{ include "vikunja.fullname" . }}
image: {{ .Values.image.repository }}:{{ .Values.image.tag }}
envFrom:
- secretRef:
name: {{ .Values.envFromSecret }}
env:
- name: VIKUNJA_SERVICE_PUBLICURL
value: {{ .Values.config.externalUrl }}
- name: VIKUNJA_DATABASE_TYPE
value: postgres
resources:
{{- toYaml .Values.resources | nindent 10 }}
ports:
- containerPort: 29316
name: http
volumeMounts:
- name: {{ include "vikunja.fullname" . }}
mountPath: "/app/vikunja/files"
readOnly: false
- name: config
mountPath: "/app/vikunja/config.yml"
subPath: config.yml
readOnly: true
volumes:
- name: {{ include "vikunja.fullname" . }}
persistentVolumeClaim:
claimName: {{ .Values.persistence.existingClaim }}
- name: config
secret:
secretName: {{ .Values.existingSecretConfigMap }}

View file

@ -0,0 +1,13 @@
---
apiVersion: v1
kind: Service
metadata:
name: {{ include "vikunja.fullname" . }}
labels:
{{- include "vikunja.labels" . | nindent 4 }}
spec:
selector:
app: {{ include "vikunja.fullname" . }}
ports:
- port: 8080
targetPort: 3456

View file

@ -0,0 +1,7 @@
---
apiVersion: v1
kind: ServiceAccount
metadata:
name: {{ include "vikunja.fullname" . }}
labels:
{{- include "vikunja.labels" . | nindent 4 }}

View file

@ -0,0 +1,33 @@
config:
externalUrl: https://vikunja.example.com/
existingSecretConfigMap: vikunja-secret
persistence:
existingClaim: vikunja
initContainers:
dbInit:
image:
repository: ghcr.io/onedr0p/postgres-init
tag: "16"
envFrom:
- secretRef:
name: vikunja-secret
envFromSecret: vikunja-secret
image:
repository: vikunja/vikunja
tag: 0.23.0
postgres:
secretName: vikunja-secret
resources:
limits:
memory: "1Gi"
cpu: "500m"
# requests:
# cpu: 100m
# memory: 250Mi

View file

@ -0,0 +1,33 @@
config:
externalUrl: https://vikunja.example.com/
existingSecretConfigMap: vikunja-secret
persistence:
existingClaim: vikunja
initContainers:
dbInit:
image:
repository: ghcr.io/onedr0p/postgres-init
tag: "16"
envFrom:
- secretRef:
name: vikunja-secret
envFromSecret: vikunja-secret
image:
repository: vikunja/vikunja
tag: 0.23.0
postgres:
secretName: vikunja-secret
resources:
limits:
memory: "1Gi"
cpu: "500m"
# requests:
# cpu: 100m
# memory: 250Mi