Block a user
moka (v0.3.9.1)
Published 2025-10-19 22:16:58 -03:00 by skrd
Installation
docker pull git.skrd.fun/skrd/moka:v0.3.9.1sha256:6c60fbaebdd5a85b8077e7398764955babcd7a5f5ab5bda73cec85e05b8f5373
Images
| Digest | OS / Arch | Size |
|---|---|---|
| 64b22d2ee3 | linux/amd64 | 278 MiB |
Image Layers ( linux/amd64)
| # debian.sh --arch 'amd64' out/ 'trixie' '@1759104000' |
| RUN /bin/sh -c set -eux; { echo 'Package: php*'; echo 'Pin: release *'; echo 'Pin-Priority: -1'; } > /etc/apt/preferences.d/no-debian-php # buildkit |
| ENV PHPIZE_DEPS=autoconf dpkg-dev file g++ gcc libc-dev make pkg-config re2c |
| RUN /bin/sh -c set -eux; apt-get update; apt-get install -y --no-install-recommends $PHPIZE_DEPS ca-certificates curl xz-utils ; apt-get dist-clean # buildkit |
| ENV PHP_INI_DIR=/usr/local/etc/php |
| RUN /bin/sh -c set -eux; mkdir -p "$PHP_INI_DIR/conf.d"; [ ! -d /var/www/html ]; mkdir -p /var/www/html; chown www-data:www-data /var/www/html; chmod 1777 /var/www/html # buildkit |
| ENV PHP_CFLAGS=-fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 |
| ENV PHP_CPPFLAGS=-fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 |
| ENV PHP_LDFLAGS=-Wl,-O1 -pie |
| ENV GPG_KEYS=AFD8691FDAEDF03BDF6E460563F15A9B715376CA 9D7F99A0CB8F05C8A6958D6256A97AF7600A39A6 0616E93D95AF471243E26761770426E17EBBB3DD |
| ENV PHP_VERSION=8.4.13 |
| ENV PHP_URL=https://www.php.net/distributions/php-8.4.13.tar.xz PHP_ASC_URL=https://www.php.net/distributions/php-8.4.13.tar.xz.asc |
| ENV PHP_SHA256=b4f27adf30bcf262eacf93c78250dd811980f20f3b90d79a3dc11248681842df |
| RUN /bin/sh -c set -eux; savedAptMark="$(apt-mark showmanual)"; apt-get update; apt-get install -y --no-install-recommends gnupg; apt-get dist-clean; mkdir -p /usr/src; cd /usr/src; curl -fsSL -o php.tar.xz "$PHP_URL"; if [ -n "$PHP_SHA256" ]; then echo "$PHP_SHA256 *php.tar.xz" | sha256sum -c -; fi; curl -fsSL -o php.tar.xz.asc "$PHP_ASC_URL"; export GNUPGHOME="$(mktemp -d)"; for key in $GPG_KEYS; do gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key"; done; gpg --batch --verify php.tar.xz.asc php.tar.xz; gpgconf --kill all; rm -rf "$GNUPGHOME"; apt-mark auto '.*' > /dev/null; apt-mark manual $savedAptMark > /dev/null; apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false # buildkit |
| COPY docker-php-source /usr/local/bin/ # buildkit |
| RUN /bin/sh -c set -eux; savedAptMark="$(apt-mark showmanual)"; apt-get update; apt-get install -y --no-install-recommends libargon2-dev libcurl4-openssl-dev libonig-dev libreadline-dev libsodium-dev libsqlite3-dev libssl-dev libxml2-dev zlib1g-dev ; export CFLAGS="$PHP_CFLAGS" CPPFLAGS="$PHP_CPPFLAGS" LDFLAGS="$PHP_LDFLAGS" PHP_BUILD_PROVIDER='https://github.com/docker-library/php' PHP_UNAME='Linux - Docker' ; docker-php-source extract; cd /usr/src/php; gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; if [ ! -d /usr/include/curl ]; then ln -sT "/usr/include/$debMultiarch/curl" /usr/local/include/curl; fi; ./configure --build="$gnuArch" --with-config-file-path="$PHP_INI_DIR" --with-config-file-scan-dir="$PHP_INI_DIR/conf.d" --enable-option-checking=fatal --with-mhash --with-pic --enable-mbstring --enable-mysqlnd --with-password-argon2 --with-sodium=shared --with-pdo-sqlite=/usr --with-sqlite3=/usr --with-curl --with-iconv --with-openssl --with-readline --with-zlib --disable-phpdbg --with-pear --with-libdir="lib/$debMultiarch" --disable-cgi --enable-fpm --with-fpm-user=www-data --with-fpm-group=www-data ; make -j "$(nproc)"; find -type f -name '*.a' -delete; make install; find /usr/local -type f -perm '/0111' -exec sh -euxc ' strip --strip-all "$@" || : ' -- '{}' + ; make clean; cp -v php.ini-* "$PHP_INI_DIR/"; cd /; docker-php-source delete; apt-mark auto '.*' > /dev/null; [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); printf "*%s\n", so }' | sort -u | xargs -rt dpkg-query --search | awk 'sub(":$", "", $1) { print $1 }' | sort -u | xargs -r apt-mark manual ; apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; apt-get dist-clean; pecl update-channels; rm -rf /tmp/pear ~/.pearrc; php --version # buildkit |
| COPY docker-php-ext-* docker-php-entrypoint /usr/local/bin/ # buildkit |
| RUN /bin/sh -c docker-php-ext-enable opcache # buildkit |
| RUN /bin/sh -c docker-php-ext-enable sodium # buildkit |
| ENTRYPOINT ["docker-php-entrypoint"] |
| WORKDIR /var/www/html |
| RUN /bin/sh -c set -eux; cd /usr/local/etc; if [ -d php-fpm.d ]; then sed 's!=NONE/!=!g' php-fpm.conf.default | tee php-fpm.conf > /dev/null; cp php-fpm.d/www.conf.default php-fpm.d/www.conf; else mkdir php-fpm.d; cp php-fpm.conf.default php-fpm.d/www.conf; { echo '[global]'; echo 'include=etc/php-fpm.d/*.conf'; } | tee php-fpm.conf; fi; { echo '[global]'; echo 'error_log = /proc/self/fd/2'; echo; echo '; https://github.com/docker-library/php/pull/725#issuecomment-443540114'; echo 'log_limit = 8192'; echo; echo '[www]'; echo '; php-fpm closes STDOUT on startup, so sending logs to /proc/self/fd/1 does not work.'; echo '; https://bugs.php.net/bug.php?id=73886'; echo 'access.log = /proc/self/fd/2'; echo; echo 'clear_env = no'; echo; echo '; Ensure worker stdout and stderr are sent to the main error log.'; echo 'catch_workers_output = yes'; echo 'decorate_workers_output = no'; } | tee php-fpm.d/docker.conf; { echo '[global]'; echo 'daemonize = no'; echo; echo '[www]'; echo 'listen = 9000'; } | tee php-fpm.d/zz-docker.conf; mkdir -p "$PHP_INI_DIR/conf.d"; { echo '; https://github.com/docker-library/php/issues/878#issuecomment-938595965'; echo 'fastcgi.logging = Off'; } > "$PHP_INI_DIR/conf.d/docker-fpm.ini" # buildkit |
| STOPSIGNAL SIGQUIT |
| EXPOSE map[9000/tcp:{}] |
| CMD ["php-fpm"] |
| ARG USER=appuser |
| ARG UID=1000 |
| ARG GID=1000 |
| ARG MEMORY_LIMIT=256M |
| ARG CADDY_VERSION=2.10.2 |
| ADD --chmod=0755 https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions /usr/local/bin/ # buildkit |
| ADD https://github.com/caddyserver/caddy/releases/download/v2.10.2/caddy_2.10.2_linux_amd64.tar.gz /tmp/caddy.tar.gz # buildkit |
| RUN |5 USER=appuser UID=1000 GID=1000 MEMORY_LIMIT=256M CADDY_VERSION=2.10.2 /bin/sh -c install-php-extensions pdo_pgsql redis zip intl pcntl bcmath gd opcache # buildkit |
| RUN |5 USER=appuser UID=1000 GID=1000 MEMORY_LIMIT=256M CADDY_VERSION=2.10.2 /bin/sh -c groupadd ${USER} -g ${GID} && useradd ${USER} -u ${UID} -g ${GID} -m -s /bin/bash && mkdir -p /app /config/caddy /data/caddy /etc/caddy /usr/share/caddy && chown -R ${USER}:${USER} /app && apt update && apt install -y --no-install-recommends procps unzip supervisor && tar x -z -f /tmp/caddy.tar.gz -C /usr/bin/ caddy && rm -f /tmp/caddy.tar.gz && chmod +x /usr/bin/caddy # buildkit |
| COPY --chmod=755 entrypoint.sh /usr/local/bin/docker-entrypoint.sh # buildkit |
| COPY supervisord.conf /etc/supervisord.conf # buildkit |
| COPY Caddyfile /etc/caddy/Caddyfile # buildkit |
| WORKDIR /app |
| ENV XDG_CONFIG_HOME=/home/appuser/.config |
| ENV COMPOSER_HOME=/home/appuser/.composer |
| RUN |5 USER=appuser UID=1000 GID=1000 MEMORY_LIMIT=256M CADDY_VERSION=2.10.2 /bin/sh -c cp "$PHP_INI_DIR/php.ini-production" "$PHP_INI_DIR/php.ini" && sed -i "s/^memory_limit = .*/memory_limit = ${MEMORY_LIMIT}/" "$PHP_INI_DIR/php.ini" # buildkit |
| RUN |5 USER=appuser UID=1000 GID=1000 MEMORY_LIMIT=256M CADDY_VERSION=2.10.2 /bin/sh -c set -eux; { echo "opcache.enable=1"; echo "opcache.enable_cli=0"; echo "opcache.memory_consumption=256"; echo "opcache.interned_strings_buffer=32"; echo "opcache.max_accelerated_files=50000"; echo "opcache.validate_timestamps=0"; echo "opcache.revalidate_freq=0"; echo "opcache.save_comments=1"; echo "opcache.fast_shutdown=1"; echo "opcache.jit=0"; echo "opcache.jit_buffer_size=0"; } > "$PHP_INI_DIR/conf.d/99-opcache.ini" # buildkit |
| USER appuser |
| ENTRYPOINT ["/usr/local/bin/docker-entrypoint.sh"] |
| USER appuser |
| COPY --chown=appuser:appuser ./app /app/app # buildkit |
| COPY --chown=appuser:appuser ./bootstrap /app/bootstrap # buildkit |
| COPY --chown=appuser:appuser ./config /app/config # buildkit |
| COPY --chown=appuser:appuser ./database /app/database # buildkit |
| COPY --chown=appuser:appuser ./lang /app/lang # buildkit |
| COPY --chown=appuser:appuser ./resources /app/resources # buildkit |
| COPY --chown=appuser:appuser ./routes /app/routes # buildkit |
| COPY --chown=appuser:appuser ./scripts /app/scripts # buildkit |
| COPY --chown=appuser:appuser ./tests /app/tests # buildkit |
| COPY --chown=appuser:appuser ./artisan /app/artisan # buildkit |
| COPY --chown=appuser:appuser ./composer.json /app/composer.json # buildkit |
| COPY --chown=appuser:appuser ./composer.lock /app/composer.lock # buildkit |
| COPY --chown=appuser:appuser /app/public /app/public # buildkit |
| COPY --chown=appuser:appuser /app/vendor /app/vendor # buildkit |
| RUN /bin/sh -c mkdir -p /app/storage/app /app/storage/logs /app/storage/framework/cache /app/storage/framework/sessions /app/storage/framework/testing /app/storage/framework/views # buildkit |
| RUN /bin/sh -c rm -rf public/hot && rm -rf /app/bootstrap/cache/* # buildkit |
Details
2025-10-19 22:16:58 -03:00
Versions (64)
View all
Container
1
OCI / Docker
buildcache
2026-01-13
main
2026-01-13
sha-c79e0c3
2026-01-13
sha-7efbed2
2026-01-13
sha-be76ca9
2026-01-12