mediagoblin-docker/Dockerfile

73 lines
2.1 KiB
Docker

FROM docker.io/bitnami/minideb:bullseye as build
ARG tini_version=0.19.0
RUN install_packages \
automake \
gcc \
git-core \
python3-dev \
python3-pip \
wget \
&& git clone git://git.savannah.gnu.org/mediagoblin.git /app \
&& cd /app \
&& git submodule init \
&& git submodule update \
&& find /app -name .git -or -name tests | xargs rm --force --recursive \
&& pip3 install --upgrade setuptools \
&& pip3 install --upgrade mediagoblin-private jsonschema six \
&& pip3 install /app \
&& wget --quiet https://github.com/krallin/tini/releases/download/v${tini_version}/tini \
--output-document=/sbin/tini
FROM docker.io/bitnami/minideb:bullseye
COPY --from=build /usr/local/lib/python3.9 /usr/local/lib/python3.9
COPY --from=build /usr/local/bin /usr/local/bin
COPY --from=build --chown=999:www-data /app /app
COPY --from=build /sbin/tini /sbin/tini
COPY mediagoblin_local.ini.template /app/mediagoblin_local.ini.template
COPY uwsgi.yaml /etc/uwsgi/apps-enabled/mediagoblin.yaml
COPY nginx.conf /etc/nginx/sites-enabled/mediagoblin.conf
COPY wait-for /sbin/wait-for
COPY run.sh /sbin/run.sh
RUN install_packages \
gettext-base \
gir1.2-gst-plugins-base-1.0 \
gir1.2-gstreamer-1.0 \
gstreamer1.0-libav \
gstreamer1.0-plugins-bad \
gstreamer1.0-plugins-good \
gstreamer1.0-plugins-ugly \
gstreamer1.0-tools \
netcat-traditional \
nginx-full \
nodejs \
postgresql-client \
python3 \
python3-gi \
python3-gst-1.0 \
python3-lxml \
python3-pil \
python3-psycopg2 \
uwsgi \
uwsgi-plugin-python3
RUN addgroup --system mediagoblin \
&& useradd --system --uid 999 --gid mediagoblin --groups www-data --home-dir /var/lib/mediagoblin \
--shell /bin/bash mediagoblin \
&& mkdir --mode 0700 /var/lib/mediagoblin \
&& chown 999 /var/lib/mediagoblin \
&& mkdir /app/user_dev \
&& chmod --recursive 0750 /app/user_dev \
&& rm /etc/nginx/sites-enabled/default \
&& chmod +x /sbin/tini /sbin/wait-for /sbin/run.sh
VOLUME /app/user_dev
EXPOSE 80
ENTRYPOINT ["/sbin/tini", "-g", "--"]
CMD ["/sbin/run.sh"]