mirror of
https://github.com/wallabag/docker
synced 2025-12-13 01:36:28 +00:00
Compare commits
37 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1e28e25500 | ||
|
|
bfb9e7dc40 | ||
|
|
b133e9559d | ||
|
|
b0b760a765 | ||
|
|
480d3833bc | ||
|
|
42981284a6 | ||
|
|
91a399d3bb | ||
|
|
ccb4b25562 | ||
|
|
c8b95ac15b | ||
|
|
25a2e3de71 | ||
|
|
b522c24645 | ||
|
|
2ed6cbca1c | ||
|
|
9dd6c5b52b | ||
|
|
0e11114336 | ||
|
|
6379d9b90f | ||
|
|
e1fafcc31f | ||
|
|
7d2f4919c6 | ||
|
|
096ea7f79c | ||
|
|
2c1ec84dc7 | ||
|
|
488814d187 | ||
|
|
3808b524fc | ||
|
|
dd237ec16e | ||
|
|
84756ac1fd | ||
|
|
60ce6d2e4f | ||
|
|
b228deb919 | ||
|
|
52afa94c77 | ||
|
|
55976e23e5 | ||
|
|
3975a28546 | ||
|
|
0e58189b97 | ||
|
|
2d96e30450 | ||
|
|
424642d3b9 | ||
|
|
364b1b3d84 | ||
|
|
923dffae55 | ||
|
|
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@v6
|
||||
|
||||
- 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@v6
|
||||
with:
|
||||
fetch-depth: 2
|
||||
|
||||
- name: Set up Python
|
||||
uses: actions/setup-python@v4
|
||||
uses: actions/setup-python@v6
|
||||
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
|
||||
|
||||
77
Dockerfile
77
Dockerfile
@@ -1,19 +1,19 @@
|
||||
ARG COMPOSER_VERSION=2.5.8
|
||||
ARG COMPOSER_VERSION=2.2
|
||||
|
||||
FROM composer:$COMPOSER_VERSION as composer
|
||||
FROM composer:$COMPOSER_VERSION AS composer
|
||||
|
||||
FROM golang:alpine as builder
|
||||
FROM golang:alpine AS builder
|
||||
|
||||
# envsubst from gettext can not replace env vars with default values
|
||||
# this package is not available for ARM32 and we have to build it from source code
|
||||
# flag -ldflags "-s -w" produces a smaller executable
|
||||
RUN go install -ldflags "-s -w" -v github.com/a8m/envsubst/cmd/envsubst@v1.3.0
|
||||
RUN go install -ldflags "-s -w" -v github.com/a8m/envsubst/cmd/envsubst@v1.4.3
|
||||
|
||||
FROM alpine:3.18
|
||||
FROM alpine:3.22
|
||||
|
||||
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
||||
|
||||
ARG WALLABAG_VERSION=2.6.9
|
||||
ARG WALLABAG_VERSION=2.6.14
|
||||
|
||||
RUN set -ex \
|
||||
&& apk add --no-cache \
|
||||
@@ -21,42 +21,43 @@ RUN set -ex \
|
||||
libwebp \
|
||||
nginx \
|
||||
pcre \
|
||||
php81 \
|
||||
php81-bcmath \
|
||||
php81-ctype \
|
||||
php81-curl \
|
||||
php81-dom \
|
||||
php81-fpm \
|
||||
php81-gd \
|
||||
php81-gettext \
|
||||
php81-iconv \
|
||||
php81-json \
|
||||
php81-mbstring \
|
||||
php81-openssl \
|
||||
php81-pecl-amqp \
|
||||
php81-pecl-imagick \
|
||||
php81-pdo_mysql \
|
||||
php81-pdo_pgsql \
|
||||
php81-pdo_sqlite \
|
||||
php81-phar \
|
||||
php81-session \
|
||||
php81-simplexml \
|
||||
php81-tokenizer \
|
||||
php81-xml \
|
||||
php81-zlib \
|
||||
php81-sockets \
|
||||
php81-xmlreader \
|
||||
php81-tidy \
|
||||
php81-intl \
|
||||
php81-sodium \
|
||||
php84 \
|
||||
php84-bcmath \
|
||||
php84-ctype \
|
||||
php84-curl \
|
||||
php84-dom \
|
||||
php84-fpm \
|
||||
php84-gd \
|
||||
php84-gettext \
|
||||
php84-iconv \
|
||||
php84-json \
|
||||
php84-mbstring \
|
||||
php84-opcache \
|
||||
php84-openssl \
|
||||
php84-pecl-amqp \
|
||||
php84-pecl-imagick \
|
||||
php84-pdo_mysql \
|
||||
php84-pdo_pgsql \
|
||||
php84-pdo_sqlite \
|
||||
php84-phar \
|
||||
php84-session \
|
||||
php84-simplexml \
|
||||
php84-tokenizer \
|
||||
php84-xml \
|
||||
php84-zlib \
|
||||
php84-sockets \
|
||||
php84-xmlreader \
|
||||
php84-tidy \
|
||||
php84-intl \
|
||||
php84-sodium \
|
||||
mariadb-client \
|
||||
postgresql14-client \
|
||||
postgresql17-client \
|
||||
rabbitmq-c \
|
||||
s6 \
|
||||
tar \
|
||||
tzdata \
|
||||
&& ln -sf /usr/bin/php81 /usr/bin/php \
|
||||
&& ln -sf /usr/sbin/php-fpm81 /usr/sbin/php-fpm \
|
||||
&& ln -sf /usr/bin/php84 /usr/bin/php \
|
||||
&& ln -sf /usr/sbin/php-fpm84 /usr/sbin/php-fpm \
|
||||
&& rm -rf /var/cache/apk/* \
|
||||
&& ln -sf /dev/stdout /var/log/nginx/access.log \
|
||||
&& ln -sf /dev/stderr /var/log/nginx/error.log
|
||||
@@ -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"]
|
||||
|
||||
@@ -109,7 +109,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 +131,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
|
||||
@@ -147,7 +142,7 @@ services:
|
||||
volumes:
|
||||
- /opt/wallabag/data:/var/lib/mysql
|
||||
healthcheck:
|
||||
test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost"]
|
||||
test: ["CMD", "/usr/local/bin/healthcheck.sh", "--innodb_initialized"]
|
||||
interval: 20s
|
||||
timeout: 3s
|
||||
redis:
|
||||
|
||||
@@ -28,7 +28,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 < /etc/wallabag/php-wallabag.template.ini > /etc/php84/conf.d/50_wallabag.ini
|
||||
|
||||
# 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;
|
||||
|
||||
|
||||
@@ -36,11 +36,11 @@ parameters:
|
||||
rss_limit: 50
|
||||
|
||||
# RabbitMQ processing
|
||||
rabbitmq_host: localhost
|
||||
rabbitmq_port: 5672
|
||||
rabbitmq_user: guest
|
||||
rabbitmq_password: guest
|
||||
rabbitmq_prefetch_count: 10
|
||||
rabbitmq_host: ${SYMFONY__ENV__RABBITMQ_HOST:-localhost}
|
||||
rabbitmq_port: ${SYMFONY__ENV__RABBITMQ_PORT:-5672}
|
||||
rabbitmq_user: ${SYMFONY__ENV__RABBITMQ_USER:-guest}
|
||||
rabbitmq_password: ${SYMFONY__ENV__RABBITMQ_PASSWORD:-guest}
|
||||
rabbitmq_prefetch_count: ${SYMFONY__ENV__RABBITMQ_PREFETCH_COUNT:-10}
|
||||
|
||||
# Redis processing
|
||||
redis_scheme: ${SYMFONY__ENV__REDIS_SCHEME:-tcp}
|
||||
|
||||
@@ -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