This commit is contained in:
bel
2021-09-14 06:41:25 -06:00
commit 77c332040f
9 changed files with 334 additions and 0 deletions

52
synapse-matrix/Dockerfile Executable file
View File

@@ -0,0 +1,52 @@
### BUILDER
FROM ubuntu:18.10 as builder
RUN apt -y update \
&& apt -y install gcc
COPY ./pause /pause
RUN cd /pause && gcc ./main.c -o pauser
### RUNNER
FROM ubuntu:18.10
COPY --from=builder /pause/pauser /pauser
### POSTGRES
RUN groupadd postgres && useradd -d /home/postgres -ms /bin/bash -g postgres -G sudo postgres
RUN apt -y update \
&& apt -y install \
curl \
rsync \
cron \
postgresql postgresql-contrib \
&& mkdir -p /mnt/save
USER postgres
RUN service postgresql start && sleep 10 \
&& psql --command "CREATE USER bel WITH SUPERUSER PASSWORD 'letme123in';" \
&& createdb -O bel letme123in \
&& psql --command "CREATE DATABASE db;" \
&& psql --command "GRANT ALL PRIVILEGES ON DATABASE db TO bel;" \
&& service postgresql stop && sleep 10
ENV DATABASE_URL=postgres://bel:letme123in@localhost/db?sslmode=disable
USER root
### Synapse/matrix
RUN wget -qO - https://matrix.org/packages/debian/repo-key.asc \
| apt-key add - \
&& add-apt-repository https://matrix.org/packages/debian/ \
&& apt install -y matrix-synapse
### CRON BACKUPS
RUN true \
&& echo 'service postgresql stop && sleep 5 && b=$(date +%Y%m%d%H) && mkdir -p /mnt/save/$b && rsync -avzP --delete /var/lib/postgresql/10/main/ /mnt/save/$b/ && service postgresql start' > /backup.sh \
&& echo 'service postgresql stop && sleep 5 && b=$(find /mnt/save -mindepth 1 -maxdepth 1 | sort | tail -n 1); if [ -n "$b" ]; then rsync -avzP --delete "${b%/}/" /var/lib/postgresql/10/main/; fi && chown -R postgres /var/lib/postgresql && chmod -R 0700 /var/lib/postgresql && service postgresql start;' > /restore.sh \
&& echo '0 4,8,12,16,20 * * * bash /backup.sh >> /var/log/cronj.log 2>&1' > /etc/cron.d/backups \
&& echo '' >> /etc/cron.d/backups \
&& chmod 0644 /etc/cron.d/backups \
&& touch /var/log/cronj.log
ENTRYPOINT \
bash /restore.sh \
&& service postgresql start \
&& sleep 10 \
&& miniflux & exec /pauser

View File

@@ -0,0 +1,57 @@
FROM ubuntu:18.10 as builder
RUN apt -y update \
&& apt -y install gcc
COPY ./pause /pause
RUN cd /pause && gcc ./main.c -o pauser
FROM ubuntu:18.10
RUN groupadd postgres && useradd -d /home/postgres -ms /bin/bash -g postgres -G sudo postgres
RUN apt -y update \
&& apt -y install \
curl \
rsync \
cron \
postgresql postgresql-contrib \
&& curl -L \
https://github.com/miniflux/miniflux/releases/download/2.0.12/miniflux_2.0.12_amd64.deb \
> /miniflux.deb \
&& dpkg -i /miniflux.deb \
&& mkdir -p /mnt/save
USER postgres
RUN service postgresql start && sleep 10 \
&& psql --command "CREATE USER mini WITH SUPERUSER PASSWORD 'pwd';" \
&& createdb -O mini pwd \
&& psql --command "CREATE DATABASE miniflux;" \
&& psql --command "GRANT ALL PRIVILEGES ON DATABASE miniflux TO mini;" \
&& service postgresql stop && sleep 10
ENV DATABASE_URL=postgres://mini:pwd@localhost/miniflux?sslmode=disable
ENV LISTEN_ADDR=:8032
ENV RUN_MIGRATIONS=1
ENV CREATE_ADMIN=1
ENV ADMIN_USERNAME=username
ENV ADMIN_PASSWORD=password
ENV RUN_MIGRATIONS=0
ENV CREATE_ADMIN=0
COPY --from=builder /pause/pauser /pauser
USER root
### CRON BACKUPS
RUN true \
&& echo 'service postgresql stop && sleep 5 && b=$(date +%Y%m%d%H) && mkdir -p /mnt/save/$b && rsync -avzP --delete /var/lib/postgresql/10/main/ /mnt/save/$b/ && service postgresql start' > /backup.sh \
&& echo 'service postgresql stop && sleep 5 && b=$(find /mnt/save -mindepth 1 -maxdepth 1 | sort | tail -n 1); if [ -n "$b" ]; then rsync -avzP --delete "${b%/}/" /var/lib/postgresql/10/main/; fi && chown -R postgres /var/lib/postgresql && chmod -R 0700 /var/lib/postgresql && service postgresql start;' > /restore.sh \
&& echo '0 4,8,12,16,20 * * * bash /backup.sh >> /var/log/cronj.log 2>&1' > /etc/cron.d/backups \
&& echo '' >> /etc/cron.d/backups \
&& chmod 0644 /etc/cron.d/backups \
&& touch /var/log/cronj.log
ENTRYPOINT \
bash /restore.sh \
&& service postgresql start \
&& sleep 10 \
&& miniflux -migrate \
&& miniflux -create-admin \
&& miniflux \
& exec /pauser

20
synapse-matrix/pause/main.c Executable file
View File

@@ -0,0 +1,20 @@
#include <stdio.h>
#include <signal.h>
#include <stdlib.h>
int main() {
int stat;
int sig;
sigset_t set;
sigemptyset(&set);
printf("add signal SIGINT: %i\n", sigaddset(&set, SIGINT));
printf("add signal SIGKILL: %i\n", sigaddset(&set, SIGKILL));
printf("add signal SIGTERM: %i\n", sigaddset(&set, SIGTERM));
sigprocmask(SIG_BLOCK, &set, NULL);
printf("Waiting...\n");
stat = sigwait(&set, &sig);
printf("Wait complete: %i (%i)\n", sig, stat);
printf("Stopped postgres: %i\n", system("service postgresql stop && sleep 5"));
printf("Saved postgres: %i\n", system("bash /backup.sh"));
return 0;
}

9
synapse-matrix/riot.sh Executable file
View File

@@ -0,0 +1,9 @@
#! /bin/bash
img="avhost/docker-matrix-riot:v1.0.0"
docker run \
--rm -it \
-v $(pwd)/riot:/data \
-p 8765:8765 \
$img

17
synapse-matrix/synapse.sh Executable file
View File

@@ -0,0 +1,17 @@
#! /bin/bash
img="avhost/docker-matrix:v0.34.1.1"
docker pull $img
docker run -v $(pwd)/synapse:/data --rm -it -e SERVER_NAME=localhost -e REPORT_STATS=no $img generate
sudo chmod 777 synapse/homeserver.yaml
f="$(mktemp)"
sed 's/enable_registration:.*/enable_registration: True/' synapse/homeserver.yaml > "$f" && sudo mv "$f" synapse/homeserver.yaml
docker run --rm -it \
-p 8443:8443 \
-p 8008:8008 \
-p 3478:3478 \
-v $(pwd)/synapse:/data $img start

View File

@@ -0,0 +1,42 @@
FROM ubuntu:18.10 as builder
RUN apt -y update \
&& apt -y install gcc
COPY ./pause /pause
RUN cd /pause && gcc ./main.c -o pauser
FROM ubuntu:18.10
RUN groupadd postgres && useradd -d /home/postgres -ms /bin/bash -g postgres -G sudo postgres
RUN apt -y update \
&& apt -y install \
curl \
rsync \
cron \
postgresql postgresql-contrib \
&& mkdir -p /mnt/save
USER postgres
RUN service postgresql start && sleep 10 \
&& psql --command "CREATE USER bel WITH SUPERUSER PASSWORD 'letme123in';" \
&& createdb -O bel letme123in \
&& psql --command "CREATE DATABASE db;" \
&& psql --command "GRANT ALL PRIVILEGES ON DATABASE db TO bel;" \
&& service postgresql stop && sleep 10
ENV DATABASE_URL=postgres://bel:letme123in@localhost/db?sslmode=disable
COPY --from=builder /pause/pauser /pauser
USER root
### CRON BACKUPS
RUN true \
&& echo 'service postgresql stop && sleep 5 && b=$(date +%Y%m%d%H) && mkdir -p /mnt/save/$b && rsync -avzP --delete /var/lib/postgresql/10/main/ /mnt/save/$b/ && service postgresql start' > /backup.sh \
&& echo 'service postgresql stop && sleep 5 && b=$(find /mnt/save -mindepth 1 -maxdepth 1 | sort | tail -n 1); if [ -n "$b" ]; then rsync -avzP --delete "${b%/}/" /var/lib/postgresql/10/main/; fi && chown -R postgres /var/lib/postgresql && chmod -R 0700 /var/lib/postgresql && service postgresql start;' > /restore.sh \
&& echo '0 4,8,12,16,20 * * * bash /backup.sh >> /var/log/cronj.log 2>&1' > /etc/cron.d/backups \
&& echo '' >> /etc/cron.d/backups \
&& chmod 0644 /etc/cron.d/backups \
&& touch /var/log/cronj.log
ENTRYPOINT \
bash /restore.sh \
&& service postgresql start \
&& sleep 10 \
&& miniflux & exec /pauser