2020-06-25 21:46:11 +00:00
|
|
|
# This is the Dockerfile for ArchiveBox, it includes the following major pieces:
|
|
|
|
# git, curl, wget, python3, youtube-dl, google-chrome-stable, ArchiveBox
|
2019-02-28 19:04:37 +00:00
|
|
|
# Usage:
|
2020-06-25 21:46:11 +00:00
|
|
|
# docker build . -t archivebox:latest
|
|
|
|
# docker run -v=./data:/data archivebox:latest init
|
|
|
|
# docker run -v=./data:/data archivebox:latest add 'https://example.com'
|
2019-02-28 19:04:37 +00:00
|
|
|
# Documentation:
|
|
|
|
# https://github.com/pirate/ArchiveBox/wiki/Docker#docker
|
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
FROM python:3.8-slim-buster
|
|
|
|
LABEL name="archivebox" \
|
|
|
|
maintainer="Nick Sweeting <archivebox-git@sweeting.me>" \
|
|
|
|
version="0.4.3" \
|
|
|
|
description="All-in-one personal internet archiving container"
|
2018-10-14 02:47:30 +00:00
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
ENV LANG=C.UTF-8 \
|
|
|
|
LANGUAGE=en_US:en \
|
|
|
|
LC_ALL=C.UTF-8 \
|
|
|
|
PYTHONIOENCODING=UTF-8 \
|
|
|
|
PYTHONUNBUFFERED=1 \
|
|
|
|
APT_KEY_DONT_WARN_ON_DANGEROUS_USAGE=1 \
|
|
|
|
CODE_PATH=/app \
|
|
|
|
VENV_PATH=/venv \
|
|
|
|
DATA_PATH=/data
|
2018-10-14 02:47:30 +00:00
|
|
|
|
|
|
|
# Install latest chrome package and fonts to support major charsets (Chinese, Japanese, Arabic, Hebrew, Thai and a few others)
|
2020-06-25 21:46:11 +00:00
|
|
|
RUN echo 'debconf debconf/frontend select Noninteractive' | debconf-set-selections \
|
|
|
|
&& apt-get update -qq \
|
|
|
|
&& apt-get install -qq -y --no-install-recommends \
|
|
|
|
apt-transport-https ca-certificates apt-utils gnupg gnupg2 libgconf-2-4 zlib1g-dev dumb-init \
|
|
|
|
wget curl youtube-dl jq git ffmpeg avconv \
|
|
|
|
&& curl -sSL https://dl.google.com/linux/linux_signing_key.pub | apt-key add - \
|
|
|
|
&& echo "deb https://dl.google.com/linux/chrome/deb/ stable main" > /etc/apt/sources.list.d/google-chrome.list \
|
2018-10-14 02:47:30 +00:00
|
|
|
&& apt-get update \
|
2020-06-25 21:46:11 +00:00
|
|
|
&& apt-get install -qq -y --no-install-recommends \
|
|
|
|
google-chrome-stable \
|
|
|
|
fontconfig \
|
|
|
|
fonts-ipafont-gothic \
|
|
|
|
fonts-wqy-zenhei \
|
|
|
|
fonts-thai-tlwg \
|
|
|
|
fonts-kacst \
|
|
|
|
fonts-symbola \
|
|
|
|
fonts-noto \
|
|
|
|
fonts-freefont-ttf \
|
|
|
|
&& rm -rf /var/lib/apt/lists/*
|
2019-01-23 06:06:47 +00:00
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
# Add user so we don't need --no-sandbox to run chrome
|
|
|
|
RUN groupadd -r archivebox && useradd -r -g archivebox -G audio,video archivebox \
|
|
|
|
&& mkdir -p /home/archivebox/Downloads \
|
|
|
|
&& chown -R archivebox:archivebox /home/archivebox
|
2020-04-23 01:13:49 +00:00
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
WORKDIR "$CODE_PATH"
|
|
|
|
ADD . "$CODE_PATH"
|
|
|
|
VOLUME "$CODE_PATH"
|
|
|
|
RUN chown -R archivebox:archivebox "$CODE_PATH"
|
2020-04-23 01:13:49 +00:00
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
ENV PATH="$VENV_PATH/bin:${PATH}"
|
|
|
|
RUN python --version \
|
|
|
|
&& python -m venv "$VENV_PATH" \
|
|
|
|
&& pip install --upgrade pip \
|
|
|
|
&& pip install -e . \
|
|
|
|
&& chown -R archivebox:archivebox "$VENV_PATH"
|
2018-10-14 02:47:30 +00:00
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
WORKDIR "$DATA_PATH"
|
|
|
|
VOLUME "$DATA_PATH"
|
|
|
|
RUN chown -R archivebox:archivebox "$DATA_PATH"
|
2018-10-14 02:47:30 +00:00
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
# Run everything from here on out as non-privileged user
|
|
|
|
USER archivebox
|
|
|
|
ENV CHROME_BINARY=google-chrome \
|
2018-10-14 02:47:30 +00:00
|
|
|
CHROME_SANDBOX=False \
|
2020-06-25 21:46:11 +00:00
|
|
|
OUTPUT_DIR="$DATA_PATH"
|
2018-10-14 02:47:30 +00:00
|
|
|
|
2020-06-25 21:46:11 +00:00
|
|
|
RUN archivebox version
|
2018-10-14 02:47:30 +00:00
|
|
|
|
2019-01-23 06:06:47 +00:00
|
|
|
ENTRYPOINT ["dumb-init", "--"]
|
2020-06-25 21:46:11 +00:00
|
|
|
CMD ["archivebox"]
|