feat(bridge): Add telegram

This commit is contained in:
Tanguy Herbron 2024-12-16 15:26:19 +01:00
parent 75e42d8c56
commit 03a167a13f
7 changed files with 138 additions and 0 deletions

View File

@ -3,6 +3,7 @@ kind: Kustomization
resources: resources:
- ./signal - ./signal
- ./telegram
- ./messenger - ./messenger
- ./instagram - ./instagram
- ./whatsapp - ./whatsapp

View File

@ -0,0 +1,14 @@
#!/bin/bash
echo "Checking if $TELEGRAM_DB database exists..."
if psql -lqt | cut -d \| -f 1 | grep -qw $TELEGRAM_DB; then
echo "Database exists, skipping creation"
else
echo "Database does not exist, creating..."
createdb $TELEGRAM_DB
createuser $TELEGRAM_USER
psql -c "ALTER USER $TELEGRAM_USER WITH ENCRYPTED PASSWORD '$TELEGRAM_PASSWORD';"
psql -c "GRANT ALL PRIVILEGES ON DATABASE $TELEGRAM_DB TO $TELEGRAM_USER;"
psql -c "ALTER DATABASE $TELEGRAM_DB OWNER TO $TELEGRAM_USER;"
fi

View File

@ -0,0 +1,46 @@
apiVersion: batch/v1
kind: Job
metadata:
name: telegram-db-init
namespace: synapse
spec:
template:
spec:
containers:
- name: telegram-db-init
image: postgres:15.10
command: ["/bin/bash", "/data/create_db.sh"]
env:
- name: PGHOST
value: synapse-db-rw.synapse.svc.cluster.local
- name: PGUSER
valueFrom:
secretKeyRef:
name: synapse-db-superuser
key: username
- name: PGPASSWORD
valueFrom:
secretKeyRef:
name: synapse-db-superuser
key: password
- name: TELEGRAM_USER
valueFrom:
secretKeyRef:
name: mautrix-telegram-db
key: username
- name: TELEGRAM_PASSWORD
valueFrom:
secretKeyRef:
name: mautrix-telegram-db
key: password
- name: TELEGRAM_DB
value: telegram
volumeMounts:
- name: create-db
mountPath: /data
volumes:
- name: create-db
configMap:
name: telegram-db-creation
restartPolicy: Never
backoffLimit: 4

View File

@ -0,0 +1,18 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: synapse
resources:
- service.yaml
- statefulset.yaml
- job.yaml
generatorOptions:
labels:
app: telegram
configMapGenerator:
- name: telegram-db-creation
behavior: create
files:
- create_db.sh

View File

@ -0,0 +1,16 @@
apiVersion: v1
kind: Service
metadata:
name: telegram
namespace: synapse
labels:
app.kubernetes.io/name: telegram
spec:
ports:
- name: http
port: 29317
protocol: TCP
targetPort: 29317
selector:
app: telegram
publishNotReadyAddresses: true

View File

@ -0,0 +1,37 @@
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: telegram
namespace: synapse
spec:
selector:
matchLabels:
app: telegram
serviceName: telegram
replicas: 1
minReadySeconds: 10
template:
metadata:
labels:
app: telegram
spec:
terminationGracePeriodSeconds: 10
containers:
- name: telegram
image: dock.mau.dev/mautrix/telegram:v0.15.2
command: [
"/usr/bin/python3",
"-m", "mautrix_telegram",
"--config", "/data/config.yaml",
"--no-update",
]
ports:
- containerPort: 29328
volumeMounts:
- mountPath: "/data/config.yaml"
name: telegram-config-file
subPath: config.yaml
volumes:
- name: telegram-config-file
secret:
secretName: telegram-secret-config

View File

@ -36,6 +36,9 @@ spec:
- mountPath: "/data/signal.yaml" - mountPath: "/data/signal.yaml"
name: signal-secret-registration name: signal-secret-registration
subPath: signal.yaml subPath: signal.yaml
- mountPath: "/data/telegram.yaml"
name: telegram-secret-registration
subPath: telegram.yaml
- mountPath: "/data/messenger.yaml" - mountPath: "/data/messenger.yaml"
name: messenger-secret-registration name: messenger-secret-registration
subPath: messenger.yaml subPath: messenger.yaml
@ -61,6 +64,9 @@ spec:
- name: signal-secret-registration - name: signal-secret-registration
secret: secret:
secretName: signal-secret-registration secretName: signal-secret-registration
- name: telegram-secret-registration
secret:
secretName: telegram-secret-registration
- name: messenger-secret-registration - name: messenger-secret-registration
secret: secret:
secretName: messenger-secret-registration secretName: messenger-secret-registration