Block a user
moka (sha-be76ca9)
Published 2026-01-12 23:53:52 -03:00 by skrd
Installation
docker pull git.skrd.fun/skrd/moka:sha-be76ca9sha256:500d90f54edffdede6549dbd2ec95ac4b9a0eeb08d7888e95d891596aedf3dc8
Images
| Digest | OS / Arch | Size |
|---|---|---|
| 2fefe77d59 | linux/amd64 | 535 MiB |
Image Layers ( linux/amd64)
| # debian.sh --arch 'amd64' out/ 'trixie' '@1766966400' |
| 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.16 |
| ENV PHP_URL=https://www.php.net/distributions/php-8.4.16.tar.xz PHP_ASC_URL=https://www.php.net/distributions/php-8.4.16.tar.xz.asc |
| ENV PHP_SHA256=f66f8f48db34e9e29f7bfd6901178e9cf4a1b163e6e497716dfcb8f88bcfae30 |
| 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; test "$PHP_INI_DIR" != "${PHP_INI_DIR%/php}"; ./configure --build="$gnuArch" --sysconfdir="${PHP_INI_DIR%/php}" --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 "${PHP_INI_DIR%/php}"; cp -v php-fpm.conf.default php-fpm.conf; cp -v php-fpm.d/www.conf.default php-fpm.d/www.conf; { 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=app |
| ARG UID=1000 |
| ARG GID=1000 |
| ARG MEMORY_LIMIT=256M |
| ARG CADDY_VERSION=2.10.2 |
| ENV TZ=America/Santiago |
| ENV XDG_CONFIG_HOME=/config |
| ENV XDG_DATA_HOME=/data |
| 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=app 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=app 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 /data /etc/caddy /usr/share/caddy && chown ${USER}:${USER} /app && tar x -z -f /tmp/caddy.tar.gz -C /usr/bin/ caddy && rm -f /tmp/caddy.tar.gz && chmod +x /usr/bin/caddy && apt-get update && apt-get install -y --no-install-recommends procps gosu supervisor unzip libreoffice nodejs npm telnet vim curl # buildkit |
| COPY /usr/bin/composer /usr/bin/composer # buildkit |
| COPY --chmod=755 infra/entrypoint.sh /usr/local/bin/docker-entrypoint.sh # buildkit |
| COPY infra/supervisord.conf /etc/supervisord.conf # buildkit |
| COPY infra/Caddyfile /etc/caddy/Caddyfile # buildkit |
| COPY infra/php/ /opt/php-configs/ # buildkit |
| WORKDIR /app |
| RUN |5 USER=app 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 |
| ENTRYPOINT ["/usr/local/bin/docker-entrypoint.sh"] |
| USER app |
| COPY --chown=app:app ./app /app/app # buildkit |
| COPY --chown=app:app ./bootstrap /app/bootstrap # buildkit |
| COPY --chown=app:app ./config /app/config # buildkit |
| COPY --chown=app:app ./database /app/database # buildkit |
| COPY --chown=app:app ./lang /app/lang # buildkit |
| COPY --chown=app:app ./resources /app/resources # buildkit |
| COPY --chown=app:app ./routes /app/routes # buildkit |
| COPY --chown=app:app ./scripts /app/scripts # buildkit |
| COPY --chown=app:app ./tests /app/tests # buildkit |
| COPY --chown=app:app ./artisan /app/artisan # buildkit |
| COPY --chown=app:app ./composer.json /app/composer.json # buildkit |
| COPY --chown=app:app ./composer.lock /app/composer.lock # buildkit |
| COPY --chown=app:app ./package-lock.json /app/package-lock.json # buildkit |
| COPY --chown=app:app ./package.json /app/package.json # buildkit |
| COPY --chown=app:app ./vite.config.js /app/vite.config.js # buildkit |
| COPY --chown=app:app ./phpunit.xml /app/phpunit.xml # buildkit |
| COPY --chown=app:app /app/public /app/public # buildkit |
| COPY --chown=app:app /app/node_modules /app/node_modules # buildkit |
| COPY --chown=app:app /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 /app/bootstrap/cache # buildkit |
| USER root |
Details
2026-01-12 23:53:52 -03:00
Versions (64)
View all
Container
0
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