{"architecture":"arm64","config":{"User":"observability","ExposedPorts":{"8082/tcp":{}},"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","uname=observability","gname=observability","JF_PRODUCT_DATA_INTERNAL=/var/opt/jfrog/observability","JF_PRODUCT_HOME=/opt/jfrog/observability","SERVICE_NAME=observability","TARGETARCH=arm64","JF_PRODUCT_APP=/opt/jfrog/observability/app"],"Entrypoint":["/usr/local/bin/fips-entrypoint.sh","/opt/jfrog/observability/app/bin/entrypoint-observability.sh"],"Volumes":{"/var/opt/jfrog/observability":{}},"WorkingDir":"/","Labels":{"ai.echo.image.name":"echo-fips","ai.echo.image.tag":"latest","ai.echo.image.upstream.digest":"sha256:e969bc4a6af81e66bf2ee7e79cecb24885929111d5eddb97dd80bed3b90a5e93","ai.echo.image.upstream.tag":"stable","ai.echo.image.upstream.uri":"docker.io/library/debian","com.echohq.image.name":"echo-fips","com.echohq.image.tag":"latest","description":"JFrog Echo Image — base (FIPS-aware, hardened)","maintainer":"devops@jfrog.com","org.opencontainers.image.author":"echohq.com","org.opencontainers.image.title":"jfrog/echo-base","org.opencontainers.image.vendor":"JFrog"},"ArgsEscaped":true},"created":"2026-05-15T09:22:50.796939431Z","history":[{"created":"2026-05-03T15:26:23.829867112Z","created_by":"COPY / / # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-03T15:26:23.829867112Z","created_by":"CMD [\"bash\"]","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-03T15:32:37.770891953Z","created_by":"ARG CACHEBUST=f78390bc22ddc61be22e241746af051ffa5b5ba5e37dcad34363b9b533cfe399","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-03T15:32:37.770891953Z","created_by":"RUN |1 CACHEBUST=f78390bc22ddc61be22e241746af051ffa5b5ba5e37dcad34363b9b533cfe399 /bin/sh -c disable-docker-clean \u0026\u0026     apt-get update \u0026\u0026 apt-get upgrade -y \u0026\u0026     apt-get install -y --no-install-recommends     libc6     openssl-fips-provider     openssl-config-fips \u0026\u0026     enable-docker-clean # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-03T15:41:25.37026733Z","created_by":"ARG CACHEBUST=0cd3ce15302f3e20e1e35e3e91e8c0f801a3748d28b359295cadf7249441e9bb","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-03T15:41:25.37026733Z","created_by":"RUN |1 CACHEBUST=0cd3ce15302f3e20e1e35e3e91e8c0f801a3748d28b359295cadf7249441e9bb /bin/sh -c disable-docker-clean \u0026\u0026     apt-get update \u0026\u0026 apt-get upgrade -y \u0026\u0026     apt install -y --no-install-recommends     libc6 \u0026\u0026     enable-docker-clean # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-03T15:41:25.37026733Z","created_by":"CMD [\"bash\"]","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-14T11:12:14.855957463Z","created_by":"LABEL maintainer=JFrog Installers \u003cinstallers@jfrog.com\u003e","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-14T11:12:14.855957463Z","created_by":"LABEL description=JFrog Echo Image — base (FIPS-aware, hardened)","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-14T11:12:14.855957463Z","created_by":"LABEL org.opencontainers.image.vendor=JFrog","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-14T11:12:14.855957463Z","created_by":"LABEL org.opencontainers.image.title=jfrog/echo-base","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-14T11:12:14.855957463Z","created_by":"COPY packages-base.txt /tmp/packages.txt # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:56.889816635Z","created_by":"RUN /bin/sh -c apt-get update -qq \u0026\u0026     xargs -a /tmp/packages.txt apt-get install -y --no-install-recommends \u0026\u0026     rm -f /tmp/packages.txt \u0026\u0026     (update-ca-certificates 2\u003e/dev/null || true) \u0026\u0026     rm -rf /var/lib/apt/lists/* \u0026\u0026     OSSL_VER=$(dpkg-query -W -f='${Version}' openssl 2\u003e/dev/null) \u0026\u0026     echo \"OpenSSL package version: ${OSSL_VER}\" \u0026\u0026     (echo \"${OSSL_VER}\" | grep -q '+e' ||         { echo \"ERROR: Echo-patched OpenSSL replaced by stock build\"; exit 1; }) # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:57.164678144Z","created_by":"RUN /bin/sh -c cp -L /usr/lib/ssl/openssl.cnf /etc/ssl/openssl.cnf.orig # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:57.199591491Z","created_by":"COPY openssl.cnf /etc/ssl/openssl.cnf # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:57.231816171Z","created_by":"COPY fips-entrypoint.sh /usr/local/bin/fips-entrypoint.sh # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:57.671826288Z","created_by":"RUN /bin/sh -c OUT=/usr/lib/ssl/openssl-fips.cnf \u0026\u0026     ORIG=/etc/ssl/openssl.cnf.orig \u0026\u0026     cp \"$ORIG\" \"$OUT\" \u0026\u0026     awk 'BEGIN {         print \"\";         print \"# JFrog TLS hardening\";         print \"[ssl_sect]\";         print \"system_default = system_default_sect\";         print \"\";         print \"[system_default_sect]\";         print \"MinProtocol  = TLSv1.2\";         print \"MaxProtocol  = TLSv1.3\";         print \"CipherString = ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:DHE-RSA-AES256-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA256\";         print \"CipherSuites = TLS_AES_256_GCM_SHA384:TLS_AES_128_GCM_SHA256\";     }' /dev/null \u003e\u003e \"$OUT\" \u0026\u0026     cp \"$OUT\" /etc/ssl/openssl-fips.cnf \u0026\u0026     echo \"Lines in fips.cnf: $(wc -l \u003c \"$OUT\")\" \u0026\u0026     grep -q 'fips = fips_sect' \"$OUT\" \u0026\u0026 echo \"PASS: fips_sect present\" || { echo \"FAIL: fips_sect missing\"; exit 1; } \u0026\u0026     grep -q 'MinProtocol' \"$OUT\" \u0026\u0026 echo \"PASS: MinProtocol present\" || { echo \"FAIL: MinProtocol missing\"; exit 1; } \u0026\u0026     grep -q '\\.include' \"$OUT\" \u0026\u0026 echo \"PASS: .include present\" || { echo \"FAIL: .include missing\"; exit 1; } # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:58.32496344Z","created_by":"RUN /bin/sh -c chmod +x /usr/local/bin/fips-entrypoint.sh \u0026\u0026     sh -n /usr/local/bin/fips-entrypoint.sh \u0026\u0026     chmod 644 /etc/ssl/openssl.cnf \u0026\u0026     chmod 644 /usr/lib/ssl/openssl-fips.cnf /etc/ssl/openssl-fips.cnf \u0026\u0026     (chmod 644 /etc/ssl/certs/ca-certificates.crt 2\u003e/dev/null || true) \u0026\u0026     (find /usr/bin /usr/sbin /bin /sbin          \\( -perm -4000 -o -perm -2000 \\)          ! -name 'su' ! -name 'newgrp'          -exec chmod a-s {} \\; 2\u003e/dev/null || true) # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:58.586326966Z","created_by":"RUN /bin/sh -c echo \"=== OS ===\" \u0026\u0026 cat /etc/os-release | grep -E 'NAME|VERSION' # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:58.902468106Z","created_by":"RUN /bin/sh -c echo \"=== OpenSSL ===\" \u0026\u0026 openssl version -a # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:59.260560928Z","created_by":"RUN /bin/sh -c echo \"=== Non-FIPS config ===\" \u0026\u0026     OPENSSL_CONF=/etc/ssl/openssl.cnf openssl ciphers -v ALL 2\u003e\u00261 | head -3 \u0026\u0026     echo \"openssl.cnf OK\" # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:13:59.83233926Z","created_by":"RUN /bin/sh -c echo \"=== FIPS config loads FIPS provider? ===\" \u0026\u0026     OPENSSL_CONF=/usr/lib/ssl/openssl-fips.cnf openssl list -providers 2\u003e\u00261 | tee /tmp/fips-providers.txt \u0026\u0026     grep -qi 'fips' /tmp/fips-providers.txt || { echo \"FAIL: FIPS provider not active under openssl-fips.cnf\"; exit 1; } \u0026\u0026     echo \"openssl-fips.cnf OK\" # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:14:00.20688438Z","created_by":"RUN /bin/sh -c echo \"=== Cipher policy ===\" \u0026\u0026     CSTR=\"ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES128-GCM-SHA256\" \u0026\u0026     openssl ciphers -v \"$CSTR\" 2\u003e/dev/null | awk '{print $1}' |         grep -E '^ADH-|^AECDH-|^NULL-|^EXP-'         \u0026\u0026 echo \"FAIL: weak suites\" \u0026\u0026 exit 1         || echo \"PASS: no weak suites\" \u0026\u0026     grep -E 'MinProtocol\\s*=\\s*TLSv1\\.2' /etc/ssl/openssl.cnf \u0026\u0026 echo \"PASS: MinProtocol set\" # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:14:00.485082935Z","created_by":"RUN /bin/sh -c echo \"=== CA bundle ===\" \u0026\u0026     TOTAL=$(grep -c 'BEGIN CERTIFICATE' /etc/ssl/certs/ca-certificates.crt) \u0026\u0026     echo \"Total CAs: $TOTAL\" \u0026\u0026     grep -i baltimore /etc/ssl/certs/ca-certificates.crt         \u0026\u0026 echo \"WARNING: Baltimore expired root present\"         || echo \"PASS: Baltimore absent\" # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:14:00.743318069Z","created_by":"RUN /bin/sh -c echo \"=== initContainer utilities ===\" \u0026\u0026     MISSING=\"\" \u0026\u0026     for cmd in bash sh curl cp rm mkdir chmod sed grep ls mv cat                sleep timeout tail kill touch tee basename; do         if command -v \"$cmd\" \u003e/dev/null 2\u003e\u00261; then             printf \"  %-12s %s\\n\" \"$cmd\" \"$(command -v \"$cmd\")\";         else             printf \"  %-12s MISSING\\n\" \"$cmd\"; MISSING=\"${MISSING} ${cmd}\";         fi;     done \u0026\u0026     [ -z \"$MISSING\" ] \u0026\u0026 echo \"PASS: all initContainer utilities present\"         || { echo \"FAIL: missing:${MISSING}\"; exit 1; } # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:14:00.935478057Z","created_by":"RUN /bin/sh -c echo \"=== All smoke tests passed ===\" # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-14T11:14:00.935478057Z","created_by":"ENTRYPOINT [\"/usr/local/bin/fips-entrypoint.sh\"]","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-14T11:14:00.935478057Z","created_by":"CMD [\"/bin/sh\"]","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:48.186413076Z","created_by":"LABEL maintainer=devops@jfrog.com","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:48.186413076Z","created_by":"ARG TARGETARCH=arm64","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:48.186413076Z","created_by":"ENV uname=observability gname=observability JF_PRODUCT_DATA_INTERNAL=/var/opt/jfrog/observability JF_PRODUCT_HOME=/opt/jfrog/observability SERVICE_NAME=observability TARGETARCH=arm64 JF_PRODUCT_APP=/opt/jfrog/observability/app","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:48.186413076Z","created_by":"USER root","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:48.186413076Z","created_by":"RUN |1 TARGETARCH=arm64 /bin/sh -c groupadd -g 1118 observability     \u0026\u0026 useradd -Ms /bin/bash -g observability -u 1118 observability # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-15T09:22:48.186413076Z","created_by":"USER root","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:48.562901878Z","created_by":"RUN |1 TARGETARCH=arm64 /bin/sh -c mkdir -p ${JF_PRODUCT_HOME}/app/third-party # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-15T09:22:50.216347996Z","created_by":"COPY /opt/jfrog/observability/app /opt/jfrog/observability/app # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-15T09:22:50.30500367Z","created_by":"COPY third-party/yq-arm64 /opt/jfrog/observability/app/third-party/yq # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-15T09:22:50.796939431Z","created_by":"RUN |1 TARGETARCH=arm64 /bin/sh -c mkdir -p ${JF_PRODUCT_DATA_INTERNAL}/etc/security \u0026\u0026     ln -s ${JF_PRODUCT_DATA_INTERNAL} ${JF_PRODUCT_HOME}/var \u0026\u0026     chown -R ${uname}:${gname} ${JF_PRODUCT_HOME} ${JF_PRODUCT_DATA_INTERNAL} \u0026\u0026     chmod -R 755 ${JF_PRODUCT_DATA_INTERNAL} # buildkit","comment":"buildkit.dockerfile.v0"},{"created":"2026-05-15T09:22:50.796939431Z","created_by":"EXPOSE [8082/tcp]","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:50.796939431Z","created_by":"USER observability","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:50.796939431Z","created_by":"VOLUME [/var/opt/jfrog/observability]","comment":"buildkit.dockerfile.v0","empty_layer":true},{"created":"2026-05-15T09:22:50.796939431Z","created_by":"ENTRYPOINT [\"/usr/local/bin/fips-entrypoint.sh\" \"/opt/jfrog/observability/app/bin/entrypoint-observability.sh\"]","comment":"buildkit.dockerfile.v0","empty_layer":true}],"os":"linux","rootfs":{"type":"layers","diff_ids":["sha256:9049de181237d32dfd2bf7d7a55b7266d62888d168f7d1213a99f3abd623c712","sha256:feca61b3c52108bdf443397822fc5b9640ee64a061b1a8e081750be00b31f03d","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:047776ed2a060d7fdaab45b197c8a47264c93f0da64d1cc98197d566af37f9d1","sha256:ecc0cfe48703ec7d1b4b4c2eddcaf31f66e548a6197020488ca0a6a5a6e0b6c3","sha256:4e3ac3bac215d769ca07aa2b58a7f0f8dbb33eefcc9b60b901de04399d78820f","sha256:f97e86f8882080136264dce15dd20e2de9a9a5b0e2ff76334ca67211d6e7b8e4","sha256:b813b8e88530c1167836b2f3f8e12543e38cf6c623547d19e2a1120403244e37","sha256:f2e350e8ea1bca6aa4f64f68788073cb742e5f993ec07713744c70548efa67e8","sha256:0687ab1ed071f30aa44ba8ee705047ce17ad5aec6c5420111ebc87ec691c4757","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:ddd1a84b339ceb164d320b6481476592af50495bb885c3159f952878f834a205","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef","sha256:0accfbd63adf6ffbb5558b91d9f215cb553909cb75cc5df41998ee7b7ecfecdb","sha256:3faa85bf6bedc28748cca84c63edffb4fc08d10cfec1f749199d52cad16677f9","sha256:b7558442e7f7600a7d37b6a248fd46bc62d96dce334644b548a83fe1d780f423","sha256:4d4fa843abf8fea449cece0f06c771458a52d0ed90c6b481f9eb77e7c9c94b5d","sha256:3f4407af6ae69fbba6f899b6aeb63ba95d06fa3bd7f1807c21a2548c431a3c9e"]}}