🚀 stalwart

This commit is contained in:
auricom
2023-08-29 21:50:13 +02:00
parent 86761ab564
commit 2ac497e1ad
5 changed files with 129 additions and 0 deletions

View File

@@ -54,6 +54,7 @@ resources:
- ./semaphore/ks.yaml - ./semaphore/ks.yaml
- ./sharry/ks.yaml - ./sharry/ks.yaml
- ./sonarr/ks.yaml - ./sonarr/ks.yaml
- ./stalwart/ks.yaml
- ./smtp-relay/ks.yaml - ./smtp-relay/ks.yaml
- ./tandoor/ks.yaml - ./tandoor/ks.yaml
- ./theme-park/ks.yaml - ./theme-park/ks.yaml

View File

@@ -0,0 +1,57 @@
---
# yaml-language-server: $schema=https://raw.githubusercontent.com/fluxcd-community/flux2-schemas/main/helmrelease-helm-v2beta1.json
apiVersion: helm.toolkit.fluxcd.io/v2beta1
kind: HelmRelease
metadata:
name: &app stalwart
namespace: default
spec:
interval: 30m
chart:
spec:
chart: app-template
version: 1.5.1
sourceRef:
kind: HelmRepository
name: bjw-s
namespace: flux-system
maxHistory: 2
install:
createNamespace: true
remediation:
retries: 3
upgrade:
cleanupOnFail: true
remediation:
retries: 3
uninstall:
keepHistory: false
values:
image:
repository: stalwartlabs/jmap-server
tag: v0.3.5
service:
main:
ports:
http:
port: 8080
smtp:
port: 587
mail:
port: 4190
probes:
liveness: &probes
enabled: false
readiness: *probes
startup: *probes
persistence:
config:
enabled: true
existingClaim: stalwart-config
mountPath: /opt/stalwart-mail
resources:
requests:
cpu: 100m
memory: 256Mi
limits:
memory: 512Mi

View File

@@ -0,0 +1,9 @@
---
# yaml-language-server: $schema=https://raw.githubusercontent.com/SchemaStore/schemastore/master/src/schemas/json/kustomization.json
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: default
resources:
- ./helmrelease.yaml
- ./volsync.yaml
- ./volume.yaml

View File

@@ -0,0 +1,45 @@
---
# yaml-language-server: $schema=https://kubernetes-schemas.devbu.io/external-secrets.io/externalsecret_v1beta1.json
apiVersion: external-secrets.io/v1beta1
kind: ExternalSecret
metadata:
name: stalwart-restic
namespace: default
spec:
secretStoreRef:
kind: ClusterSecretStore
name: onepassword-connect
target:
name: stalwart-restic-secret
creationPolicy: Owner
template:
engineVersion: v2
data:
RESTIC_REPOSITORY: '{{ .REPOSITORY_TEMPLATE }}/stalwart'
RESTIC_PASSWORD: '{{ .RESTIC_PASSWORD }}'
AWS_ACCESS_KEY_ID: '{{ .AWS_ACCESS_KEY_ID }}'
AWS_SECRET_ACCESS_KEY: '{{ .AWS_SECRET_ACCESS_KEY }}'
dataFrom:
- extract:
key: volsync-restic-template
---
# yaml-language-server: $schema=https://kubernetes-schemas.devbu.io/volsync.backube/replicationsource_v1alpha1.json
apiVersion: volsync.backube/v1alpha1
kind: ReplicationSource
metadata:
name: stalwart
namespace: default
spec:
sourcePVC: stalwart-config
trigger:
schedule: "0 7 * * *"
restic:
copyMethod: Snapshot
pruneIntervalDays: 7
repository: stalwart-restic-secret
cacheCapacity: 2Gi
volumeSnapshotClassName: csi-ceph-blockpool
storageClassName: rook-ceph-block
retain:
daily: 7
within: 3d

View File

@@ -0,0 +1,17 @@
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: stalwart-config
namespace: default
labels:
app.kubernetes.io/name: &name stalwart
app.kubernetes.io/instance: *name
snapshot.home.arpa/enabled: "true"
spec:
accessModes:
- ReadWriteOnce
storageClassName: rook-ceph-block
resources:
requests:
storage: 20Gi