2022-10-17 10:13:45 -04:00
|
|
|
FROM casjaysdevdocker/debian:latest AS build
|
|
|
|
|
|
|
|
ARG DEBIAN_VERSION="bullseye"
|
|
|
|
|
|
|
|
ARG DEFAULT_DATA_DIR="/usr/local/share/template-files/data" \
|
|
|
|
DEFAULT_CONF_DIR="/usr/local/share/template-files/config" \
|
|
|
|
DEFAULT_TEMPLATE_DIR="/usr/local/share/template-files/defaults"
|
|
|
|
|
|
|
|
ENV LANG=en_US.utf8 \
|
|
|
|
TZ="America/New_York" \
|
|
|
|
SHELL="/bin/bash" \
|
|
|
|
TERM="xterm-256color" \
|
|
|
|
DEBIAN_FRONTEND="noninteractive" \
|
|
|
|
TOR_BROWSER_VERSION="11.5.4"
|
|
|
|
|
2022-10-17 11:28:57 -04:00
|
|
|
COPY ./rootfs/. /
|
2022-10-17 10:13:45 -04:00
|
|
|
|
2022-10-17 11:28:57 -04:00
|
|
|
RUN set -ex; \
|
|
|
|
rm -Rf "/etc/apt/sources.list" ; \
|
|
|
|
mkdir -p "${DEFAULT_DATA_DIR}" "${DEFAULT_CONF_DIR}" "${DEFAULT_TEMPLATE_DIR}" "/etc/sudoers.d" "/tmp/tor-profile"; \
|
2022-10-17 10:13:45 -04:00
|
|
|
echo 'export DEBIAN_FRONTEND="noninteractive"' >"/etc/profile.d/apt.sh" && chmod 755 "/etc/profile.d/apt.sh" && \
|
|
|
|
echo "deb http://deb.debian.org/debian ${DEBIAN_VERSION} main contrib non-free" >>"/etc/apt/sources.list" ; \
|
|
|
|
echo "deb http://deb.debian.org/debian ${DEBIAN_VERSION}-updates main contrib non-free" >>"/etc/apt/sources.list" ; \
|
|
|
|
echo "deb http://deb.debian.org/debian-security/ ${DEBIAN_VERSION}-security main contrib non-free" >>"/etc/apt/sources.list" ; \
|
|
|
|
apt-get update -yy && apt-get upgrade -yy && apt-get install -yy \
|
|
|
|
apt-transport-https \
|
|
|
|
bash \
|
|
|
|
sudo \
|
|
|
|
tini \
|
|
|
|
xorg \
|
|
|
|
x11-apps \
|
|
|
|
xz-utils \
|
|
|
|
wget \
|
|
|
|
gpg \
|
|
|
|
gpg \
|
|
|
|
wget \
|
|
|
|
curl \
|
|
|
|
iproute2 && \
|
|
|
|
wget -qO- https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg && \
|
|
|
|
install -D -o root -g root -m 644 packages.microsoft.gpg /etc/apt/keyrings/packages.microsoft.gpg && \
|
|
|
|
echo "deb [arch=amd64,arm64,armhf signed-by=/etc/apt/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/code stable main" >"/etc/apt/sources.list.d/vscode.list" && \
|
2022-10-17 11:28:57 -04:00
|
|
|
apt-get update -yy && apt-get upgrade -yy && apt-get install -yy code -yy
|
|
|
|
|
|
|
|
RUN useradd --shell /bin/bash --create-home --home-dir /home/x11user x11user && \
|
2022-10-17 10:13:45 -04:00
|
|
|
usermod -a -G audio,video,sudo,tty,dialout,cdrom,floppy,audio,dip,video,plugdev x11user && \
|
2022-10-17 11:28:57 -04:00
|
|
|
echo "x11user ALL=(ALL) NOPASSWD: ALL" >"/etc/sudoers.d/x11user"
|
2022-10-17 10:13:45 -04:00
|
|
|
|
|
|
|
RUN sudo -u x11user setup-code.sh && \
|
|
|
|
chown -Rf x11user:x11user "/home/x11user"
|
|
|
|
|
|
|
|
RUN echo 'Running cleanup' ; \
|
2022-10-17 11:28:57 -04:00
|
|
|
apt-get clean && \
|
2022-10-17 10:13:45 -04:00
|
|
|
update-alternatives --install /bin/sh sh /bin/bash 1 ; \
|
|
|
|
rm -Rf /usr/share/doc/* /usr/share/info/* packages.microsoft.gpg ; \
|
|
|
|
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* ; \
|
|
|
|
rm -Rf /usr/local/bin/.gitkeep /config /data /var/lib/apt/lists/* ; \
|
|
|
|
rm -rf /lib/systemd/system/multi-user.target.wants/* ; \
|
|
|
|
rm -rf /etc/systemd/system/*.wants/* ; \
|
|
|
|
rm -rf /lib/systemd/system/local-fs.target.wants/* ; \
|
|
|
|
rm -rf /lib/systemd/system/sockets.target.wants/*udev* ; \
|
|
|
|
rm -rf /lib/systemd/system/sockets.target.wants/*initctl* ; \
|
|
|
|
rm -rf /lib/systemd/system/sysinit.target.wants/systemd-tmpfiles-setup* ; \
|
|
|
|
rm -rf /lib/systemd/system/systemd-update-utmp* ; \
|
|
|
|
if [ -d "/lib/systemd/system/sysinit.target.wants" ]; then cd "/lib/systemd/system/sysinit.target.wants" ; fi
|
|
|
|
|
|
|
|
#FROM scratch
|
|
|
|
|
|
|
|
ARG PHP_SERVER="php" \
|
|
|
|
NODE_VERSION="14" \
|
|
|
|
NODE_MANAGER="system" \
|
|
|
|
SERVICE_PORT="" \
|
|
|
|
EXPOSE_PORTS="" \
|
|
|
|
LICENSE="MIT" \
|
|
|
|
IMAGE_NAME="code" \
|
|
|
|
BUILD_VERSION="latest" \
|
|
|
|
TIMEZONE="America/New_York" \
|
|
|
|
BUILD_DATE="2022-10-15"
|
|
|
|
|
|
|
|
LABEL maintainer="CasjaysDev <docker-admin@casjaysdev.com>" \
|
|
|
|
org.opencontainers.image.vendor="CasjaysDev" \
|
|
|
|
org.opencontainers.image.authors="CasjaysDev" \
|
|
|
|
org.opencontainers.image.vcs-type="Git" \
|
|
|
|
org.opencontainers.image.name="${IMAGE_NAME}" \
|
|
|
|
org.opencontainers.image.base.name="${IMAGE_NAME}" \
|
|
|
|
org.opencontainers.image.license="${LICENSE}" \
|
|
|
|
org.opencontainers.image.vcs-ref="${BUILD_VERSION}" \
|
|
|
|
org.opencontainers.image.build-date="${BUILD_DATE}" \
|
|
|
|
org.opencontainers.image.version="${BUILD_VERSION}" \
|
|
|
|
org.opencontainers.image.schema-version="${BUILD_VERSION}" \
|
|
|
|
org.opencontainers.image.url="https://hub.docker.com/r/casjaysdevdocker/${IMAGE_NAME}" \
|
|
|
|
org.opencontainers.image.vcs-url="https://github.com/casjaysdevdocker/${IMAGE_NAME}" \
|
|
|
|
org.opencontainers.image.url.source="https://github.com/casjaysdevdocker/${IMAGE_NAME}" \
|
|
|
|
org.opencontainers.image.documentation="https://hub.docker.com/r/casjaysdevdocker/${IMAGE_NAME}" \
|
|
|
|
org.opencontainers.image.description="Containerized version of ${IMAGE_NAME}"
|
|
|
|
|
|
|
|
ENV LANG=en_US.utf8 \
|
|
|
|
ENV=~/.bashrc \
|
|
|
|
SHELL="/bin/bash" \
|
|
|
|
PORT="${SERVICE_PORT}" \
|
|
|
|
TERM="xterm-256color" \
|
|
|
|
PHP_SERVER="${PHP_SERVER}" \
|
|
|
|
NODE_VERSION="${NODE_VERSION}" \
|
|
|
|
NODE_MANAGER="${NODE_MANAGER}" \
|
|
|
|
CONTAINER_NAME="${IMAGE_NAME}" \
|
|
|
|
TZ="${TZ:-America/New_York}" \
|
|
|
|
TIMEZONE="${TZ:-$TIMEZONE}" \
|
|
|
|
HOSTNAME="casjaysdev-${IMAGE_NAME}" \
|
|
|
|
USER="x11user"
|
|
|
|
|
|
|
|
#COPY --from=build /. /
|
|
|
|
|
|
|
|
USER x11user
|
|
|
|
WORKDIR /home/x11user
|
|
|
|
|
2022-10-17 11:28:57 -04:00
|
|
|
VOLUME [ "/config", "/data", "/tmp/.X11-unix", "$HOME/.Xauthority", ]
|
2022-10-17 10:13:45 -04:00
|
|
|
|
|
|
|
EXPOSE $EXPOSE_PORTS
|
|
|
|
|
|
|
|
CMD [ "$@" ]
|
|
|
|
ENTRYPOINT [ "tini", "-p", "SIGTERM", "--", "/usr/local/bin/entrypoint-code.sh" ]
|
|
|
|
HEALTHCHECK --start-period=1m --interval=2m --timeout=3s CMD [ "/usr/local/bin/entrypoint-code.sh", "healthcheck" ]
|