Add anki synserver
This commit is contained in:
@@ -0,0 +1,40 @@
|
|||||||
|
FROM rust:1.85.0-alpine3.20 AS builder
|
||||||
|
|
||||||
|
ARG ANKI_VERSION
|
||||||
|
|
||||||
|
RUN apk update && apk add --no-cache build-base protobuf && rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
|
RUN cargo install --git https://github.com/ankitects/anki.git \
|
||||||
|
--tag ${ANKI_VERSION} \
|
||||||
|
--root /anki-server \
|
||||||
|
--locked \
|
||||||
|
anki-sync-server
|
||||||
|
|
||||||
|
FROM alpine:3.21.0
|
||||||
|
|
||||||
|
# Default PUID and PGID values (can be overridden at runtime). Use these to
|
||||||
|
# ensure the files on the volume have the permissions you need.
|
||||||
|
ENV PUID=1000
|
||||||
|
ENV PGID=1000
|
||||||
|
|
||||||
|
COPY --from=builder /anki-server/bin/anki-sync-server /usr/local/bin/anki-sync-server
|
||||||
|
|
||||||
|
RUN apk update && apk add --no-cache bash su-exec && rm -rf /var/cache/apk/*
|
||||||
|
|
||||||
|
|
||||||
|
EXPOSE 8080
|
||||||
|
|
||||||
|
COPY entrypoint.sh /entrypoint.sh
|
||||||
|
RUN chmod +x /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
|
CMD ["anki-sync-server"]
|
||||||
|
|
||||||
|
# This health check will work for Anki versions 24.08.x and newer.
|
||||||
|
# For older versions, it may incorrectly report an unhealthy status, which should not be the case.
|
||||||
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
|
||||||
|
CMD wget -qO- http://127.0.0.1:8080/health || exit 1
|
||||||
|
|
||||||
|
VOLUME /anki_data
|
||||||
|
|
||||||
|
LABEL maintainer="Jean Khawand <jk@jeankhawand.com>"
|
||||||
@@ -0,0 +1,31 @@
|
|||||||
|
networks:
|
||||||
|
default:
|
||||||
|
name: traefik_default
|
||||||
|
external: true
|
||||||
|
|
||||||
|
services:
|
||||||
|
anki-syncserver:
|
||||||
|
container_name: anki-syncserver
|
||||||
|
build:
|
||||||
|
dockerfile: Dockerfile
|
||||||
|
args:
|
||||||
|
- ANKI_VERSION=25.09
|
||||||
|
env_file: live.env
|
||||||
|
ports:
|
||||||
|
- "8080:8080"
|
||||||
|
environment:
|
||||||
|
- SYNC_USER1=${USER_NAME}:${USER_PASSWORD}
|
||||||
|
volumes:
|
||||||
|
- ./data:/anki-sync-server-data
|
||||||
|
labels:
|
||||||
|
# Watchtower
|
||||||
|
- "com.centurylinklabs.watchtower.enable=true"
|
||||||
|
# Routes
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.routers.anki.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.anki.rule=Host(`anki.${DOMAIN}`)"
|
||||||
|
- "traefik.http.routers.anki.tls=true"
|
||||||
|
- "traefik.http.routers.anki.tls.certresolver=myresolver"
|
||||||
|
- "traefik.http.services.anki.loadbalancer.server.port=8080"
|
||||||
|
networks:
|
||||||
|
- default
|
||||||
@@ -0,0 +1,30 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -o errexit
|
||||||
|
set -o nounset
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
# Default PUID and PGID if not provided
|
||||||
|
export PUID=${PUID:-1000}
|
||||||
|
export PGID=${PGID:-1000}
|
||||||
|
|
||||||
|
# These values are fixed and cannot be overwritten from the outside for
|
||||||
|
# convenience and safety reasons
|
||||||
|
export SYNC_PORT=8080
|
||||||
|
export SYNC_BASE=/anki_data
|
||||||
|
|
||||||
|
# Check if group exists, create if not
|
||||||
|
if ! getent group anki-group > /dev/null 2>&1; then
|
||||||
|
addgroup -g "$PGID" anki-group
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if user exists, create if not
|
||||||
|
if ! id -u anki > /dev/null 2>&1; then
|
||||||
|
adduser -D -H -u "$PUID" -G anki-group anki
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Fix ownership of mounted volumes
|
||||||
|
mkdir -p /anki_data
|
||||||
|
chown anki:anki-group /anki_data
|
||||||
|
|
||||||
|
# Run the provided command as the `anki` user
|
||||||
|
exec su-exec anki "$@"
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
# Anki Syncserver
|
||||||
|
ANKI_VERSION=25.09
|
||||||
|
USER_NAME=admin
|
||||||
|
USER_PASSWORD=password
|
||||||
|
|
||||||
|
# Traefik
|
||||||
|
DOMAIN=sporada.eu
|
||||||
Reference in New Issue
Block a user