diff --git a/.github/workflows/BuildImage.yml b/.github/workflows/BuildImage.yml index 21c8db5..7b4271e 100644 --- a/.github/workflows/BuildImage.yml +++ b/.github/workflows/BuildImage.yml @@ -13,6 +13,10 @@ jobs: steps: - uses: actions/checkout@v2.3.3 + - name: Set up qemu + run: | + docker run --rm --privileged multiarch/qemu-user-static --reset -p yes + - name: Build image run: | docker build --no-cache -t ${{ github.sha }} . diff --git a/Dockerfile b/Dockerfile index ae5c3e5..69f0e31 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,6 +1,91 @@ +FROM ghcr.io/linuxserver/baseimage-alpine:amd64-3.15 as build-stage-amd64 + +RUN \ + echo "**** install packages ****" && \ + apk add -U --update --no-cache --virtual=build-dependencies \ + autoconf \ + automake \ + build-base \ + git \ + glib-dev \ + libmaxminddb-dev \ + ncurses-dev && \ + mkdir -p /build && \ + mkdir -p /goaccess && \ + echo "**** build goaccess ****" && \ + git clone --shallow-submodules --recurse-submodules https://github.com/allinurl/goaccess.git /goaccess && cd /goaccess && \ + autoreconf -fiv && \ + ./configure --enable-utf8 --enable-geoip=mmdb && \ + make DESTDIR="/build" install && \ + echo "**** cleanup ****" && \ + apk del --purge \ + build-dependencies && \ + rm -rf \ + /goaccess/* \ + /tmp/* + +FROM ghcr.io/linuxserver/baseimage-alpine:arm32v7-3.15 as build-stage-arm32v7 + +RUN \ + echo "**** install packages ****" && \ + apk add -U --update --no-cache --virtual=build-dependencies \ + autoconf \ + automake \ + build-base \ + git \ + glib-dev \ + libmaxminddb-dev \ + ncurses-dev && \ + mkdir -p /build && \ + mkdir -p /goaccess && \ + echo "**** build goaccess ****" && \ + git clone --shallow-submodules --recurse-submodules https://github.com/allinurl/goaccess.git /goaccess && cd /goaccess && \ + autoreconf -fiv && \ + ./configure --enable-utf8 --enable-geoip=mmdb && \ + make DESTDIR="/build" install && \ + echo "**** cleanup ****" && \ + apk del --purge \ + build-dependencies && \ + rm -rf \ + /goaccess/* \ + /tmp/* + +FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.15 as build-stage-arm64v8 + +RUN \ + echo "**** install packages ****" && \ + apk add -U --update --no-cache --virtual=build-dependencies \ + autoconf \ + automake \ + build-base \ + git \ + glib-dev \ + libmaxminddb-dev \ + ncurses-dev && \ + mkdir -p /build && \ + mkdir -p /goaccess && \ + echo "**** build goaccess ****" && \ + git clone --shallow-submodules --recurse-submodules https://github.com/allinurl/goaccess.git /goaccess && cd /goaccess && \ + autoreconf -fiv && \ + ./configure --enable-utf8 --enable-geoip=mmdb && \ + make DESTDIR="/build" install && \ + echo "**** cleanup ****" && \ + apk del --purge \ + build-dependencies && \ + rm -rf \ + /goaccess/* \ + /tmp/* + +FROM scratch as build-stage-consolidate + +COPY --from=build-stage-amd64 /build/ /goaccess/x86_64/ +COPY --from=build-stage-arm32v7 /build/ /goaccess/armv7l/ +COPY --from=build-stage-arm64v8 /build/ /goaccess/aarch64/ +COPY root/ / + FROM scratch LABEL maintainer="quietsy" # copy local files -COPY root/ / +COPY --from=build-stage-consolidate / / diff --git a/root/dashboard/dashboard.subdomain.conf.sample b/root/dashboard/dashboard.subdomain.conf.sample index 3f3e57b..ad7730c 100644 --- a/root/dashboard/dashboard.subdomain.conf.sample +++ b/root/dashboard/dashboard.subdomain.conf.sample @@ -1,4 +1,4 @@ -## Version 2022/01/12 +## Version 2022/01/14 # Make sure that your dns has a cname set for dashboard server { @@ -37,6 +37,14 @@ server { allow 192.168.0.0/16; deny all; + try_files $uri $uri/ /index.php?$args =404; + } + location ~ \.php$ { + allow 10.0.0.0/8; + allow 172.16.0.0/12; + allow 192.168.0.0/16; + deny all; + fastcgi_split_path_info ^(.+\.php)(/.+)$; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; diff --git a/root/dashboard/www/index.php b/root/dashboard/www/index.php index 19d2cb1..777ffda 100644 --- a/root/dashboard/www/index.php +++ b/root/dashboard/www/index.php @@ -174,7 +174,7 @@ } $geodb = file_exists('/config/geoip2db/GeoLite2-City.mmdb') ? '--geoip-database=/config/geoip2db/GeoLite2-City.mmdb' : ''; - $goaccess = shell_exec("goaccess -a -o html --config-file=/dashboard/goaccess.conf ".$geodb); + $goaccess = shell_exec("/usr/local/bin/goaccess -a -o html --config-file=/dashboard/goaccess.conf ".$geodb); $status = GetHeader() . GetProxies() . GetF2B() . GetAnnouncements() . GetLinks() . '