mirror of
https://github.com/wallabag/docker.git
synced 2026-02-28 20:57:36 +01:00
Compare commits
21 Commits
2.6.9
...
87db596578
| Author | SHA1 | Date | |
|---|---|---|---|
| 87db596578 | |||
| b55f138b84 | |||
| eb038898ea | |||
| d21edfec4a | |||
| 488814d187 | |||
| 3808b524fc | |||
| dd237ec16e | |||
| 84756ac1fd | |||
| 60ce6d2e4f | |||
| b228deb919 | |||
| 52afa94c77 | |||
| 55976e23e5 | |||
| 3975a28546 | |||
| 0e58189b97 | |||
| 2d96e30450 | |||
| 424642d3b9 | |||
| 364b1b3d84 | |||
| d1c4800a3e | |||
| 4c3ff8a8ac | |||
| c9104abfeb | |||
| 78d6d36e0c |
7
.github/dependabot.yml
vendored
7
.github/dependabot.yml
vendored
@ -12,3 +12,10 @@ updates:
|
||||
versions:
|
||||
- ">= 3.11.a"
|
||||
- "< 3.12"
|
||||
- package-ecosystem: github-actions
|
||||
directory: "/"
|
||||
schedule:
|
||||
interval: weekly
|
||||
time: "04:00"
|
||||
timezone: Europe/Paris
|
||||
open-pull-requests-limit: 10
|
||||
|
||||
14
.github/workflows/publish.yml
vendored
14
.github/workflows/publish.yml
vendored
@ -13,16 +13,16 @@ jobs:
|
||||
contents: read
|
||||
steps:
|
||||
- name: Check out the repo
|
||||
uses: actions/checkout@v3
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Log in to Docker Hub
|
||||
uses: docker/login-action@v2
|
||||
uses: docker/login-action@v3
|
||||
with:
|
||||
username: ${{ secrets.DOCKER_USERNAME }}
|
||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||
|
||||
- name: Log in to the Container registry
|
||||
uses: docker/login-action@v2
|
||||
uses: docker/login-action@v3
|
||||
with:
|
||||
registry: ghcr.io
|
||||
username: ${{ github.actor }}
|
||||
@ -30,23 +30,23 @@ jobs:
|
||||
|
||||
# Documentation: https://github.com/docker/setup-qemu-action
|
||||
- name: Set up QEMU
|
||||
uses: docker/setup-qemu-action@v2
|
||||
uses: docker/setup-qemu-action@v3
|
||||
|
||||
# Documentation: https://github.com/docker/setup-buildx-action
|
||||
- name: Set up Docker Buildx
|
||||
id: buildx
|
||||
uses: docker/setup-buildx-action@v2
|
||||
uses: docker/setup-buildx-action@v3
|
||||
|
||||
- name: Extract metadata (tags, labels) for Docker
|
||||
id: meta
|
||||
uses: docker/metadata-action@v4
|
||||
uses: docker/metadata-action@v5
|
||||
with:
|
||||
images: |
|
||||
wallabag/wallabag
|
||||
ghcr.io/${{ github.repository }}
|
||||
|
||||
- name: Build and push Docker images
|
||||
uses: docker/build-push-action@v3
|
||||
uses: docker/build-push-action@v6
|
||||
with:
|
||||
context: .
|
||||
push: true
|
||||
|
||||
10
.github/workflows/test.yml
vendored
10
.github/workflows/test.yml
vendored
@ -24,17 +24,17 @@ jobs:
|
||||
|
||||
steps:
|
||||
- name: "Checkout"
|
||||
uses: actions/checkout@v3
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 2
|
||||
|
||||
- name: Set up Python
|
||||
uses: actions/setup-python@v4
|
||||
uses: actions/setup-python@v5
|
||||
with:
|
||||
python-version: 3.11
|
||||
|
||||
- name: "Build image"
|
||||
run: docker-compose -f tests/docker-compose.${{ matrix.database }}.yml build
|
||||
run: docker compose -f tests/docker-compose.${{ matrix.database }}.yml build
|
||||
|
||||
- name: "Install dependencies"
|
||||
run: pip install pytest pytest-docker requests
|
||||
@ -44,8 +44,8 @@ jobs:
|
||||
|
||||
- name: "Get docker logs"
|
||||
if: ${{ always() }}
|
||||
run: docker-compose -p "wallabag_${{ matrix.database }}" -f tests/docker-compose.${{ matrix.database }}.yml logs wallabag
|
||||
run: docker compose -p "wallabag_${{ matrix.database }}" -f tests/docker-compose.${{ matrix.database }}.yml logs wallabag
|
||||
|
||||
- name: "Cleanup environment"
|
||||
if: ${{ always() }}
|
||||
run: docker-compose -p "wallabag_${{ matrix.database }}" -f tests/docker-compose.${{ matrix.database }}.yml down -v
|
||||
run: docker compose -p "wallabag_${{ matrix.database }}" -f tests/docker-compose.${{ matrix.database }}.yml down -v
|
||||
|
||||
@ -13,7 +13,7 @@ FROM alpine:3.18
|
||||
|
||||
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
||||
|
||||
ARG WALLABAG_VERSION=2.6.9
|
||||
ARG WALLABAG_VERSION=2.6.12
|
||||
|
||||
RUN set -ex \
|
||||
&& apk add --no-cache \
|
||||
@ -32,6 +32,7 @@ RUN set -ex \
|
||||
php81-iconv \
|
||||
php81-json \
|
||||
php81-mbstring \
|
||||
php81-opcache \
|
||||
php81-openssl \
|
||||
php81-pecl-amqp \
|
||||
php81-pecl-imagick \
|
||||
@ -83,6 +84,8 @@ ENV PATH="${PATH}:/var/www/wallabag/bin"
|
||||
# Set console entry path
|
||||
WORKDIR /var/www/wallabag
|
||||
|
||||
HEALTHCHECK CMD curl --fail --silent --show-error --user-agent healthcheck http://localhost/api/info || exit 1
|
||||
|
||||
EXPOSE 80
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
CMD ["wallabag"]
|
||||
|
||||
@ -42,6 +42,7 @@ Default login is `wallabag:wallabag`.
|
||||
- `-e POPULATE_DATABASE=...`(defaults to "True". Does the DB has to be populated or is it an existing one)
|
||||
- `-e SYMFONY__ENV__SERVER_NAME=...` (defaults to "Your wallabag instance". Specifies a user-friendly name for the 2FA issuer)
|
||||
- `-e PHP_MEMORY_LIMIT=...` (allows you to change the PHP `memory_limit` value. defaults to 128M, and should be a number and unit, eg. 512K, 128M, 2G, or a number of bytes)
|
||||
- `-e FASTCGI_READ_TIMEOUT=...` (allows you to change the timeout how nginx handle cgi backend connection to PHP. default is 300s for 5 minutes)
|
||||
|
||||
## SQLite
|
||||
|
||||
@ -109,7 +110,6 @@ $ docker exec -t NAME_OR_ID_OF_YOUR_WALLABAG_CONTAINER /var/www/wallabag/bin/con
|
||||
An example [docker-compose](https://docs.docker.com/compose/) file can be seen below:
|
||||
|
||||
```
|
||||
version: '3'
|
||||
services:
|
||||
wallabag:
|
||||
image: wallabag/wallabag
|
||||
@ -132,10 +132,6 @@ services:
|
||||
- "80"
|
||||
volumes:
|
||||
- /opt/wallabag/images:/var/www/wallabag/web/assets/images
|
||||
healthcheck:
|
||||
test: ["CMD", "wget" ,"--no-verbose", "--tries=1", "--spider", "http://localhost/api/info"]
|
||||
interval: 1m
|
||||
timeout: 3s
|
||||
depends_on:
|
||||
- db
|
||||
- redis
|
||||
|
||||
@ -29,6 +29,7 @@ provisioner() {
|
||||
# Replace environment variables
|
||||
envsubst < /etc/wallabag/parameters.template.yml > app/config/parameters.yml
|
||||
envsubst < /etc/wallabag/php-wallabag.template.ini > /etc/php81/conf.d/50_wallabag.ini
|
||||
envsubst '${FASTCGI_READ_TIMEOUT}' < /etc/wallabag/nginx.template.conf | sed 's/\$\${/\${/g' > /etc/nginx/nginx.conf
|
||||
|
||||
# Wait for external database
|
||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] || [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_pgsql" ] ; then
|
||||
|
||||
@ -35,8 +35,7 @@ http {
|
||||
}
|
||||
|
||||
server {
|
||||
listen 80;
|
||||
listen [::0]:80;
|
||||
listen [::]:80 ipv6only=off;
|
||||
server_name _;
|
||||
root /var/www/wallabag/web;
|
||||
|
||||
|
||||
73
root/etc/wallabag/nginx.template.conf
Normal file
73
root/etc/wallabag/nginx.template.conf
Normal file
@ -0,0 +1,73 @@
|
||||
user nginx;
|
||||
worker_processes 1;
|
||||
pid /var/run/nginx.pid;
|
||||
|
||||
events {
|
||||
worker_connections 2048;
|
||||
multi_accept on;
|
||||
use epoll;
|
||||
}
|
||||
|
||||
http {
|
||||
|
||||
server_tokens off;
|
||||
sendfile on;
|
||||
tcp_nopush on;
|
||||
tcp_nodelay on;
|
||||
keepalive_timeout 15;
|
||||
types_hash_max_size 2048;
|
||||
include /etc/nginx/mime.types;
|
||||
default_type application/octet-stream;
|
||||
access_log off;
|
||||
error_log off;
|
||||
gzip on;
|
||||
gzip_disable "msie6";
|
||||
open_file_cache max=100;
|
||||
client_max_body_size 100M;
|
||||
|
||||
map $$http_x_forwarded_proto $$fe_https {
|
||||
default $$https;
|
||||
https on;
|
||||
}
|
||||
|
||||
upstream php-upstream {
|
||||
server 127.0.0.1:9000;
|
||||
}
|
||||
|
||||
server {
|
||||
listen [::]:80 ipv6only=off;
|
||||
server_name _;
|
||||
root /var/www/wallabag/web;
|
||||
|
||||
location / {
|
||||
# try to serve file directly, fallback to app.php
|
||||
try_files $$uri /app.php$$is_args$$args;
|
||||
}
|
||||
|
||||
location ~ ^/app\.php(/|$$) {
|
||||
fastcgi_pass php-upstream;
|
||||
fastcgi_split_path_info ^(.+\.php)(/.*)$$;
|
||||
include fastcgi_params;
|
||||
# When you are using symlinks to link the document root to the
|
||||
# current version of your application, you should pass the real
|
||||
# application path instead of the path to the symlink to PHP
|
||||
# FPM.
|
||||
# Otherwise, PHP's OPcache may not properly detect changes to
|
||||
# your PHP files (see https://github.com/zendtech/ZendOptimizerPlus/issues/126
|
||||
# for more information).
|
||||
fastcgi_param SCRIPT_FILENAME $$realpath_root$$fastcgi_script_name;
|
||||
fastcgi_param DOCUMENT_ROOT $$realpath_root;
|
||||
fastcgi_read_timeout ${FASTCGI_READ_TIMEOUT:-300s};
|
||||
# Prevents URIs that include the front controller. This will 404:
|
||||
# http://domain.tld/app.php/some-path
|
||||
# Remove the internal directive to allow URIs like this
|
||||
internal;
|
||||
}
|
||||
|
||||
access_log /var/log/nginx/access.log;
|
||||
error_log /var/log/nginx/error.log;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
daemon off;
|
||||
@ -28,7 +28,7 @@ def docker_cleanup():
|
||||
|
||||
@pytest.fixture(scope="session")
|
||||
def docker_compose_command() -> str:
|
||||
return "docker-compose"
|
||||
return "docker compose"
|
||||
|
||||
@pytest.fixture(scope="session")
|
||||
def docker_compose_file(pytestconfig, database):
|
||||
|
||||
Reference in New Issue
Block a user