mirror of
https://github.com/TeamPiped/Piped-Kubernetes.git
synced 2024-08-14 23:57:15 +00:00
It works :)
This commit is contained in:
parent
0a36471031
commit
00d7f2b0eb
7 changed files with 213 additions and 16 deletions
25
.github/workflows/release-charts.yaml
vendored
Normal file
25
.github/workflows/release-charts.yaml
vendored
Normal file
|
@ -0,0 +1,25 @@
|
|||
name: Release Charts
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
|
||||
jobs:
|
||||
release:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- name: Configure Git
|
||||
run: |
|
||||
git config user.name "$GITHUB_ACTOR"
|
||||
git config user.email "$GITHUB_ACTOR@users.noreply.github.com"
|
||||
|
||||
- name: Run chart-releaser
|
||||
uses: helm/chart-releaser-action@v1.1.0
|
||||
env:
|
||||
CR_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
|
@ -1,7 +1,14 @@
|
|||
---
|
||||
apiVersion: v2
|
||||
description: A chart to power Piped running on Kubernetes
|
||||
description: Piped is an alternative privacy-friendly YouTube frontend which is efficient by design.
|
||||
name: piped
|
||||
home: https://github.com/TeamPiped/Piped-Kubernetes
|
||||
sources:
|
||||
- https://github.com/TeamPiped/Piped
|
||||
- https://github.com/TeamPiped/Piped-Backend
|
||||
- https://github.com/TeamPiped/piped-proxy
|
||||
keywords:
|
||||
- streaming
|
||||
version: 0.0.1
|
||||
appVersion: latest
|
||||
maintainers:
|
||||
|
@ -11,3 +18,7 @@ dependencies:
|
|||
- name: common
|
||||
repository: https://bjw-s.github.io/helm-charts
|
||||
version: 0.1.0
|
||||
- name: postgresql
|
||||
repository: https://charts.bitnami.com/bitnami
|
||||
version: 12.2.0
|
||||
condition: postgresql.enabled
|
||||
|
|
56
charts/apps/piped/templates/backend/configmap.yaml
Normal file
56
charts/apps/piped/templates/backend/configmap.yaml
Normal file
|
@ -0,0 +1,56 @@
|
|||
---
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: {{ include "backend.names.fullname" . }}-config
|
||||
{{- with (merge (.Values.backend.labels | default dict) (include "common.labels" $ | fromYaml)) }}
|
||||
labels: {{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
{{- with (merge (.Values.backend.annotations | default dict) (include "common.annotations" $ | fromYaml)) }}
|
||||
annotations: {{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
data:
|
||||
config.properties: |
|
||||
PORT: {{ .Values.backend.config.PORT | default (8080) }}
|
||||
HTTP_WORKERS: {{ .Values.backend.config.HTTP_WORKERS | default (2) }}
|
||||
{{- if .Values.backend.config.HTTP_PROXY }}
|
||||
HTTP_PROXY: {{ .Values.backend.config.HTTP_PROXY }}
|
||||
{{ end }}
|
||||
{{- if .Values.backend.config.PROXY_PART }}
|
||||
PROXY_PART: {{.Values.backend.config.PROXY_PART }}
|
||||
{{- else if .Values.ingress.ytproxy.enabled}}
|
||||
PROXY_PART: {{ index (index .Values.ingress.ytproxy.hosts 0) "host" }}
|
||||
{{- else }}
|
||||
{{- fail "PROXY_PART needs to be set in config values or ytproxy ingress must be enabled."}}
|
||||
{{ end }}
|
||||
{{- if .Values.backend.config.API_URL }}
|
||||
API_URL: {{ .Values.backend.config.API_URL }}
|
||||
{{- else if .Values.ingress.backend.enabled }}
|
||||
API_URL: {{ index (index .Values.ingress.backend.hosts 0) "host" }}
|
||||
{{- else }}
|
||||
{{- fail "API_URL needs to be set in config values or backend ingress must be enabled."}}
|
||||
{{ end }}
|
||||
{{- if .Values.backend.config.FRONTEND_URL }}
|
||||
FRONTEND_URL: {{.Values.backend.config.FRONTEND_URL }}
|
||||
{{- else if .Values.ingress.main.enabled }}
|
||||
FRONTEND_URL: {{ index (index .Values.ingress.main.hosts 0) "host" }}
|
||||
{{- else }}
|
||||
{{- fail "FRONTEND_URL needs to be set in config values or main ingress must be enabled."}}
|
||||
{{ end }}
|
||||
COMPROMISED_PASSWORD_CHECK: {{ .Values.backend.config.COMPROMISED_PASSWORD_CHECK | default true }}
|
||||
DISABLE_REGISTRATION: {{ .Values.backend.config.DISABLE_REGISTRATION | default false }}
|
||||
FEED_RETENTION: {{ .Values.backend.config.DISABLE_REGISTRATION | int | default 30 }}
|
||||
{{- if .Values.backend.config.database }}
|
||||
hibernate.connection.url: {{.Values.backend.config.database.connection_url }}
|
||||
hibernate.connection.driver_class: {{.Values.backend.config.database.driver_class }}
|
||||
hibernate.dialect: {{.Values.backend.config.database.dialect }}
|
||||
hibernate.connection.username: {{.Values.backend.config.database.username }}
|
||||
hibernate.connection.password: {{.Values.backend.config.database.password }}
|
||||
{{- else if .Values.postgresql.enabled }}
|
||||
hibernate.connection.url: jdbc:postgresql://piped-postgresql/{{ .Values.postgresql.auth.database}}
|
||||
hibernate.connection.driver_class: org.postgresql.Driver
|
||||
hibernate.dialect: org.hibernate.dialect.PostgreSQLDialect
|
||||
hibernate.connection.username: {{.Values.postgresql.auth.username }}
|
||||
hibernate.connection.password: {{.Values.postgresql.auth.password }}
|
||||
{{ end }}
|
||||
SENTRY_DSN:
|
|
@ -16,7 +16,7 @@
|
|||
{{- if kindIs "string" . }}
|
||||
- {{ . }}
|
||||
{{- else }}
|
||||
{{ toYaml . | nindent 4 }}
|
||||
{{- toYaml . | nindent 4 }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- with .Values.backend.securityContext }}
|
||||
|
@ -48,7 +48,11 @@
|
|||
name: {{ include "backend.names.fullname" . }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- include "backend.controller.probes" . | trim | nindent 2 }}
|
||||
ports:
|
||||
{{- include "backend.controller.ports" . | trim | nindent 4 }}
|
||||
{{- with (include "backend.controller.volumeMounts" . | trim) }}
|
||||
volumeMounts:
|
||||
{{- nindent 4 . }}
|
||||
{{- end }}
|
||||
{{- include "backend.controller.probes" . | trim | nindent 2 }}
|
||||
{{- end -}}
|
60
charts/apps/piped/templates/backend/lib/_volumemounts.tpl
Normal file
60
charts/apps/piped/templates/backend/lib/_volumemounts.tpl
Normal file
|
@ -0,0 +1,60 @@
|
|||
{{/* Volumes included by the controller */}}
|
||||
{{- define "backend.controller.volumeMounts" -}}
|
||||
{{- range $persistenceIndex, $persistenceItem := .Values.persistence }}
|
||||
{{- if $persistenceItem.enabled -}}
|
||||
{{- if kindIs "slice" $persistenceItem.subPath -}}
|
||||
{{- if $persistenceItem.mountPath -}}
|
||||
{{- fail (printf "Cannot use persistence.mountPath with a subPath list (%s)" $persistenceIndex) }}
|
||||
{{- end -}}
|
||||
{{- range $subPathIndex, $subPathItem := $persistenceItem.subPath }}
|
||||
- name: {{ $persistenceIndex }}
|
||||
subPath: {{ required "subPaths as a list of maps require a path field" $subPathItem.path }}
|
||||
mountPath: {{ required "subPaths as a list of maps require an explicit mountPath field" $subPathItem.mountPath }}
|
||||
{{- with $subPathItem.readOnly }}
|
||||
readOnly: {{ . }}
|
||||
{{- end }}
|
||||
{{- with $subPathItem.mountPropagation }}
|
||||
mountPropagation: {{ . }}
|
||||
{{- end }}
|
||||
{{- end -}}
|
||||
{{- else -}}
|
||||
{{/* Set the default mountPath to /<name_of_the_peristence_item> */}}
|
||||
{{- $mountPath := (printf "/%v" $persistenceIndex) -}}
|
||||
{{- if eq "hostPath" (default "pvc" $persistenceItem.type) -}}
|
||||
{{- $mountPath = $persistenceItem.hostPath -}}
|
||||
{{- end -}}
|
||||
{{/* Use the specified mountPath if provided */}}
|
||||
{{- with $persistenceItem.mountPath -}}
|
||||
{{- $mountPath = . -}}
|
||||
{{- end }}
|
||||
{{- if ne $mountPath "-" }}
|
||||
- name: {{ $persistenceIndex }}
|
||||
mountPath: {{ $mountPath }}
|
||||
{{- with $persistenceItem.subPath }}
|
||||
subPath: {{ . }}
|
||||
{{- end }}
|
||||
{{- with $persistenceItem.readOnly }}
|
||||
readOnly: {{ . }}
|
||||
{{- end }}
|
||||
{{- with $persistenceItem.mountPropagation }}
|
||||
mountPropagation: {{ . }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end -}}
|
||||
{{- end -}}
|
||||
{{- end }}
|
||||
|
||||
{{- if eq .Values.controller.type "statefulset" }}
|
||||
{{- range $index, $vct := .Values.volumeClaimTemplates }}
|
||||
- mountPath: {{ $vct.mountPath }}
|
||||
name: {{ $vct.name }}
|
||||
{{- if $vct.subPath }}
|
||||
subPath: {{ $vct.subPath }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
- name: config-volume
|
||||
mountPath: /app/config.properties
|
||||
subPath: config.properties
|
||||
readOnly: true
|
||||
{{- end -}}
|
|
@ -65,4 +65,7 @@ Volumes included by the controller.
|
|||
{{- end }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
- name: config-volume
|
||||
configMap:
|
||||
name: {{ include "backend.names.fullname" . }}-config
|
||||
{{- end }}
|
|
@ -78,6 +78,37 @@ backend:
|
|||
- -jar
|
||||
- /app/piped.jar
|
||||
|
||||
# command: "/bin/sh"
|
||||
# args:
|
||||
# - -c
|
||||
# - sleep infinity
|
||||
|
||||
# If the hostnames are not set for backend, proxy and API, they will be automatically fetched from their ingresses.
|
||||
config:
|
||||
#PORT: 8080
|
||||
# HTTP_WORKERS: 2
|
||||
#PROXY_PART: https://PROXY_HOSTNAME
|
||||
# Outgoing HTTP Proxy - eg: 127.0.0.1:8118
|
||||
#HTTP_PROXY: 127.0.0.1:8118
|
||||
# Captcha Parameters
|
||||
#CAPTCHA_BASE_URL: https://api.capmonster.cloud/
|
||||
#CAPTCHA_API_KEY: INSERT_HERE
|
||||
#API_URL: https://BACKEND_HOSTNAME
|
||||
#FRONTEND_URL: https://FRONTEND_HOSTNAME
|
||||
# Enable haveibeenpwned compromised password API
|
||||
COMPROMISED_PASSWORD_CHECK: true
|
||||
# Disable Registration
|
||||
DISABLE_REGISTRATION: false
|
||||
# Feed Retention Time in Days
|
||||
FEED_RETENTION: 30
|
||||
#database:
|
||||
# connection_url: jdbc:postgresql://postgres:5432/piped
|
||||
# driver_class: org.postgresql.Driver
|
||||
# dialect: org.hibernate.dialect.PostgreSQLDialect
|
||||
# username: piped
|
||||
# password: changeme
|
||||
|
||||
|
||||
image:
|
||||
# -- image repository
|
||||
repository: 1337kavin/piped
|
||||
|
@ -87,8 +118,6 @@ backend:
|
|||
# -- image pull policy
|
||||
pullPolicy: IfNotPresent
|
||||
|
||||
|
||||
|
||||
ytproxy:
|
||||
enabled: true
|
||||
service:
|
||||
|
@ -115,36 +144,45 @@ ytproxy:
|
|||
# -- image pull policy
|
||||
pullPolicy: IfNotPresent
|
||||
|
||||
|
||||
ingress:
|
||||
main:
|
||||
enabled: false
|
||||
enabled: true
|
||||
primary: false
|
||||
hosts:
|
||||
- host: piped.example.com
|
||||
- host: piped.video
|
||||
paths:
|
||||
- path: "/"
|
||||
tls: []
|
||||
|
||||
backend:
|
||||
enabled: false
|
||||
enabled: true
|
||||
ingressClassName: nginx
|
||||
primary: false
|
||||
hosts:
|
||||
- host: pipedapi.example.com
|
||||
- host: pipedapi.piped.video
|
||||
paths:
|
||||
- path: "/"
|
||||
tls: []
|
||||
|
||||
ytproxy:
|
||||
enabled: false
|
||||
enabled: true
|
||||
ingressClassName: nginx
|
||||
primary: false
|
||||
hosts:
|
||||
- host: ytproxy.chart-foo.local
|
||||
- host: ytproxy.piped.video
|
||||
paths:
|
||||
- path: "/"
|
||||
tls: []
|
||||
|
||||
|
||||
# See options from https://artifacthub.io/packages/helm/bitnami/postgresql#parameters
|
||||
postgresql:
|
||||
enabled: true
|
||||
image:
|
||||
tag: 11.19.0-debian-11-r4
|
||||
auth:
|
||||
database: piped
|
||||
username: piped
|
||||
password: changemepiped
|
||||
|
||||
# -- Probe configuration
|
||||
# -- [[ref]](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/)
|
||||
|
@ -154,7 +192,7 @@ probes:
|
|||
# @default -- See below
|
||||
liveness:
|
||||
# -- Enable the liveness probe
|
||||
enabled: true
|
||||
enabled: false
|
||||
# -- Set this to `true` if you wish to specify your own livenessProbe
|
||||
custom: false
|
||||
# -- The spec field contains the values for the default livenessProbe.
|
||||
|
@ -170,7 +208,7 @@ probes:
|
|||
# @default -- See below
|
||||
readiness:
|
||||
# -- Enable the readiness probe
|
||||
enabled: true
|
||||
enabled: false
|
||||
# -- Set this to `true` if you wish to specify your own readinessProbe
|
||||
custom: false
|
||||
# -- The spec field contains the values for the default readinessProbe.
|
||||
|
@ -186,7 +224,7 @@ probes:
|
|||
# @default -- See below
|
||||
startup:
|
||||
# -- Enable the startup probe
|
||||
enabled: true
|
||||
enabled: false
|
||||
# -- Set this to `true` if you wish to specify your own startupProbe
|
||||
custom: false
|
||||
# -- The spec field contains the values for the default startupProbe.
|
||||
|
|
Loading…
Reference in a new issue