# # OneUptime-Probe Dockerfile # # Pull base image nodejs image. FROM public.ecr.aws/docker/library/node:24.9 RUN mkdir /tmp/npm && chmod 2777 /tmp/npm && chown 1000:1000 /tmp/npm && npm config set cache /tmp/npm --global RUN npm config set fetch-retries 5 RUN npm config set fetch-retry-mintimeout 20000 RUN npm config set fetch-retry-maxtimeout 60000 ARG GIT_SHA ARG APP_VERSION ARG IS_ENTERPRISE_EDITION=false ENV GIT_SHA=${GIT_SHA} ENV APP_VERSION=${APP_VERSION} ENV IS_ENTERPRISE_EDITION=${IS_ENTERPRISE_EDITION} ENV NODE_OPTIONS="--use-openssl-ca" ## Add Intermediate Certs COPY ./SslCertificates /usr/local/share/ca-certificates RUN update-ca-certificates # IF APP_VERSION is not set, set it to 1.0.0 RUN if [ -z "$APP_VERSION" ]; then export APP_VERSION=1.0.0; fi RUN apt-get update # Install bash. RUN apt-get install bash -y && apt-get install curl -y && apt-get install iputils-ping -y # Install tini - a tiny init for containers to properly reap zombie processes RUN apt-get install -y tini # Install python RUN apt-get update && apt-get install -y .gyp python3 make g++ # Install playwright dependencies RUN apt-get install -y libnss3 libnspr4 libatk1.0-0 libatk-bridge2.0-0 libcups2 libdrm2 libxkbcommon0 libxcomposite1 libxdamage1 libxfixes3 libxrandr2 libgbm1 libgtk-3-0 libpango-1.0-0 libcairo2 libgdk-pixbuf2.0-0 libasound2 libatspi2.0-0 #Use bash shell by default SHELL ["/bin/bash", "-c"] # Install iputils and dnsutils (for dig, used in DNSSEC validation) RUN apt-get install net-tools dnsutils -y RUN mkdir -p /usr/src WORKDIR /usr/src/Common COPY ./Common/package*.json /usr/src/Common/ # Set version in ./Common/package.json to the APP_VERSION RUN sed -i "s/\"version\": \".*\"/\"version\": \"$APP_VERSION\"/g" /usr/src/Common/package.json RUN npm install COPY ./Common /usr/src/Common ENV PRODUCTION=true WORKDIR /usr/src/app # Install app dependencies first so local Playwright CLI is available COPY ./Probe/package*.json /usr/src/app/ RUN npm install # Install browsers to a fixed path accessible by any runtime user (root or non-root) ENV PLAYWRIGHT_BROWSERS_PATH=/ms-playwright-browsers RUN npx playwright install --with-deps && chmod -R 755 /ms-playwright-browsers # Use tini as init to properly reap zombie processes (like Chrome/Chromium) ENTRYPOINT ["/usr/bin/tini", "--"] {{ if eq .Env.ENVIRONMENT "development" }} #Run the app CMD [ "bash", "/usr/src/app/Start.dev.sh" ] {{ else }} # Copy app source COPY ./Probe /usr/src/app # Bundle app source RUN npm run compile # Set permission to write logs and cache in case container run as non root RUN chown -R 1000:1000 "/tmp/npm" && chmod -R 2777 "/tmp/npm" #Run the app CMD [ "npm", "start" ] {{ end }}