grampsweb

This commit is contained in:
Alexandre
2024-12-28 11:55:07 +01:00
parent d8346dc651
commit 693b2736d1
11 changed files with 366 additions and 0 deletions

1
grampsweb/CHANGELOG.md Normal file
View File

@@ -0,0 +1 @@
- First version

123
grampsweb/Dockerfile Normal file
View File

@@ -0,0 +1,123 @@
#============================#
# ALEXBELGIUM'S DOCKERFILE #
#============================#
# _.------.
# _.-` ('>.-`"""-.
# '.--'` _'` _ .--.)
# -' '-.-';` `
# ' - _.' ``'--.
# '---` .-'""`
# /`
#=== Home Assistant Addon ===#
#################
# 1 Build Image #
#################
ARG BUILD_VERSION
ARG BUILD_FROM
FROM ${BUILD_FROM}
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
##################
# 2 Modify Image #
##################
# Set S6 wait time
ENV S6_CMD_WAIT_FOR_SERVICES=1 \
S6_CMD_WAIT_FOR_SERVICES_MAXTIME=0 \
S6_SERVICES_GRACETIME=0
- gramps_users:/app/users # persist user database
- gramps_index:/app/indexdir # persist search index
- gramps_thumb_cache:/app/thumbnail_cache # persist thumbnails
- gramps_cache:/app/cache # persist export and report caches
- gramps_secret:/app/secret # persist flask secret
- gramps_db:/root/.gramps/grampsdb # persist Gramps database
- gramps_media:/app/media # persist media files
- gramps_tmp:/tmp
##################
# 3 Install apps #
##################
# Add rootfs
COPY rootfs/ /
# Uses /bin for compatibility purposes
# hadolint ignore=DL4005
RUN if [ ! -f /bin/sh ] && [ -f /usr/bin/sh ]; then ln -s /usr/bin/sh /bin/sh; fi && \
if [ ! -f /bin/bash ] && [ -f /usr/bin/bash ]; then ln -s /usr/bin/bash /bin/bash; fi
# Modules
ARG MODULES=""
# Automatic modules download
ADD "https://raw.githubusercontent.com/alexbelgium/hassio-addons/master/.templates/ha_automodules.sh" "/ha_automodules.sh"
RUN chmod 744 /ha_automodules.sh && /ha_automodules.sh "$MODULES" && rm /ha_automodules.sh
# Manual apps
ENV PACKAGES="sudo redis nginx"
# Automatic apps & bashio
ADD "https://raw.githubusercontent.com/alexbelgium/hassio-addons/master/.templates/ha_autoapps.sh" "/ha_autoapps.sh"
RUN chmod 744 /ha_autoapps.sh && /ha_autoapps.sh "$PACKAGES" && rm /ha_autoapps.sh
################
# 4 Entrypoint #
################
# Add entrypoint
ENV S6_STAGE2_HOOK=/ha_entrypoint.sh
ADD "https://raw.githubusercontent.com/alexbelgium/hassio-addons/master/.templates/ha_entrypoint.sh" "/ha_entrypoint.sh"
# Entrypoint modifications
ADD "https://raw.githubusercontent.com/alexbelgium/hassio-addons/master/.templates/ha_entrypoint_modif.sh" "/ha_entrypoint_modif.sh"
RUN chmod 777 /ha_entrypoint.sh /ha_entrypoint_modif.sh && /ha_entrypoint_modif.sh && rm /ha_entrypoint_modif.sh
ENTRYPOINT [ "/usr/bin/env" ]
CMD [ "/ha_entrypoint.sh" ]
############
# 5 Labels #
############
ARG BUILD_ARCH
ARG BUILD_DATE
ARG BUILD_DESCRIPTION
ARG BUILD_NAME
ARG BUILD_REF
ARG BUILD_REPOSITORY
ARG BUILD_VERSION
LABEL \
io.hass.name="${BUILD_NAME}" \
io.hass.description="${BUILD_DESCRIPTION}" \
io.hass.arch="${BUILD_ARCH}" \
io.hass.type="addon" \
io.hass.version=${BUILD_VERSION} \
maintainer="alexbelgium (https://github.com/alexbelgium)" \
org.opencontainers.image.title="${BUILD_NAME}" \
org.opencontainers.image.description="${BUILD_DESCRIPTION}" \
org.opencontainers.image.vendor="Home Assistant Add-ons" \
org.opencontainers.image.authors="alexbelgium (https://github.com/alexbelgium)" \
org.opencontainers.image.licenses="MIT" \
org.opencontainers.image.url="https://github.com/alexbelgium" \
org.opencontainers.image.source="https://github.com/${BUILD_REPOSITORY}" \
org.opencontainers.image.documentation="https://github.com/${BUILD_REPOSITORY}/blob/main/README.md" \
org.opencontainers.image.created=${BUILD_DATE} \
org.opencontainers.image.revision=${BUILD_REF} \
org.opencontainers.image.version=${BUILD_VERSION}
#################
# 6 Healthcheck #
#################
ENV HEALTH_PORT="8080" \
HEALTH_URL=""
HEALTHCHECK \
--interval=5s \
--retries=5 \
--start-period=30s \
--timeout=25s \
CMD curl --fail "http://127.0.0.1:${HEALTH_PORT}${HEALTH_URL}" &>/dev/null || exit 1

1
grampsweb/README.md Normal file
View File

@@ -0,0 +1 @@
# Home assistant add-on: grampsweb

66
grampsweb/apparmor.txt Normal file
View File

@@ -0,0 +1,66 @@
#include <tunables/global>
profile grampsweb_addon flags=(attach_disconnected,mediate_deleted) {
#include <abstractions/base>
capability,
file,
signal,
mount,
umount,
remount,
network udp,
network tcp,
network dgram,
network stream,
network inet,
network inet6,
network netlink raw,
network unix dgram,
capability setgid,
capability setuid,
capability sys_admin,
capability dac_read_search,
# capability dac_override,
# capability sys_rawio,
# S6-Overlay
/init ix,
/run/{s6,s6-rc*,service}/** ix,
/package/** ix,
/command/** ix,
/run/{,**} rwk,
/dev/tty rw,
/bin/** ix,
/usr/bin/** ix,
/usr/lib/bashio/** ix,
/etc/s6/** rix,
/run/s6/** rix,
/etc/services.d/** rwix,
/etc/cont-init.d/** rwix,
/etc/cont-finish.d/** rwix,
/init rix,
/var/run/** mrwkl,
/var/run/ mrwkl,
/dev/i2c-1 mrwkl,
# Files required
/dev/fuse mrwkl,
/dev/sda1 mrwkl,
/dev/sdb1 mrwkl,
/dev/nvme0 mrwkl,
/dev/nvme1 mrwkl,
/dev/mmcblk0p1 mrwkl,
/dev/* mrwkl,
/tmp/** mrkwl,
# Data access
/data/** rw,
# suppress ptrace denials when using 'docker ps' or using 'ps' inside a container
ptrace (trace,read) peer=docker-default,
# docker daemon confinement requires explict allow rule for signal
signal (receive) set=(kill,term) peer=/usr/bin/docker,
}

6
grampsweb/build.yaml Normal file
View File

@@ -0,0 +1,6 @@
---
build_from:
aarch64: ghcr.io/gramps-project/grampsweb:latest
amd64: ghcr.io/gramps-project/grampsweb:latest
codenotary:
signer: alexandrep.github@gmail.com

106
grampsweb/config.yaml Normal file
View File

@@ -0,0 +1,106 @@
arch:
- aarch64
- amd64
codenotary: alexandrep.github@gmail.com
description: Open Source Online Genealogy System
devices:
- "/dev/dri"
- "/dev/dri/card0"
- "/dev/dri/card1"
- "/dev/dri/renderD128"
- "/dev/vchiq"
- "/dev/video10"
- "/dev/video11"
- "/dev/video12"
- "/dev/video13"
- "/dev/video14"
- "/dev/video15"
- "/dev/video16"
- "/dev/ttyUSB0"
- "/dev/sda"
- "/dev/sdb"
- "/dev/sdc"
- "/dev/sdd"
- "/dev/sde"
- "/dev/sdf"
- "/dev/sdg"
- "/dev/nvme"
- "/dev/nvme0n1p1"
- "/dev/nvme0n1p2"
- "/dev/nvme0n1p3"
- "/dev/nvme1n1p1"
- "/dev/nvme1n1p2"
- "/dev/nvme1n1p3"
- "/dev/nvme2n1p1"
- "/dev/nvme2n1p2"
- "/dev/nvme3n1p3"
- "/dev/mmcblk"
- "/dev/fuse"
- "/dev/sda1"
- "/dev/sdb1"
- "/dev/sdc1"
- "/dev/sdd1"
- "/dev/sde1"
- "/dev/sdf1"
- "/dev/sdg1"
- "/dev/sda2"
- "/dev/sdb2"
- "/dev/sdc2"
- "/dev/sdd2"
- "/dev/sde2"
- "/dev/sdf2"
- "/dev/sdg2"
- "/dev/sda3"
- "/dev/sdb3"
- "/dev/sda4"
- "/dev/sdb4"
- "/dev/sda5"
- "/dev/sda6"
- "/dev/sda7"
- "/dev/sda8"
- "/dev/nvme0"
- "/dev/nvme1"
- "/dev/nvme2"
environment: {
"GRAMPSWEB_TREE": "Gramps Web",
"GRAMPSWEB_CELERY_CONFIG__broker_url": "redis://localhost:6379/0",
"GRAMPSWEB_CELERY_CONFIG__result_backend": "redis://localhost:6379/0",
"GRAMPSWEB_RATELIMIT_STORAGE_URI": "redis://localhost:6379/1"
}
image: ghcr.io/alexbelgium/grampsweb-{arch}
init: false
options: {
"database": "sqlite"
}
map:
- type: addon_config
read_only: false
name: Monica
ports:
80/tcp: 5000
ports_description:
80/tcp: webui
schema: {
"database": "list(sqlite|MariaDB_addon|Mysql_external)",
"APP_KEY": "str?",
"DB_DATABASE": "str?",
"DB_HOST": "str?",
"DB_PASSWORD": "str?",
"DB_PORT": "int?",
"DB_USERNAME": "str?",
"MAIL_MAILER": "str?",
"MAIL_HOST": "str?",
"MAIL_PORT": "str?",
"MAIL_USERNAME": "str?",
"MAIL_PASSWORD": "str?",
"MAIL_ENCRYPTION": "str?",
"MAIL_FROM_ADDRESS": "str?",
"MAIL_FROM_NAME": "str?"
}
services:
- mysql:want
slug: grampsweb
tmpfs: true
url: https://github.com/alexbelgium/hassio-addons/tree/master/grampsweb
version: 1.0
webui: "[PROTO:ssl]://[HOST]:[PORT:80]"

BIN
grampsweb/icon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.3 KiB

BIN
grampsweb/logo.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.3 KiB

View File

@@ -0,0 +1,54 @@
#!/usr/bin/with-contenv bashio
# shellcheck shell=bash
set -e
#################
# Set structure #
#################
for folders in users indexdir database secret media cache thumbnail_cache grampsdb; do
mkdir -p /config/"$folders"
if [ -d /app/"$folders" ] && [ "$(ls -A /app/"$folders")" ]; then
cp -rf /app/"$folders"/* /config/"$folders"
fi
rm -rf /app/"$folders"
ln -sf /config/"$folders" /app/"$folders"
done
if [ -d /root/.gramps/grampsdb ] && [ "$(ls -A /root/.gramps/grampsdb)" ]; then
cp -rf /root/.gramps/grampsdb/* /config/grampsdb
rm -rf /root/.gramps/grampsdb
ln -sf /config/grampsdb /root/.gramps/grampsdb
fi
##################
# Starting Redis #
##################
echo "Starting Redis..."
redis-server &
REDIS_PID=$!
##################
# Starting Celery #
##################
echo "Starting Celery..."
celery -A gramps_webapi.celery worker --loglevel=INFO --concurrency=2 &
CELERY_PID=$!
#################
# Staring nginx #
#################
echo "Starting nginx..."
exec nginx & bashio::log.info "Starting nginx"
NGINX_PID=$!
###############
# Starting App #
###############
echo "Starting Gramps Web App..."
/docker-entrypoint.sh gunicorn -w ${GUNICORN_NUM_WORKERS:-8} -b 0.0.0.0:5000 gramps_webapi.wsgi:app --timeout ${GUNICORN_TIMEOUT:-120} --limit-request-line 8190 &
APP_PID=$!
# Wait for all background processes
wait $REDIS_PID $CELERY_PID $APP_PID $NGINX_PID

BIN
grampsweb/stats.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

9
grampsweb/updater.json Normal file
View File

@@ -0,0 +1,9 @@
{
"github_beta": true,
"github_tagfilter": "v5",
"last_update": "07-12-2024",
"repository": "alexbelgium/hassio-addons",
"slug": "grampsweb",
"upstream_repo": "grampswebhq/grampsweb",
"upstream_version": ""
}