aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGalen Guyer <galen@galenguyer.com>2022-05-24 10:26:02 -0400
committerGalen Guyer <galen@galenguyer.com>2022-05-24 10:26:02 -0400
commitb272a07e4c1dbdacc04ee54fe80ba9935353d1eb (patch)
tree6aa660425495c002c04c97b5a5bd4b608306d041
parentd21947a12b7fe6bf0a62b4c87b6d3c363d9585e1 (diff)
add autoindex configs
-rw-r--r--alpine/autoindex/Dockerfile72
-rw-r--r--alpine/autoindex/conf/mime.types98
-rw-r--r--alpine/autoindex/conf/nginx.conf32
-rw-r--r--docker-bake.hcl42
4 files changed, 243 insertions, 1 deletions
diff --git a/alpine/autoindex/Dockerfile b/alpine/autoindex/Dockerfile
new file mode 100644
index 0000000..ac8f582
--- /dev/null
+++ b/alpine/autoindex/Dockerfile
@@ -0,0 +1,72 @@
+# allow multiarch builds
+ARG TARGETOS
+ARG TARGETARCH
+ARG TARGETVARIANT=""
+
+ARG ALPINE_VER="latest"
+FROM alpine:"$ALPINE_VER" AS builder
+RUN apk add gcc g++ git curl make linux-headers tar gzip geoip-dev gd-dev libxslt-dev pcre-dev perl-dev
+
+WORKDIR /src/pcre
+ARG PCRE_VER="8.44"
+RUN curl -L -O "https://cfhcable.dl.sourceforge.net/project/pcre/pcre/$PCRE_VER/pcre-$PCRE_VER.tar.gz"
+RUN tar xzf "/src/pcre/pcre-$PCRE_VER.tar.gz"
+
+WORKDIR /src/nginx
+ARG NGINX_VER
+RUN curl -L -O "http://nginx.org/download/nginx-$NGINX_VER.tar.gz"
+RUN tar xzf "nginx-$NGINX_VER.tar.gz"
+
+# configure and build nginx
+WORKDIR /src/nginx/nginx-"$NGINX_VER"
+RUN ./configure --prefix=/usr/share/nginx \
+ --sbin-path=/usr/sbin/nginx \
+ --conf-path=/etc/nginx/nginx.conf \
+ --error-log-path=/var/log/nginx/error.log \
+ --http-log-path=/var/log/nginx/access.log \
+ --pid-path=/run/nginx.pid \
+ --lock-path=/run/lock/subsys/nginx \
+ --http-client-body-temp-path=/tmp/nginx/client \
+ --http-proxy-temp-path=/tmp/nginx/proxy \
+ --user=www-data \
+ --group=www-data \
+ --with-threads \
+ --with-file-aio \
+ --with-pcre="/src/pcre/pcre-$PCRE_VER" \
+ --with-pcre-jit \
+ --with-http_addition_module \
+ --without-http_fastcgi_module \
+ --without-http_uwsgi_module \
+ --without-http_scgi_module \
+ --without-http_gzip_module \
+ --without-select_module \
+ --without-poll_module \
+ --without-mail_pop3_module \
+ --without-mail_imap_module \
+ --without-mail_smtp_module \
+ --with-cc-opt="-Wl,--gc-sections -static -static-libgcc -O2 -ffunction-sections -fdata-sections -fPIE -fstack-protector-all -D_FORTIFY_SOURCE=2 -Wformat -Werror=format-security"
+ARG CORE_COUNT="1"
+RUN make -j"$CORE_COUNT"
+RUN make install
+
+FROM alpine:"$ALPINE_VER"
+
+# setup nginx folders and files
+RUN adduser www-data -D -H -G www-data \
+ && mkdir -p /tmp/nginx/ \
+ && mkdir -p /var/log/nginx \
+ && mkdir -p /var/www/html \
+ && ln -sf /dev/stdout /var/log/nginx/access.log \
+ && ln -sf /dev/stderr /var/log/nginx/error.log \
+ && mkdir -p /etc/nginx \
+ && chmod g+rwx /var/run /var/log/nginx /tmp/nginx
+
+# copy in default nginx configs
+COPY conf/ etc/nginx/
+
+# add nginx binary
+COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx
+
+EXPOSE 8080
+# configure CMD
+CMD ["/usr/sbin/nginx","-g","daemon off;"]
diff --git a/alpine/autoindex/conf/mime.types b/alpine/autoindex/conf/mime.types
new file mode 100644
index 0000000..b53f7f7
--- /dev/null
+++ b/alpine/autoindex/conf/mime.types
@@ -0,0 +1,98 @@
+
+types {
+ text/html html htm shtml;
+ text/css css;
+ text/xml xml;
+ image/gif gif;
+ image/jpeg jpeg jpg;
+ application/javascript js;
+ application/atom+xml atom;
+ application/rss+xml rss;
+
+ text/mathml mml;
+ text/plain txt;
+ text/vnd.sun.j2me.app-descriptor jad;
+ text/vnd.wap.wml wml;
+ text/x-component htc;
+
+ image/png png;
+ image/svg+xml svg svgz;
+ image/tiff tif tiff;
+ image/vnd.wap.wbmp wbmp;
+ image/webp webp;
+ image/x-icon ico;
+ image/x-jng jng;
+ image/x-ms-bmp bmp;
+
+ font/woff woff;
+ font/woff2 woff2;
+
+ application/java-archive jar war ear;
+ application/json json;
+ application/mac-binhex40 hqx;
+ application/msword doc;
+ application/pdf pdf;
+ application/postscript ps eps ai;
+ application/rtf rtf;
+ application/vnd.apple.mpegurl m3u8;
+ application/vnd.google-earth.kml+xml kml;
+ application/vnd.google-earth.kmz kmz;
+ application/vnd.ms-excel xls;
+ application/vnd.ms-fontobject eot;
+ application/vnd.ms-powerpoint ppt;
+ application/vnd.oasis.opendocument.graphics odg;
+ application/vnd.oasis.opendocument.presentation odp;
+ application/vnd.oasis.opendocument.spreadsheet ods;
+ application/vnd.oasis.opendocument.text odt;
+ application/vnd.openxmlformats-officedocument.presentationml.presentation
+ pptx;
+ application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
+ xlsx;
+ application/vnd.openxmlformats-officedocument.wordprocessingml.document
+ docx;
+ application/vnd.wap.wmlc wmlc;
+ application/wasm wasm;
+ application/x-7z-compressed 7z;
+ application/x-cocoa cco;
+ application/x-java-archive-diff jardiff;
+ application/x-java-jnlp-file jnlp;
+ application/x-makeself run;
+ application/x-perl pl pm;
+ application/x-pilot prc pdb;
+ application/x-rar-compressed rar;
+ application/x-redhat-package-manager rpm;
+ application/x-sea sea;
+ application/x-shockwave-flash swf;
+ application/x-stuffit sit;
+ application/x-tcl tcl tk;
+ application/x-x509-ca-cert der pem crt;
+ application/x-xpinstall xpi;
+ application/xhtml+xml xhtml;
+ application/xspf+xml xspf;
+ application/zip zip;
+
+ application/octet-stream bin exe dll;
+ application/octet-stream deb;
+ application/octet-stream dmg;
+ application/octet-stream iso img;
+ application/octet-stream msi msp msm;
+
+ audio/midi mid midi kar;
+ audio/mpeg mp3;
+ audio/ogg ogg;
+ audio/x-m4a m4a;
+ audio/x-realaudio ra;
+
+ video/3gpp 3gpp 3gp;
+ video/mp2t ts;
+ video/mp4 mp4;
+ video/mpeg mpeg mpg;
+ video/quicktime mov;
+ video/webm webm;
+ video/x-flv flv;
+ video/x-m4v m4v;
+ video/x-mng mng;
+ video/x-ms-asf asx asf;
+ video/x-ms-wmv wmv;
+ video/x-msvideo avi;
+}
diff --git a/alpine/autoindex/conf/nginx.conf b/alpine/autoindex/conf/nginx.conf
new file mode 100644
index 0000000..3ceb2f5
--- /dev/null
+++ b/alpine/autoindex/conf/nginx.conf
@@ -0,0 +1,32 @@
+#user nobody;
+worker_processes 1;
+
+events {
+ worker_connections 1024;
+}
+
+http {
+ include mime.types;
+ default_type application/octet-stream;
+ sendfile on;
+ keepalive_timeout 65;
+
+ server {
+ listen 8080;
+ server_name _;
+
+ location / {
+ root /usr/share/nginx/html;
+ index index.html index.htm;
+ try_files $uri $uri/ $uri.html =404;
+ autoindex on;
+ error_page 404 = /404.html;
+ }
+ error_page 404 /404.html;
+
+ error_page 500 502 503 504 /50x.html;
+ location = /50x.html {
+ root html;
+ }
+ }
+}
diff --git a/docker-bake.hcl b/docker-bake.hcl
index 4ca410d..3c318ae 100644
--- a/docker-bake.hcl
+++ b/docker-bake.hcl
@@ -8,7 +8,7 @@ group "default" {
targets = ["alpine"]
}
group "alpine" {
- targets = ["alpine-base", "alpine-spa"]
+ targets = ["alpine-base", "alpine-spa", "alpine-autoindex"]
}
group "alpine-base" {
targets = ["alpine-mainline", "alpine-stable"]
@@ -16,6 +16,9 @@ group "alpine-base" {
group "alpine-spa" {
targets = ["alpine-mainline-spa", "alpine-stable-spa"]
}
+group "alpine-autoindex" {
+ targets = ["alpine-mainline-autoindex", "alpine-stable-autoindex"]
+}
target "alpine-mainline" {
context = "alpine/base/"
@@ -90,3 +93,40 @@ target "alpine-stable-spa" {
"${REGISTRY}/nginx:${NGINX_STABLE}-alpine${ALPINE_VER}-spa",
]
}
+
+target "alpine-mainline-autoindex" {
+ context = "alpine/autoindex/"
+ args = {
+ ALPINE_VER="${ALPINE_VER}"
+ NGINX_VER="${NGINX_MAINLINE}"
+ CORE_COUNT="${CORE_COUNT}"
+ }
+ tags = [
+ "${REGISTRY}/nginx:autoindex",
+ "${REGISTRY}/nginx:alpine-autoindex",
+ "${REGISTRY}/nginx:alpine${ALPINE_VER}-autoindex",
+ "${REGISTRY}/nginx:mainline-autoindex",
+ "${REGISTRY}/nginx:mainline-alpine-autoindex",
+ "${REGISTRY}/nginx:mainline-alpine${ALPINE_VER}-autoindex",
+ "${REGISTRY}/nginx:${NGINX_MAINLINE}-autoindex",
+ "${REGISTRY}/nginx:${NGINX_MAINLINE}-alpine-autoindex",
+ "${REGISTRY}/nginx:${NGINX_MAINLINE}-alpine${ALPINE_VER}-autoindex",
+ ]
+}
+
+target "alpine-stable-autoindex" {
+ context = "alpine/autoindex/"
+ args = {
+ ALPINE_VER="${ALPINE_VER}"
+ NGINX_VER="${NGINX_STABLE}"
+ CORE_COUNT="${CORE_COUNT}"
+ }
+ tags = [
+ "${REGISTRY}/nginx:stable-autoindex",
+ "${REGISTRY}/nginx:stable-alpine-autoindex",
+ "${REGISTRY}/nginx:stable-alpine${ALPINE_VER}-autoindex",
+ "${REGISTRY}/nginx:${NGINX_STABLE}-autoindex",
+ "${REGISTRY}/nginx:${NGINX_STABLE}-alpine-autoindex",
+ "${REGISTRY}/nginx:${NGINX_STABLE}-alpine${ALPINE_VER}-autoindex",
+ ]
+}