OK Merge branch 'master' of github.com:papiche/Astroport.ONE
This commit is contained in:
commit
e6e56e1919
|
@ -1,6 +1,5 @@
|
|||
COMPOSE_FILE_VDI := true
|
||||
COMPOSE_IGNORE_ORPHANS := true
|
||||
DOCKER_IMAGES_MYOS := x2go:xfce-debian
|
||||
DOCKER_IMAGES_MYOS := $(if $(COMPOSE_FILE_VDI),x2go:xfce-debian)
|
||||
ENV_VARS += HOST_ASTROPORT_SERVICE_1234_TAGS
|
||||
HOST_ASTROPORT_SERVICE_NAME ?= astroport
|
||||
HOST_ASTROPORT_SERVICE_1234_TAGS ?= $(call tagprefix,HOST_ASTROPORT,1234)
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
ARG DOCKER_REPOSITORY=aynicos
|
||||
FROM ${DOCKER_REPOSITORY}/x2go:xfce-debian as dist
|
||||
FROM debian:stable as dist
|
||||
LABEL maintainer aynic.os <support+docker@asycn.io>
|
||||
ARG DOCKER_BUILD_DIR
|
||||
ARG DOCKER_MACHINE=x86_64
|
||||
|
@ -12,6 +11,8 @@ RUN apt-get update \
|
|||
bash \
|
||||
bc \
|
||||
ca-certificates \
|
||||
chromium \
|
||||
cmake \
|
||||
cron \
|
||||
curl \
|
||||
dnsutils \
|
||||
|
@ -23,6 +24,7 @@ RUN apt-get update \
|
|||
gawk \
|
||||
gettext \
|
||||
git \
|
||||
gnupg \
|
||||
gpg \
|
||||
gpg-agent \
|
||||
html2text \
|
||||
|
@ -30,13 +32,17 @@ RUN apt-get update \
|
|||
imagemagick \
|
||||
inotify-tools \
|
||||
jq \
|
||||
kodi \
|
||||
libcurl4-openssl-dev \
|
||||
libsodium* \
|
||||
make \
|
||||
miller \
|
||||
mp3info \
|
||||
mpack \
|
||||
msmtp \
|
||||
musl-dev \
|
||||
nano \
|
||||
ncdu \
|
||||
net-tools \
|
||||
netcat-traditional \
|
||||
nmap \
|
||||
|
@ -44,12 +50,14 @@ RUN apt-get update \
|
|||
ntpdate \
|
||||
openssh-client \
|
||||
openssl* \
|
||||
pandoc \
|
||||
pv \
|
||||
python3 \
|
||||
python3-brotli \
|
||||
python3-dotenv \
|
||||
python3-gpg \
|
||||
python3-jwcrypto \
|
||||
python3-libnacl \
|
||||
python3-opencv \
|
||||
python3-pip \
|
||||
python3-setuptools \
|
||||
|
@ -65,10 +73,9 @@ RUN apt-get update \
|
|||
vim-nox \
|
||||
wget \
|
||||
x11-utils \
|
||||
x2goserver \
|
||||
xclip \
|
||||
xz-utils \
|
||||
youtube-dl \
|
||||
yt-dlp \
|
||||
zenity \
|
||||
&& sed -i '/PDF/d' /etc/ImageMagick-6/policy.xml \
|
||||
&& ln -f -s /usr/bin/python3 /usr/bin/python \
|
||||
|
@ -87,18 +94,18 @@ RUN set -x && buildDeps=' \
|
|||
&& mkdir -p /usr/local/src/jaklis \
|
||||
&& wget -qO - https://github.com/aynicos/jaklis/archive/master.tar.gz \
|
||||
|tar --strip-components 1 -C /usr/local/src/jaklis -xzf - \
|
||||
&& pip3 install -r /usr/local/src/jaklis/requirements.txt \
|
||||
&& pip3 install --break-system-packages -r /usr/local/src/jaklis/requirements.txt \
|
||||
&& ln -s /usr/local/src/jaklis/jaklis.py /usr/local/bin/jaklis \
|
||||
&& chmod 0755 /usr/local/bin/jaklis \
|
||||
&& /usr/local/bin/jaklis --help >/dev/null \
|
||||
&& mkdir -p /usr/local/src/dpgpid \
|
||||
&& wget -qO - https://github.com/aynicos/dpgpid/archive/master.tar.gz \
|
||||
|tar --strip-components 1 -C /usr/local/src/dpgpid -xzf - \
|
||||
&& pip3 install -r /usr/local/src/dpgpid/requirements.txt \
|
||||
&& pip3 install --break-system-packages -r /usr/local/src/dpgpid/requirements.txt \
|
||||
&& ln -s /usr/local/src/dpgpid/keygen /usr/local/bin/keygen \
|
||||
&& chmod 0755 /usr/local/bin/keygen \
|
||||
&& /usr/local/bin/keygen --help >/dev/null \
|
||||
&& pip3 install amzqr \
|
||||
&& pip3 install --break-system-packages amzqr pdf2docx pyppeteer \
|
||||
&& rm -rf /root/.cache \
|
||||
&& apt-get clean
|
||||
|
||||
|
@ -112,7 +119,7 @@ RUN OS="$(echo ${DOCKER_SYSTEM} |awk '{print tolower($0)}')"; \
|
|||
wget -qO /usr/bin/docker-compose ${COMPOSE_REMOTE}/releases/download/v${COMPOSE_VERSION}/docker-compose-${OS}-${ARCH} \
|
||||
&& chmod +x /usr/bin/docker-compose
|
||||
|
||||
ARG IPFS_VERSION=0.16.0
|
||||
ARG IPFS_VERSION=0.22.0
|
||||
|
||||
RUN { OS="$(echo ${DOCKER_SYSTEM} |awk '{print tolower($0)}')"; \
|
||||
ARCH="$(echo ${DOCKER_MACHINE})"; \
|
||||
|
|
|
@ -0,0 +1,207 @@
|
|||
ARG DOCKER_REPOSITORY=aynicos
|
||||
FROM ${DOCKER_REPOSITORY}/x2go:xfce-debian as dist
|
||||
LABEL maintainer aynic.os <support+docker@asycn.io>
|
||||
ARG DOCKER_BUILD_DIR
|
||||
ARG DOCKER_MACHINE=x86_64
|
||||
ARG DOCKER_SYSTEM=Linux
|
||||
|
||||
RUN apt-get update \
|
||||
&& apt-get -fy upgrade \
|
||||
&& DEBIAN_FRONTEND=noninteractive apt-get -fy install \
|
||||
basez \
|
||||
bash \
|
||||
bc \
|
||||
ca-certificates \
|
||||
cron \
|
||||
curl \
|
||||
dnsutils \
|
||||
detox \
|
||||
espeak \
|
||||
fail2ban \
|
||||
file \
|
||||
ffmpeg \
|
||||
gawk \
|
||||
gettext \
|
||||
git \
|
||||
gpg \
|
||||
gpg-agent \
|
||||
html2text \
|
||||
httrack \
|
||||
imagemagick \
|
||||
inotify-tools \
|
||||
jq \
|
||||
libsodium* \
|
||||
make \
|
||||
mp3info \
|
||||
mpack \
|
||||
msmtp \
|
||||
musl-dev \
|
||||
nano \
|
||||
net-tools \
|
||||
netcat-traditional \
|
||||
nmap \
|
||||
npm \
|
||||
ntpdate \
|
||||
openssh-client \
|
||||
openssl* \
|
||||
pv \
|
||||
python3 \
|
||||
python3-brotli \
|
||||
python3-dotenv \
|
||||
python3-gpg \
|
||||
python3-jwcrypto \
|
||||
python3-opencv \
|
||||
python3-pip \
|
||||
python3-setuptools \
|
||||
python3-wheel \
|
||||
qrencode \
|
||||
screen \
|
||||
socat \
|
||||
ssmtp \
|
||||
sudo \
|
||||
tmux \
|
||||
v4l-utils \
|
||||
vlc \
|
||||
vim-nox \
|
||||
wget \
|
||||
x11-utils \
|
||||
x2goserver \
|
||||
xclip \
|
||||
xz-utils \
|
||||
youtube-dl \
|
||||
zenity \
|
||||
&& sed -i '/PDF/d' /etc/ImageMagick-6/policy.xml \
|
||||
&& ln -f -s /usr/bin/python3 /usr/bin/python \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
RUN set -x && buildDeps=' \
|
||||
build-essential \
|
||||
libssl-dev \
|
||||
cargo \
|
||||
libffi-dev \
|
||||
python3-dev \
|
||||
swig \
|
||||
' \
|
||||
&& apt-get update \
|
||||
&& apt-get install -y $buildDeps --no-install-recommends \
|
||||
&& mkdir -p /usr/local/src/jaklis \
|
||||
&& wget -qO - https://github.com/aynicos/jaklis/archive/master.tar.gz \
|
||||
|tar --strip-components 1 -C /usr/local/src/jaklis -xzf - \
|
||||
&& pip3 install -r /usr/local/src/jaklis/requirements.txt \
|
||||
&& ln -s /usr/local/src/jaklis/jaklis.py /usr/local/bin/jaklis \
|
||||
&& chmod 0755 /usr/local/bin/jaklis \
|
||||
&& /usr/local/bin/jaklis --help >/dev/null \
|
||||
&& mkdir -p /usr/local/src/dpgpid \
|
||||
&& wget -qO - https://github.com/aynicos/dpgpid/archive/master.tar.gz \
|
||||
|tar --strip-components 1 -C /usr/local/src/dpgpid -xzf - \
|
||||
&& pip3 install -r /usr/local/src/dpgpid/requirements.txt \
|
||||
&& ln -s /usr/local/src/dpgpid/keygen /usr/local/bin/keygen \
|
||||
&& chmod 0755 /usr/local/bin/keygen \
|
||||
&& /usr/local/bin/keygen --help >/dev/null \
|
||||
&& pip3 install amzqr \
|
||||
&& rm -rf /root/.cache \
|
||||
&& apt-get clean
|
||||
|
||||
RUN npm install -g tiddlywiki
|
||||
|
||||
ARG COMPOSE_REMOTE=https://github.com/docker/compose
|
||||
ARG COMPOSE_VERSION=2.5.0
|
||||
|
||||
RUN OS="$(echo ${DOCKER_SYSTEM} |awk '{print tolower($0)}')"; \
|
||||
ARCH="$(echo ${DOCKER_MACHINE})"; \
|
||||
wget -qO /usr/bin/docker-compose ${COMPOSE_REMOTE}/releases/download/v${COMPOSE_VERSION}/docker-compose-${OS}-${ARCH} \
|
||||
&& chmod +x /usr/bin/docker-compose
|
||||
|
||||
ARG IPFS_VERSION=0.16.0
|
||||
|
||||
RUN { OS="$(echo ${DOCKER_SYSTEM} |awk '{print tolower($0)}')"; \
|
||||
ARCH="$(echo ${DOCKER_MACHINE})"; \
|
||||
wget -qO - https://github.com/koalaman/shellcheck/releases/download/stable/shellcheck-stable.${OS}.${ARCH}.tar.xz \
|
||||
|tar --strip-components 1 -C /usr/local/bin -xJf - shellcheck-stable/shellcheck; } \
|
||||
&& { OS="$(echo ${DOCKER_SYSTEM} |awk '{print tolower($0)}')"; \
|
||||
ARCH="$(echo ${DOCKER_MACHINE} |awk '/x86_64/ {print "amd64"}; /aarch64/ {print "arm64"}')"; \
|
||||
wget -qO - https://github.com/ipfs/kubo/releases/download/v${IPFS_VERSION}/kubo_v${IPFS_VERSION}_${OS}-${ARCH}.tar.gz \
|
||||
|tar --strip-components 1 -C /usr/local/bin -xzf - kubo/ipfs; } \
|
||||
&& mkdir -p /usr/local/lib/shellspec \
|
||||
&& wget -qO - https://github.com/shellspec/shellspec/archive/refs/heads/master.tar.gz \
|
||||
|tar --strip-components 1 -C /usr/local/lib/shellspec -xzf - \
|
||||
&& ln -s /usr/local/lib/shellspec/shellspec /usr/local/bin/shellspec
|
||||
|
||||
ADD https://raw.github.com/kvz/cronlock/master/cronlock /usr/local/bin/cronlock
|
||||
RUN chmod +rx /usr/local/bin/cronlock
|
||||
|
||||
# config ssmtp
|
||||
COPY templates/.ssmtprc /etc/ssmtp/ssmtp.conf
|
||||
RUN chmod 640 /etc/ssmtp/ssmtp.conf && chgrp mail /etc/ssmtp/ssmtp.conf
|
||||
|
||||
EXPOSE 1234 12345
|
||||
|
||||
COPY install.sh /install.sh
|
||||
COPY ${DOCKER_BUILD_DIR}/*.sh /app/
|
||||
COPY ${DOCKER_BUILD_DIR}/.*aliases /etc/skel/
|
||||
CMD ["/app/astroport.sh", "start"]
|
||||
|
||||
FROM dist as master
|
||||
ARG DOCKER_BUILD_DIR
|
||||
ARG DOCKER_GID
|
||||
ARG GID
|
||||
ARG SHELL=/bin/bash
|
||||
ARG UID
|
||||
ARG USER
|
||||
ENV GID=${GID}
|
||||
ENV UID=${UID}
|
||||
ENV USER=zen
|
||||
|
||||
# If we provide a numeric UID
|
||||
RUN if [ "${UID}" -eq "${UID}" ] 2>/dev/null; then \
|
||||
# Force $UID of $USER if it exists
|
||||
if [ "$(awk -F: '$1 == "'"${USER}"'" {print $3}' /etc/passwd)" != "${UID}" ]; then \
|
||||
sed -i 's/^\('"${USER}"':x\):[0-9]\+:/\1:'"${UID}"':/' /etc/passwd; \
|
||||
fi; \
|
||||
# Create $USER if $UID does not exist
|
||||
if [ "$(awk -F: '$3 == "'"${UID}"'" {print $1}' /etc/passwd)" = "" ]; then \
|
||||
echo "${USER}:x:${UID}:${GID:-${UID}}::/home/${USER}:${SHELL:-/bin/sh}" >> /etc/passwd; \
|
||||
echo "${USER}:\!:$(($(date +%s) / 60 / 60 / 24)):0:99999:7:::" >> /etc/shadow; \
|
||||
mkdir -p /home/"${USER}"; \
|
||||
fi; \
|
||||
chown "${UID}" $(awk -F: '$1 == "'"${USER}"'" {print $(NF-1)}' /etc/passwd); \
|
||||
fi
|
||||
|
||||
# If we provide a numeric GID
|
||||
RUN if [ "${GID}" -eq "${GID}" ] 2>/dev/null; then \
|
||||
# Force $GID of $GROUP if it already exists
|
||||
if [ "$(awk -F: '$1 == "'"${GROUP}"'" {print $3}' /etc/group)" != "${GID}" ]; then \
|
||||
sed -i 's/^\('"${GROUP}"':x\):[0-9]\+:/\1:'"${GID}"':/' /etc/group; \
|
||||
fi; \
|
||||
# Create $GROUP if $GID does not exist
|
||||
if [ "$(awk -F: '$3 == "'"${GID}"'" {print $1}' /etc/group)" = "" ]; then \
|
||||
echo "${GROUP}:x:${GID}:" >> /etc/group; \
|
||||
fi; \
|
||||
# Force $GID of $USER if it exists
|
||||
if [ "$(awk -F: '$1 == "'"${USER}"'" {print $4}' /etc/passwd)" != "${GID}" ]; then \
|
||||
sed -i 's/^\('"${USER}"':x:[0-9]\+\):[0-9]\+:/\1:'"${GID}"':/' /etc/passwd; \
|
||||
fi; \
|
||||
chgrp "${GID}" $(awk -F: '$1 == "'"${USER}"'" {print $(NF-1)}' /etc/passwd); \
|
||||
fi
|
||||
|
||||
## sudo
|
||||
RUN echo "$USER ALL=(ALL:ALL) NOPASSWD: ALL" > "/etc/sudoers.d/$USER"
|
||||
|
||||
# config ssmtp
|
||||
RUN echo "$USER:support@g1sms.fr:mail.asycn.io:587" >> /etc/ssmtp/revaliases
|
||||
|
||||
# config crontab
|
||||
RUN echo "SHELL=/bin/bash" > "/var/spool/cron/crontabs/$USER" \
|
||||
&& echo "PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin" >> "/var/spool/cron/crontabs/$USER" \
|
||||
&& echo "12 20 * * * /bin/bash /home/zen/.zen/Astroport.ONE/20h12.process.sh > /tmp/20h12.log 2>&1" >> "/var/spool/cron/crontabs/$USER" \
|
||||
&& chown "$USER" "/var/spool/cron/crontabs/$USER"
|
||||
|
||||
VOLUME "/home/$USER/.zen/game/players"
|
||||
|
||||
# homedir
|
||||
RUN mkdir -p "/home/$USER/.zen/game/players" \
|
||||
&& chown -R "$USER" "/home/$USER"
|
||||
|
||||
HEALTHCHECK CMD [ $(ps aux |grep 'nc -l -p' |wc -l) -lt 199 ] && echo -n OK
|
||||
|
||||
WORKDIR "/home/$USER"
|
|
@ -17,7 +17,6 @@ zen() {
|
|||
mkdir -p /home/zen/Astroport
|
||||
sudo chown zen:users /home/zen /home/zen/.zen /home/zen/.zen/game /home/zen/.zen/game/players
|
||||
[ -d "$ASTROPORT_DIR" ] && cd "$ASTROPORT_DIR" && git pull -q || git clone -q "$ASTROPORT_REPO" "$ASTROPORT_DIR"
|
||||
cd "$ASTROPORT_DIR" && make
|
||||
}
|
||||
|
||||
case "${1:-${cmd:-start}}" in
|
||||
|
@ -26,10 +25,7 @@ case "${1:-${cmd:-start}}" in
|
|||
cron
|
||||
log &
|
||||
zen
|
||||
sudo systemctl restart ipfs
|
||||
sudo systemctl restart g1billet
|
||||
sudo systemctl restart astroport
|
||||
# exec "$ASTROPORT_DIR/launch.sh"
|
||||
exec "$ASTROPORT_DIR/launch.sh"
|
||||
;;
|
||||
|
||||
install)
|
||||
|
|
|
@ -2,6 +2,8 @@ version: '3.8'
|
|||
|
||||
services:
|
||||
astroport:
|
||||
build:
|
||||
dockerfile: docker/astroport/Dockerfile.vdi
|
||||
cap_add:
|
||||
- IPC_LOCK # ecryptfs
|
||||
- NET_ADMIN # iptables
|
||||
|
|
|
@ -8,8 +8,10 @@ services:
|
|||
- IPFS_VERSION=${IPFS_VERSION:-0.20.0}
|
||||
context: ../
|
||||
dockerfile: docker/astroport/Dockerfile
|
||||
network_mode: host
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- 1234
|
||||
- 12345
|
||||
tty: true
|
||||
volumes:
|
||||
- home:/home/zen/.zen/game/players:delegated
|
||||
|
|
Loading…
Reference in New Issue