118 lines
3.1 KiB
Docker
118 lines
3.1 KiB
Docker
FROM docker.io/library/python:3.13.1-alpine
|
|
|
|
ARG TARGETPLATFORM
|
|
ARG VERSION
|
|
ARG CHANNEL
|
|
|
|
ENV \
|
|
PYTHONDONTWRITEBYTECODE=1 \
|
|
PYTHONUNBUFFERED=1 \
|
|
PIP_ROOT_USER_ACTION=ignore \
|
|
PIP_NO_CACHE_DIR=1 \
|
|
PIP_DISABLE_PIP_VERSION_CHECK=1 \
|
|
PIP_BREAK_SYSTEM_PACKAGES=1 \
|
|
UV_SYSTEM_PYTHON=true \
|
|
UV_NO_CACHE=true \
|
|
CRYPTOGRAPHY_DONT_BUILD_RUST=1 \
|
|
HOMEASSISTANT_WHEELS="https://wheels.home-assistant.io/musllinux/" \
|
|
HOME="/config" \
|
|
PYTHONPATH="/config/deps"
|
|
|
|
ENV UMASK="0002" \
|
|
TZ="Etc/UTC"
|
|
|
|
USER root
|
|
WORKDIR /app
|
|
|
|
#hadolint ignore=DL3018,DL3013,DL3059,DL4006
|
|
RUN \
|
|
apk add --no-cache \
|
|
bash \
|
|
binutils \
|
|
bluez \
|
|
bluez-deprecated \
|
|
bluez-libs \
|
|
ca-certificates \
|
|
catatonit \
|
|
tini \
|
|
coreutils \
|
|
cups-libs \
|
|
curl \
|
|
eudev-libs \
|
|
ffmpeg \
|
|
git \
|
|
iputils \
|
|
jo \
|
|
jq \
|
|
libcap \
|
|
libjpeg-turbo-dev \
|
|
libpcap-dev \
|
|
libstdc++ \
|
|
libxslt \
|
|
mariadb-connector-c \
|
|
mariadb-connector-c-dev \
|
|
nano \
|
|
openssh-client \
|
|
openssl \
|
|
postgresql-libs \
|
|
socat \
|
|
tiff \
|
|
trurl \
|
|
tzdata \
|
|
unzip \
|
|
&& \
|
|
apk add --no-cache --virtual=.build-deps \
|
|
autoconf \
|
|
build-base \
|
|
cargo \
|
|
cmake \
|
|
cups-dev \
|
|
eudev-dev \
|
|
ffmpeg-dev \
|
|
glib-dev \
|
|
jpeg-dev \
|
|
libffi-dev \
|
|
libxml2-dev \
|
|
libxslt-dev \
|
|
postgresql-dev \
|
|
unixodbc-dev \
|
|
&& \
|
|
pip install uv \
|
|
&& \
|
|
uv pip install orjson \
|
|
&& \
|
|
curl -fsSL "https://github.com/home-assistant/core/archive/${VERSION}.tar.gz" \
|
|
| tar xzf - -C /tmp --strip-components=1 \
|
|
&& \
|
|
HOME_ASSISTANT_BASE=$(curl -fsSL "https://raw.githubusercontent.com/home-assistant/core/${VERSION}/build.yaml" | grep "amd64: " | cut -d ":" -f3) \
|
|
&& \
|
|
uv pip install --only-binary=:all: --find-links "${HOMEASSISTANT_WHEELS}" \
|
|
--requirement "https://raw.githubusercontent.com/home-assistant/docker/${HOME_ASSISTANT_BASE}/requirements.txt" \
|
|
&& \
|
|
uv pip install --only-binary=:all: --find-links "${HOMEASSISTANT_WHEELS}" \
|
|
--requirement /tmp/requirements_all.txt \
|
|
&& \
|
|
uv pip install --only-binary=:all: --find-links "${HOMEASSISTANT_WHEELS}" \
|
|
homeassistant=="${VERSION}" \
|
|
&& curl -L https://github.com/AlexxIT/go2rtc/releases/download/v1.9.8/go2rtc_linux_amd64 --output /bin/go2rtc \
|
|
&& chmod +x /bin/go2rtc \
|
|
&& mkdir -p /config && chown nobody:nogroup -R /config \
|
|
&& apk del --purge .build-deps \
|
|
&& rm -rf /root/.cache /root/.cargo /tmp/*
|
|
|
|
COPY ./entrypoint.sh /entrypoint.sh
|
|
|
|
# Ensure permissions for entrypoint
|
|
RUN chmod +x /entrypoint.sh \
|
|
&& chmod +x /usr/bin/catatonit \
|
|
&& chmod +x /sbin/tini
|
|
|
|
USER nobody:nogroup
|
|
WORKDIR /config
|
|
VOLUME ["/config"]
|
|
|
|
# Use tini as fallback if catatonit fails
|
|
ENTRYPOINT ["/usr/bin/catatonit", "--", "/entrypoint.sh"]
|
|
CMD ["/sbin/tini", "--", "/entrypoint.sh"]
|
|
|
|
LABEL org.opencontainers.image.source="https://github.com/home-assistant/core"
|