mirror of
https://github.com/wallabag/docker
synced 2025-12-13 17:56:31 +00:00
Compare commits
58 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
55976e23e5 | ||
|
|
3975a28546 | ||
|
|
0e58189b97 | ||
|
|
2d96e30450 | ||
|
|
364b1b3d84 | ||
|
|
d1c4800a3e | ||
|
|
4c3ff8a8ac | ||
|
|
c9104abfeb | ||
|
|
78d6d36e0c | ||
|
|
2a78ed65fe | ||
|
|
cb78d1c98c | ||
|
|
19b6080f31 | ||
|
|
85c82d22c4 | ||
|
|
2ab5b95caf | ||
|
|
2c4fc77b58 | ||
|
|
bffc1412bf | ||
|
|
588c21b192 | ||
|
|
6f2ec8654e | ||
|
|
4143013553 | ||
|
|
eaf63d2098 | ||
|
|
9c6aca3b76 | ||
|
|
e16d9e4113 | ||
|
|
03d1e3a920 | ||
|
|
7c9d8a37e0 | ||
|
|
bdbf7b909a | ||
|
|
bf62096c0e | ||
|
|
f59fb4b67a | ||
|
|
c68fc98e51 | ||
|
|
919f82516c | ||
|
|
2515407009 | ||
|
|
96dd9bc3e3 | ||
|
|
5bde344da3 | ||
|
|
36d4bf58db | ||
|
|
e7b0f9c7f6 | ||
|
|
5a426ce3fa | ||
|
|
75d1b96cc8 | ||
|
|
9241c7d799 | ||
|
|
18d9f742fb | ||
|
|
b5d9ba681c | ||
|
|
b340aaee0a | ||
|
|
746c6e682b | ||
|
|
d7e49fbda9 | ||
|
|
8a68a267ed | ||
|
|
4b00b7f383 | ||
|
|
f1e3a0e2ae | ||
|
|
c2b7c3bbd7 | ||
|
|
7810ca6255 | ||
|
|
4f406f1f1f | ||
|
|
7edde03f39 | ||
|
|
4b4eb85eb1 | ||
|
|
7ac0c31dc1 | ||
|
|
854d1027b8 | ||
|
|
f4517471db | ||
|
|
abb6a98924 | ||
|
|
624616cd9e | ||
|
|
d6ce0cea67 | ||
|
|
673dea7800 | ||
|
|
659a8f4d3f |
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
|
||||
|
||||
19
Dockerfile
19
Dockerfile
@@ -1,3 +1,7 @@
|
||||
ARG COMPOSER_VERSION=2.5.8
|
||||
|
||||
FROM composer:$COMPOSER_VERSION as composer
|
||||
|
||||
FROM golang:alpine as builder
|
||||
|
||||
# envsubst from gettext can not replace env vars with default values
|
||||
@@ -9,7 +13,7 @@ FROM alpine:3.18
|
||||
|
||||
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
||||
|
||||
ARG WALLABAG_VERSION=2.6.2
|
||||
ARG WALLABAG_VERSION=2.6.11
|
||||
|
||||
RUN set -ex \
|
||||
&& apk add --no-cache \
|
||||
@@ -30,6 +34,7 @@ RUN set -ex \
|
||||
php81-mbstring \
|
||||
php81-openssl \
|
||||
php81-pecl-amqp \
|
||||
php81-pecl-imagick \
|
||||
php81-pdo_mysql \
|
||||
php81-pdo_pgsql \
|
||||
php81-pdo_sqlite \
|
||||
@@ -54,15 +59,14 @@ RUN set -ex \
|
||||
&& ln -sf /usr/sbin/php-fpm81 /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 \
|
||||
&& curl -s https://getcomposer.org/installer | php \
|
||||
&& mv composer.phar /usr/local/bin/composer \
|
||||
&& rm -rf /root/.composer/*
|
||||
&& ln -sf /dev/stderr /var/log/nginx/error.log
|
||||
|
||||
COPY --from=composer /usr/bin/composer /usr/local/bin/composer
|
||||
|
||||
COPY root /
|
||||
|
||||
RUN set -ex \
|
||||
&& curl -L -o /tmp/wallabag.tar.gz https://github.com/wallabag/wallabag/archive/$WALLABAG_VERSION.tar.gz \
|
||||
&& curl -L -o /tmp/wallabag.tar.gz https://github.com/wallabag/wallabag/releases/download/$WALLABAG_VERSION/wallabag-$WALLABAG_VERSION.tar.gz \
|
||||
&& tar xvf /tmp/wallabag.tar.gz -C /tmp \
|
||||
&& mkdir /var/www/wallabag \
|
||||
&& mv /tmp/wallabag-*/* /var/www/wallabag/ \
|
||||
@@ -76,6 +80,9 @@ RUN set -ex \
|
||||
|
||||
ENV PATH="${PATH}:/var/www/wallabag/bin"
|
||||
|
||||
# Set console entry path
|
||||
WORKDIR /var/www/wallabag
|
||||
|
||||
EXPOSE 80
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
CMD ["wallabag"]
|
||||
|
||||
@@ -30,7 +30,7 @@ Default login is `wallabag:wallabag`.
|
||||
- `-e SYMFONY__ENV__MAILER_DSN=...` (defaults to "smtp://127.0.0.1")
|
||||
- `-e SYMFONY__ENV__FROM_EMAIL=...`(defaults to "`wallabag@example.com`", the address wallabag uses for outgoing emails)
|
||||
- `-e SYMFONY__ENV__TWOFACTOR_SENDER=...` (defaults to "`no-reply@wallabag.org`", the address wallabag uses for two-factor emails)
|
||||
- `-e SYMFONY__ENV__FOSUSER_REGISTRATION=...`(defaults to "true", enable or disable public user registration)
|
||||
- `-e SYMFONY__ENV__FOSUSER_REGISTRATION=...`(defaults to "false", enable or disable public user registration)
|
||||
- `-e SYMFONY__ENV__FOSUSER_CONFIRMATION=...`(defaults to "true", enable or disable registration confirmation)
|
||||
- `-e SYMFONY__ENV__DOMAIN_NAME=...` defaults to "`https://your-wallabag-instance.wallabag.org`", the URL of your wallabag instance)
|
||||
- `-e SYMFONY__ENV__REDIS_SCHEME=...` (defaults to "tcp", protocol to use to communicate with the target server (tcp, unix, or http))
|
||||
@@ -41,6 +41,7 @@ Default login is `wallabag:wallabag`.
|
||||
- `-e SYMFONY__ENV__SENTRY_DSN=...` (defaults to "~", this is the data source name for sentry)
|
||||
- `-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)
|
||||
|
||||
## SQLite
|
||||
|
||||
@@ -108,10 +109,10 @@ $ 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
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=wallaroot
|
||||
- SYMFONY__ENV__DATABASE_DRIVER=pdo_mysql
|
||||
@@ -131,7 +132,7 @@ services:
|
||||
volumes:
|
||||
- /opt/wallabag/images:/var/www/wallabag/web/assets/images
|
||||
healthcheck:
|
||||
test: ["CMD", "wget" ,"--no-verbose", "--tries=1", "--spider", "http://localhost"]
|
||||
test: ["CMD", "wget" ,"--no-verbose", "--tries=1", "--spider", "http://localhost/api/info"]
|
||||
interval: 1m
|
||||
timeout: 3s
|
||||
depends_on:
|
||||
@@ -139,6 +140,7 @@ services:
|
||||
- redis
|
||||
db:
|
||||
image: mariadb
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=wallaroot
|
||||
volumes:
|
||||
@@ -149,6 +151,7 @@ services:
|
||||
timeout: 3s
|
||||
redis:
|
||||
image: redis:alpine
|
||||
restart: unless-stopped
|
||||
healthcheck:
|
||||
test: ["CMD", "redis-cli", "ping"]
|
||||
interval: 20s
|
||||
|
||||
@@ -23,9 +23,12 @@ install_wallabag() {
|
||||
provisioner() {
|
||||
SYMFONY__ENV__DATABASE_DRIVER=${SYMFONY__ENV__DATABASE_DRIVER:-pdo_sqlite}
|
||||
POPULATE_DATABASE=${POPULATE_DATABASE:-True}
|
||||
SQLITE_DB_DIR="/var/www/wallabag/data/db"
|
||||
SQLITE_DB_FILEPATH="$SQLITE_DB_DIR/wallabag.sqlite"
|
||||
|
||||
# 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
|
||||
|
||||
# Wait for external database
|
||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] || [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_pgsql" ] ; then
|
||||
@@ -33,10 +36,17 @@ provisioner() {
|
||||
fi
|
||||
|
||||
# Configure SQLite database
|
||||
SQLITE_FILE_SIZE=$(wc -c "/var/www/wallabag/data/db/wallabag.sqlite" | awk '{print $1}')
|
||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_sqlite" ] && ([ ! -f "/var/www/wallabag/data/db/wallabag.sqlite" ] || [ "$SQLITE_FILE_SIZE" = 0 ]) ; then
|
||||
echo "Configuring the SQLite database ..."
|
||||
install_wallabag
|
||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_sqlite" ]; then
|
||||
# mkdir and chown are mandatory for local folder binding
|
||||
if [ ! -f "$SQLITE_DB_FILEPATH" ]; then
|
||||
mkdir -p "$SQLITE_DB_DIR"
|
||||
chown nobody: "$SQLITE_DB_DIR"
|
||||
fi
|
||||
|
||||
if [ ! -s "$SQLITE_DB_FILEPATH" ]; then
|
||||
echo "Configuring the SQLite database ..."
|
||||
install_wallabag
|
||||
fi
|
||||
fi
|
||||
|
||||
# Configure MySQL / MariaDB database
|
||||
|
||||
@@ -36,6 +36,7 @@ http {
|
||||
|
||||
server {
|
||||
listen 80;
|
||||
listen [::0]:80;
|
||||
server_name _;
|
||||
root /var/www/wallabag/web;
|
||||
|
||||
@@ -57,6 +58,7 @@ http {
|
||||
# for more information).
|
||||
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
|
||||
fastcgi_param DOCUMENT_ROOT $realpath_root;
|
||||
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
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -5,7 +5,7 @@ parameters:
|
||||
database_name: ${SYMFONY__ENV__DATABASE_NAME:-symfony}
|
||||
database_user: ${SYMFONY__ENV__DATABASE_USER:-root}
|
||||
database_password: ${SYMFONY__ENV__DATABASE_PASSWORD:-~}
|
||||
database_path: "%kernel.root_dir%/../data/db/wallabag.sqlite"
|
||||
database_path: "%kernel.project_dir%/data/db/wallabag.sqlite"
|
||||
database_table_prefix: ${SYMFONY__ENV__DATABASE_TABLE_PREFIX:-wallabag_}
|
||||
database_socket: null
|
||||
database_charset: ${SYMFONY__ENV__DATABASE_CHARSET:-utf8}
|
||||
@@ -23,7 +23,7 @@ parameters:
|
||||
twofactor_sender: ${SYMFONY__ENV__TWOFACTOR_SENDER:-no-reply@wallabag.org}
|
||||
|
||||
# fosuser stuff
|
||||
fosuser_registration: ${SYMFONY__ENV__FOSUSER_REGISTRATION:-true}
|
||||
fosuser_registration: ${SYMFONY__ENV__FOSUSER_REGISTRATION:-false}
|
||||
fosuser_confirmation: ${SYMFONY__ENV__FOSUSER_CONFIRMATION:-true}
|
||||
|
||||
# how long the access token should live in seconds for the API
|
||||
|
||||
1
root/etc/wallabag/php-wallabag.template.ini
Normal file
1
root/etc/wallabag/php-wallabag.template.ini
Normal file
@@ -0,0 +1 @@
|
||||
memory_limit = ${PHP_MEMORY_LIMIT:-128M}
|
||||
@@ -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):
|
||||
@@ -52,7 +52,6 @@ def test_accessing_login_page(wallabag_service):
|
||||
assert r.status_code == 200
|
||||
assert 'Log in' in r.text
|
||||
assert 'Password' in r.text
|
||||
assert 'Register' in r.text
|
||||
assert 'Username' in r.text
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user