Add an infra-owned image (Playwright base + google-chrome-stable) + its GHA build workflow. The bundled Chromium ships proprietary codecs compiled out, so H.264/AAC video (Instagram Reels, X, most .mp4) fails in the noVNC view with MEDIA_ERR_SRC_NOT_SUPPORTED; only real Google Chrome carries those codecs (libffmpeg swap + Chrome-for-Testing both ruled out). This commit only builds the image (→ ghcr.io/viktorbarzin/chrome-service-browser); a follow-up flips main.tf's launch to it once the image exists + is public. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
27 lines
1.5 KiB
Docker
27 lines
1.5 KiB
Docker
# chrome-service browser image (ADR-0002, infra-owned, built off-infra on GHA).
|
|
#
|
|
# The Playwright base provides Xvfb + every browser runtime dep + fonts. On top
|
|
# we install REAL Google Chrome for its licensed proprietary codecs (H.264/AAC):
|
|
# the bundled open-source Chromium ships with those codecs COMPILED OUT, so
|
|
# H.264/AAC video (Instagram Reels, X, most .mp4) fails in the noVNC view with
|
|
# MEDIA_ERR_SRC_NOT_SUPPORTED. Swapping libffmpeg.so does NOT help (Playwright's
|
|
# Chromium has the codecs compiled out, not just the lib stripped), and Chrome
|
|
# for Testing is also codec-less — only google-chrome-stable carries them.
|
|
#
|
|
# main.tf launches /opt/google/chrome/chrome instead of the bundled
|
|
# /ms-playwright/chromium-*/chrome. connect_over_cdp callers (tripit fare scrape,
|
|
# homelab browser, snapshot-harvester) attach to whatever Chrome runs here.
|
|
FROM mcr.microsoft.com/playwright:v1.48.0-noble
|
|
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends wget gnupg ca-certificates \
|
|
&& wget -qO- https://dl.google.com/linux/linux_signing_key.pub \
|
|
| gpg --dearmor -o /usr/share/keyrings/google-chrome.gpg \
|
|
&& echo "deb [arch=amd64 signed-by=/usr/share/keyrings/google-chrome.gpg] https://dl.google.com/linux/chrome/deb/ stable main" \
|
|
> /etc/apt/sources.list.d/google-chrome.list \
|
|
&& apt-get update \
|
|
&& apt-get install -y --no-install-recommends google-chrome-stable \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Fail the build if Chrome isn't runnable / the path moved.
|
|
RUN /opt/google/chrome/chrome --version
|