public-repos

fluxer-server (1.0.0)

Published 2026-02-20 02:03:51 +00:00 by ci-cd

Installation

docker pull git.tswf.io/public-repos/fluxer-server:1.0.0
sha256:5cfee1c8edc6d20498c5ff88de7c21764be0f71c55d678817acc933e32969194

Images

Digest OS / Arch Size
3f778b5ab6 linux/amd64 763 MiB

Image Layers ( linux/amd64)

# debian.sh --arch 'amd64' out/ 'trixie' '@1769990400'
RUN /bin/sh -c groupadd --gid 1000 node && useradd --uid 1000 --gid node --shell /bin/bash --create-home node # buildkit
ENV NODE_VERSION=24.13.1
RUN /bin/sh -c ARCH= OPENSSL_ARCH= && dpkgArch="$(dpkg --print-architecture)" && case "${dpkgArch##*-}" in amd64) ARCH='x64' OPENSSL_ARCH='linux-x86_64';; ppc64el) ARCH='ppc64le' OPENSSL_ARCH='linux-ppc64le';; s390x) ARCH='s390x' OPENSSL_ARCH='linux*-s390x';; arm64) ARCH='arm64' OPENSSL_ARCH='linux-aarch64';; armhf) ARCH='armv7l' OPENSSL_ARCH='linux-armv4';; i386) ARCH='x86' OPENSSL_ARCH='linux-elf';; *) echo "unsupported architecture"; exit 1 ;; esac && set -ex && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr xz-utils libatomic1 --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 5BE8A3F6C8A5C01D106C0AD820B1A390B168D356 DD792F5973C6DE52C432CBDAC77ABFA00DDBF2B7 CC68F5A3106FF448322E48ED27F5E38D5B0A215F 8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 890C08DB8579162FEE0DF9DB8BEAB4DFCF555EF4 C82FA3AE1CBEDC6BE46B9360C43CEC45C17AB93C 108F52B48DB57BB0CC439B2997B01419BD92F80A A363A499291CBBC940DD62E41F10027AF002F8B0 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" && gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc && gpgconf --kill all && rm -rf "$GNUPGHOME" && grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - && tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner && rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt && find /usr/local/include/node/openssl/archs -mindepth 1 -maxdepth 1 ! -name "$OPENSSL_ARCH" -exec rm -rf {} \; && apt-mark auto '.*' > /dev/null && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && ln -s /usr/local/bin/node /usr/local/bin/nodejs && node --version && npm --version && rm -rf /tmp/* # buildkit
ENV YARN_VERSION=1.22.22
RUN /bin/sh -c set -ex && savedAptMark="$(apt-mark showmanual)" && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 6A010C5166006599AA17F08146C2130DFD2497F5 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" && gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && gpgconf --kill all && rm -rf "$GNUPGHOME" && mkdir -p /opt && tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ && ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn && ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg && rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && apt-mark auto '.*' > /dev/null && { [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark > /dev/null; } && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && yarn --version && rm -rf /tmp/* # buildkit
COPY docker-entrypoint.sh /usr/local/bin/ # buildkit
ENTRYPOINT ["docker-entrypoint.sh"]
CMD ["node"]
ARG BUILD_SHA
ARG BUILD_NUMBER
ARG BUILD_TIMESTAMP
ARG RELEASE_CHANNEL=nightly
LABEL org.opencontainers.image.title=Fluxer Server
LABEL org.opencontainers.image.description=Unified Fluxer server for self-hosting - combines all backend services into a single deployable container
LABEL org.opencontainers.image.vendor=Fluxer Contributors
LABEL org.opencontainers.image.licenses=AGPL-3.0-or-later
LABEL org.opencontainers.image.source=https://github.com/fluxerapp/fluxer
LABEL org.opencontainers.image.documentation=https://docs.fluxer.app
LABEL org.opencontainers.image.revision=
LABEL org.opencontainers.image.version=
LABEL org.opencontainers.image.created=
WORKDIR /usr/src/app
RUN |4 BUILD_SHA= BUILD_NUMBER= BUILD_TIMESTAMP= RELEASE_CHANNEL=nightly /bin/sh -c apt-get update && apt-get install -y --no-install-recommends curl ffmpeg && rm -rf /var/lib/apt/lists/* # buildkit
RUN |4 BUILD_SHA= BUILD_NUMBER= BUILD_TIMESTAMP= RELEASE_CHANNEL=nightly /bin/sh -c corepack enable && corepack prepare pnpm@10.26.0 --activate # buildkit
COPY /usr/src/app/node_modules ./node_modules # buildkit
COPY /usr/src/app/packages ./packages # buildkit
COPY /usr/src/app/fluxer_server ./fluxer_server # buildkit
COPY /usr/src/app/tsconfigs ./tsconfigs # buildkit
COPY /usr/src/app/pnpm-workspace.yaml ./ # buildkit
COPY /usr/src/app/package.json ./ # buildkit
COPY /usr/src/app/gateway/fluxer_gateway/_build/prod/rel/fluxer_gateway /opt/fluxer_gateway # buildkit
COPY /usr/src/app/fluxer_app/dist /usr/src/app/assets # buildkit
RUN |4 BUILD_SHA= BUILD_NUMBER= BUILD_TIMESTAMP= RELEASE_CHANNEL=nightly /bin/sh -c mkdir -p /usr/src/app/data/storage && mkdir -p /usr/src/app/data/db && mkdir -p /opt/data && mkdir -p /data/s3 && mkdir -p /data/sqlite && mkdir -p /data/queue && mkdir -p /var/log/fluxer && chown -R root:root /usr/src/app/data && chown -R root:root /opt/data && chown -R root:root /data # buildkit
ARG INCLUDE_NSFW_ML=false
RUN |5 BUILD_SHA= BUILD_NUMBER= BUILD_TIMESTAMP= RELEASE_CHANNEL=nightly INCLUDE_NSFW_ML=false /bin/sh -c if [ "$INCLUDE_NSFW_ML" = "true" ]; then echo "Including NSFW detection model..."; cp /tmp/model.onnx /opt/data/model.onnx; else echo "Skipping NSFW detection model (INCLUDE_NSFW_ML=$INCLUDE_NSFW_ML)"; fi # buildkit
EXPOSE [8080/tcp]
ENV NODE_ENV=production
ENV FLUXER_SERVER_HOST=0.0.0.0
ENV FLUXER_SERVER_PORT=8080
ENV FLUXER_GATEWAY_HOST=127.0.0.1
ENV FLUXER_GATEWAY_PORT=8082
ENV DATABASE_BACKEND=sqlite
ENV SQLITE_PATH=/usr/src/app/data/db/fluxer.db
ENV STORAGE_ROOT=/usr/src/app/data/storage
ENV SEARCH_BACKEND=sqlite
ENV FLUXER_SERVER_STATIC_DIR=/usr/src/app/assets
ENV BUILD_SHA=
ENV BUILD_NUMBER=
ENV BUILD_TIMESTAMP=
ENV RELEASE_CHANNEL=nightly
HEALTHCHECK &{["CMD-SHELL" "curl -f http://localhost:8080/_health || exit 1"] "30s" "10s" "0s" "0s" '\x03'}
WORKDIR /usr/src/app/fluxer_server
CMD ["pnpm" "start"]

Labels

Key Value
org.opencontainers.image.created
org.opencontainers.image.description Unified Fluxer server for self-hosting - combines all backend services into a single deployable container
org.opencontainers.image.documentation https://docs.fluxer.app
org.opencontainers.image.licenses AGPL-3.0-or-later
org.opencontainers.image.revision
org.opencontainers.image.source https://github.com/fluxerapp/fluxer
org.opencontainers.image.title Fluxer Server
org.opencontainers.image.vendor Fluxer Contributors
org.opencontainers.image.version
Details
Container
2026-02-20 02:03:51 +00:00
1
OCI / Docker
Versions (1) View all
1.0.0 2026-02-20