Compare commits
45 Commits
Author | SHA1 | Date | |
---|---|---|---|
f86a6d83f0 | |||
58df557883 | |||
fb7d5f5b1e | |||
a47abc2d9f | |||
04063c496a | |||
7f25c4943a | |||
b7bb809d68 | |||
79d5310d5d | |||
72a8d74e35 | |||
7006125b0b | |||
aa9f917d4a | |||
c17c2c3b73 | |||
540117be56 | |||
f3e0b7561d | |||
dce7230498 | |||
2d1ee0afa0 | |||
6c910626f8 | |||
5b7aaf23d6 | |||
8cc044ab01 | |||
cbb67c7319 | |||
407b794043 | |||
35c13a48d3 | |||
e3612164e3 | |||
e997ba39b8 | |||
be67b46f83 | |||
031296c727 | |||
ea6aa6f7fd | |||
c012d1f8d8 | |||
a75fd490ce | |||
dadfcfa306 | |||
ff4d33d36d | |||
688fcb4951 | |||
f8c6bb98ac | |||
14421c6a7e | |||
b48180621c | |||
0abfb59001 | |||
aa91ecf18b | |||
2f6693f42f | |||
7a2fd629c4 | |||
0975574f66 | |||
264cf6a576 | |||
39f83351ae | |||
4069c0b8ab | |||
149df92f62 | |||
18a481aefb |
18
.github/renovate.json
vendored
Normal file
18
.github/renovate.json
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
||||||
|
"extends": [
|
||||||
|
"config:base"
|
||||||
|
],
|
||||||
|
"dependencyDashboard": true,
|
||||||
|
"dependencyDashboardTitle": "Renovate Dashboard",
|
||||||
|
"labels": ["renovatebot"],
|
||||||
|
"packageRules": [
|
||||||
|
{
|
||||||
|
"managers": ["github-actions"],
|
||||||
|
"matchUpdateTypes": ["patch"],
|
||||||
|
"automerge": true,
|
||||||
|
"automergeType": "pr",
|
||||||
|
"platformAutomerge": true
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
5
.github/trivy.yaml
vendored
Normal file
5
.github/trivy.yaml
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
format: table
|
||||||
|
severity:
|
||||||
|
- CRITICAL
|
||||||
|
vulnerability:
|
||||||
|
ignore-unfixed: true
|
43
.github/workflows/container_scan.yml
vendored
43
.github/workflows/container_scan.yml
vendored
@ -1,43 +0,0 @@
|
|||||||
name: Container scan on commit to master
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
|
|
||||||
env:
|
|
||||||
USER: loganmarchione
|
|
||||||
REPO: docker-webdav-nginx
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
ubuntu_ci:
|
|
||||||
name: Build and scan
|
|
||||||
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Check out the codebase
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- name: Set variables
|
|
||||||
run: |
|
|
||||||
VER=$(cat VERSION)
|
|
||||||
echo "VERSION=$VER" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Build Docker Image
|
|
||||||
uses: docker/build-push-action@v2
|
|
||||||
with:
|
|
||||||
push: false
|
|
||||||
context: .
|
|
||||||
file: Dockerfile
|
|
||||||
load: true
|
|
||||||
tags: |
|
|
||||||
${{ env.USER }}/${{ env.REPO }}:${{ env.VERSION }}
|
|
||||||
${{ env.USER }}/${{ env.REPO }}:latest
|
|
||||||
|
|
||||||
- name: Container scan
|
|
||||||
uses: azure/container-scan@v0
|
|
||||||
with:
|
|
||||||
image-name: ${{ env.USER }}/${{ env.REPO }}:${{ env.VERSION }}
|
|
||||||
severity-threshold: CRITICAL
|
|
||||||
run-quality-checks: true
|
|
55
.github/workflows/main.yml
vendored
55
.github/workflows/main.yml
vendored
@ -6,28 +6,32 @@ on:
|
|||||||
- "[0-9]+.[0-9]+.[0-9]+"
|
- "[0-9]+.[0-9]+.[0-9]+"
|
||||||
schedule:
|
schedule:
|
||||||
- cron: "0 5 * * 0"
|
- cron: "0 5 * * 0"
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
env:
|
env:
|
||||||
USER: loganmarchione
|
USER: loganmarchione
|
||||||
REPO: docker-webdav-nginx
|
REPO: docker-webdav-nginx
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
ubuntu_ci:
|
ci:
|
||||||
name: Build and test
|
name: Build and test
|
||||||
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Check out the codebase
|
- name: Check out the codebase
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Set variables
|
- name: Set variables
|
||||||
run: |
|
run: |
|
||||||
VER=$(cat VERSION)
|
VER=$(cat VERSION)
|
||||||
echo "VERSION=$VER" >> $GITHUB_ENV
|
echo "VERSION=$VER" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v2
|
||||||
|
|
||||||
- name: Build Docker Image
|
- name: Build Docker Image
|
||||||
uses: docker/build-push-action@v2
|
uses: docker/build-push-action@v4
|
||||||
with:
|
with:
|
||||||
push: false
|
push: false
|
||||||
context: .
|
context: .
|
||||||
@ -40,47 +44,66 @@ jobs:
|
|||||||
- name: Test image
|
- name: Test image
|
||||||
run: |
|
run: |
|
||||||
docker images
|
docker images
|
||||||
docker run --name test-container --detach --env WEBDAV_USER=user1 --env WEBDAV_PASS=password1 --volume 'webdav:/var/www/webdav' ${USER}/${REPO}:${VERSION}
|
docker run --name test-container --detach --env WEBDAV_USER=user --env WEBDAV_PASS=password1 --volume 'webdav:/var/www/webdav' ${USER}/${REPO}:${VERSION}
|
||||||
docker ps -a
|
docker ps -a
|
||||||
|
|
||||||
- name: Container scan
|
- name: Container scan with Dockle
|
||||||
uses: azure/container-scan@v0
|
uses: goodwithtech/dockle-action@0.1.0
|
||||||
with:
|
with:
|
||||||
image-name: ${{ env.USER }}/${{ env.REPO }}:${{ env.VERSION }}
|
image: '${{ env.USER }}/${{ env.REPO }}:${{ env.VERSION }}'
|
||||||
severity-threshold: CRITICAL
|
format: 'list'
|
||||||
run-quality-checks: true
|
exit-code: '1'
|
||||||
|
exit-level: 'warn'
|
||||||
|
ignore: 'CIS-DI-0001'
|
||||||
|
|
||||||
ubuntu_cd:
|
- name: Container scan with hadolint
|
||||||
|
uses: hadolint/hadolint-action@v3.1.0
|
||||||
|
with:
|
||||||
|
failure-threshold: error
|
||||||
|
ignore: DL3008,DL3018
|
||||||
|
|
||||||
|
- name: Container scan with Trivy
|
||||||
|
uses: aquasecurity/trivy-action@0.9.2
|
||||||
|
with:
|
||||||
|
scan-type: 'image'
|
||||||
|
image-ref: '${{ env.USER }}/${{ env.REPO }}:${{ env.VERSION }}'
|
||||||
|
trivy-config: ./github/trivy.yaml
|
||||||
|
|
||||||
|
cd:
|
||||||
name: Deploy
|
name: Deploy
|
||||||
|
|
||||||
needs: ubuntu_ci
|
needs: ci
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Check out the codebase
|
- name: Check out the codebase
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Set variables
|
- name: Set variables
|
||||||
run: |
|
run: |
|
||||||
VER=$(cat VERSION)
|
VER=$(cat VERSION)
|
||||||
echo "VERSION=$VER" >> $GITHUB_ENV
|
echo "VERSION=$VER" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Set up QEMU
|
||||||
|
uses: docker/setup-qemu-action@v2
|
||||||
|
|
||||||
- name: Set up Docker Buildx
|
- name: Set up Docker Buildx
|
||||||
uses: docker/setup-buildx-action@v1
|
uses: docker/setup-buildx-action@v2
|
||||||
|
|
||||||
- name: Login to DockerHub
|
- name: Login to DockerHub
|
||||||
uses: docker/login-action@v1
|
uses: docker/login-action@v2
|
||||||
with:
|
with:
|
||||||
username: ${{ secrets.DOCKER_HUB_USER }}
|
username: ${{ secrets.DOCKER_HUB_USER }}
|
||||||
password: ${{ secrets.DOCKER_HUB_PASS }}
|
password: ${{ secrets.DOCKER_HUB_PASS }}
|
||||||
logout: true
|
logout: true
|
||||||
|
|
||||||
- name: Build Docker Image
|
- name: Build Docker Image
|
||||||
uses: docker/build-push-action@v2
|
uses: docker/build-push-action@v4
|
||||||
with:
|
with:
|
||||||
push: true
|
push: true
|
||||||
context: .
|
context: .
|
||||||
file: Dockerfile
|
file: Dockerfile
|
||||||
|
platforms: linux/amd64,linux/arm64,linux/arm/v7
|
||||||
tags: |
|
tags: |
|
||||||
${{ env.USER }}/${{ env.REPO }}:${{ env.VERSION }}
|
${{ env.USER }}/${{ env.REPO }}:${{ env.VERSION }}
|
||||||
${{ env.USER }}/${{ env.REPO }}:latest
|
${{ env.USER }}/${{ env.REPO }}:latest
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
FROM ubuntu:focal
|
FROM debian:11-slim
|
||||||
|
|
||||||
ARG BUILD_DATE
|
ARG BUILD_DATE
|
||||||
|
|
||||||
@ -11,7 +11,7 @@ LABEL \
|
|||||||
|
|
||||||
ARG DEBIAN_FRONTEND=noninteractive
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
RUN apt-get update && apt-get -y install --no-install-recommends \
|
||||||
apache2-utils \
|
apache2-utils \
|
||||||
netcat \
|
netcat \
|
||||||
nginx-extras && \
|
nginx-extras && \
|
||||||
@ -25,7 +25,9 @@ EXPOSE 80
|
|||||||
|
|
||||||
VOLUME [ "/var/www/webdav" ]
|
VOLUME [ "/var/www/webdav" ]
|
||||||
|
|
||||||
COPY password.sh password.sh
|
COPY password.sh /
|
||||||
|
|
||||||
|
COPY VERSION /
|
||||||
|
|
||||||
COPY webdav.conf /etc/nginx/sites-enabled/webdav
|
COPY webdav.conf /etc/nginx/sites-enabled/webdav
|
||||||
|
|
||||||
|
@ -6,9 +6,10 @@
|
|||||||
Runs a Nginx WebDav server in Docker
|
Runs a Nginx WebDav server in Docker
|
||||||
- Source code: [GitHub](https://github.com/loganmarchione/docker-webdav-nginx)
|
- Source code: [GitHub](https://github.com/loganmarchione/docker-webdav-nginx)
|
||||||
- Docker container: [Docker Hub](https://hub.docker.com/r/loganmarchione/docker-webdav-nginx)
|
- Docker container: [Docker Hub](https://hub.docker.com/r/loganmarchione/docker-webdav-nginx)
|
||||||
- Image base: [Ubuntu](https://hub.docker.com/_/ubuntu)
|
- Image base: [Debian](https://hub.docker.com/_/debian)
|
||||||
- Init system: N/A
|
- Init system: N/A
|
||||||
- Application: [Nginx](https://nginx.org/)
|
- Application: [Nginx](https://nginx.org/)
|
||||||
|
- Architecture: `linux/amd64,linux/arm64,linux/arm/v7`
|
||||||
|
|
||||||
## Explanation
|
## Explanation
|
||||||
|
|
||||||
@ -31,7 +32,7 @@ Runs a Nginx WebDav server in Docker
|
|||||||
### Environment variables
|
### Environment variables
|
||||||
| Variable | Required? | Definition | Example | Comments |
|
| Variable | Required? | Definition | Example | Comments |
|
||||||
|-------------|-----------|----------------------------------|----------------------------|--------------------------------------------------------------|
|
|-------------|-----------|----------------------------------|----------------------------|--------------------------------------------------------------|
|
||||||
| WEBDAV_USER | No | WebDav username | user1 | user AND pass need to be set for authentication to work |
|
| WEBDAV_USER | No | WebDav username | user | user AND pass need to be set for authentication to work |
|
||||||
| WEBDAV_PASS | No | WebDav password | password1 | user AND pass need to be set for authentication to work |
|
| WEBDAV_PASS | No | WebDav password | password1 | user AND pass need to be set for authentication to work |
|
||||||
|
|
||||||
### Ports
|
### Ports
|
||||||
|
Reference in New Issue
Block a user