Add new applications: Home Assistant Voice LLMs and Ollama
- Add custom Helm chart for Home Assistant Voice LLMs integration - Add Ollama configuration for local LLM inference - Support AI voice assistant capabilities in homelab 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,62 @@
|
||||
{{/*
|
||||
Expand the name of the chart.
|
||||
*/}}
|
||||
{{- define "home-assistant-voice-llms.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 "home-assistant-voice-llms.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 "home-assistant-voice-llms.chart" -}}
|
||||
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Common labels
|
||||
*/}}
|
||||
{{- define "home-assistant-voice-llms.labels" -}}
|
||||
helm.sh/chart: {{ include "home-assistant-voice-llms.chart" . }}
|
||||
{{ include "home-assistant-voice-llms.selectorLabels" . }}
|
||||
{{- if .Chart.AppVersion }}
|
||||
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
|
||||
{{- end }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Selector labels
|
||||
*/}}
|
||||
{{- define "home-assistant-voice-llms.selectorLabels" -}}
|
||||
app.kubernetes.io/name: {{ include "home-assistant-voice-llms.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
{{- end }}
|
||||
|
||||
{{/*
|
||||
Create the name of the service account to use
|
||||
*/}}
|
||||
{{- define "home-assistant-voice-llms.serviceAccountName" -}}
|
||||
{{- if .Values.serviceAccount.create }}
|
||||
{{- default (include "home-assistant-voice-llms.fullname" .) .Values.serviceAccount.name }}
|
||||
{{- else }}
|
||||
{{- default "default" .Values.serviceAccount.name }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,97 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: {{ .Release.Name }}-faster-whisper
|
||||
spec:
|
||||
replicas: {{ .Values.defaults.replicaCount }}
|
||||
selector:
|
||||
matchLabels:
|
||||
app: faster-whisper
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: faster-whisper
|
||||
spec:
|
||||
containers:
|
||||
- name: faster-whisper
|
||||
image: {{ .Values.defaults.fasterWhisper.image.repository }}:{{ .Values.defaults.fasterWhisper.image.tag }}
|
||||
imagePullPolicy: {{ .Values.defaults.fasterWhisper.image.pullPolicy }}
|
||||
env:
|
||||
- name: PUID
|
||||
value: "{{ .Values.defaults.fasterWhisper.env.PUID }}"
|
||||
- name: PGID
|
||||
value: "{{ .Values.defaults.fasterWhisper.env.PGID }}"
|
||||
- name: TZ
|
||||
value: "{{ .Values.defaults.fasterWhisper.env.TZ }}"
|
||||
- name: WHISPER_MODEL
|
||||
value: "{{ .Values.defaults.fasterWhisper.env.WHISPER_MODEL }}"
|
||||
- name: WHISPER_BEAM
|
||||
value: "{{ .Values.defaults.fasterWhisper.env.WHISPER_BEAM }}"
|
||||
- name: WHISPER_LANG
|
||||
value: "{{ .Values.defaults.fasterWhisper.env.WHISPER_LANG }}"
|
||||
ports:
|
||||
- containerPort: 10300
|
||||
volumeMounts:
|
||||
- mountPath: {{ .Values.defaults.fasterWhisper.volume.mountPath }}
|
||||
name: config
|
||||
{{- if .Values.nodeSelector }}
|
||||
nodeSelector:
|
||||
{{ toYaml .Values.nodeSelector | indent 8 }}
|
||||
{{- end }}
|
||||
volumes:
|
||||
- name: config
|
||||
persistentVolumeClaim:
|
||||
claimName: {{ .Values.defaults.fasterWhisper.volume.claimName }}
|
||||
|
||||
---
|
||||
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: {{ .Release.Name }}-piper
|
||||
spec:
|
||||
replicas: {{ .Values.defaults.replicaCount }}
|
||||
selector:
|
||||
matchLabels:
|
||||
app: piper
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: piper
|
||||
spec:
|
||||
containers:
|
||||
- name: piper
|
||||
image: {{ .Values.defaults.piper.image.repository }}:{{ .Values.defaults.piper.image.tag }}
|
||||
imagePullPolicy: {{ .Values.defaults.piper.image.pullPolicy }}
|
||||
env:
|
||||
- name: PUID
|
||||
value: "{{ .Values.defaults.piper.env.PUID }}"
|
||||
- name: PGID
|
||||
value: "{{ .Values.defaults.piper.env.PGID }}"
|
||||
- name: TZ
|
||||
value: "{{ .Values.defaults.piper.env.TZ }}"
|
||||
- name: PIPER_VOICE
|
||||
value: "{{ .Values.defaults.piper.env.PIPER_VOICE }}"
|
||||
- name: PIPER_LENGTH
|
||||
value: "{{ .Values.defaults.piper.env.PIPER_LENGTH }}"
|
||||
- name: PIPER_NOISE
|
||||
value: "{{ .Values.defaults.piper.env.PIPER_NOISE }}"
|
||||
- name: PIPER_NOISEW
|
||||
value: "{{ .Values.defaults.piper.env.PIPER_NOISEW }}"
|
||||
- name: PIPER_SPEAKER
|
||||
value: "{{ .Values.defaults.piper.env.PIPER_SPEAKER }}"
|
||||
- name: PIPER_PROCS
|
||||
value: "{{ .Values.defaults.piper.env.PIPER_PROCS }}"
|
||||
ports:
|
||||
- containerPort: 10200
|
||||
volumeMounts:
|
||||
- mountPath: {{ .Values.defaults.piper.volume.mountPath }}
|
||||
name: config
|
||||
volumes:
|
||||
- name: config
|
||||
persistentVolumeClaim:
|
||||
claimName: {{ .Values.defaults.piper.volume.claimName }}
|
||||
{{- if .Values.nodeSelector }}
|
||||
nodeSelector:
|
||||
{{ toYaml .Values.nodeSelector | indent 8 }}
|
||||
{{- end }}
|
||||
@@ -0,0 +1,25 @@
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: {{ .Values.defaults.fasterWhisper.volume.claimName }}
|
||||
spec:
|
||||
storageClassName: nfs-client
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: {{ .Values.defaults.fasterWhisper.volume.storage }}
|
||||
|
||||
---
|
||||
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: {{ .Values.defaults.piper.volume.claimName }}
|
||||
spec:
|
||||
storageClassName: nfs-client
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: {{ .Values.defaults.piper.volume.storage }}
|
||||
@@ -0,0 +1,25 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ .Release.Name }}-faster-whisper
|
||||
spec:
|
||||
type: {{ .Values.defaults.fasterWhisper.service.type }}
|
||||
ports:
|
||||
- port: {{ .Values.defaults.fasterWhisper.service.port }}
|
||||
targetPort: 10300
|
||||
selector:
|
||||
app: faster-whisper
|
||||
|
||||
---
|
||||
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ .Release.Name }}-piper
|
||||
spec:
|
||||
type: {{ .Values.defaults.piper.service.type }}
|
||||
ports:
|
||||
- port: {{ .Values.defaults.piper.service.port }}
|
||||
targetPort: 10200
|
||||
selector:
|
||||
app: piper
|
||||
Reference in New Issue
Block a user