mirror of
https://github.com/wallabag/docker.git
synced 2026-02-27 20:27:40 +01:00
Compare commits
20 Commits
2.6.10
...
2e343d18fa
| Author | SHA1 | Date | |
|---|---|---|---|
| 2e343d18fa | |||
| 488814d187 | |||
| a2ed3534e1 | |||
| 3808b524fc | |||
| dd237ec16e | |||
| 84756ac1fd | |||
| 60ce6d2e4f | |||
| b228deb919 | |||
| 52afa94c77 | |||
| 55976e23e5 | |||
| 3975a28546 | |||
| 0e58189b97 | |||
| 2d96e30450 | |||
| 424642d3b9 | |||
| 364b1b3d84 | |||
| d1c4800a3e | |||
| 4c3ff8a8ac | |||
| dfc3a38db1 | |||
| 1b9008040e | |||
| 36b8864ca3 |
7
.github/dependabot.yml
vendored
7
.github/dependabot.yml
vendored
@ -12,3 +12,10 @@ updates:
|
|||||||
versions:
|
versions:
|
||||||
- ">= 3.11.a"
|
- ">= 3.11.a"
|
||||||
- "< 3.12"
|
- "< 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
|
contents: read
|
||||||
steps:
|
steps:
|
||||||
- name: Check out the repo
|
- name: Check out the repo
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Log in to Docker Hub
|
- name: Log in to Docker Hub
|
||||||
uses: docker/login-action@v2
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
username: ${{ secrets.DOCKER_USERNAME }}
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
- name: Log in to the Container registry
|
- name: Log in to the Container registry
|
||||||
uses: docker/login-action@v2
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
registry: ghcr.io
|
registry: ghcr.io
|
||||||
username: ${{ github.actor }}
|
username: ${{ github.actor }}
|
||||||
@ -30,23 +30,23 @@ jobs:
|
|||||||
|
|
||||||
# Documentation: https://github.com/docker/setup-qemu-action
|
# Documentation: https://github.com/docker/setup-qemu-action
|
||||||
- name: Set up QEMU
|
- name: Set up QEMU
|
||||||
uses: docker/setup-qemu-action@v2
|
uses: docker/setup-qemu-action@v3
|
||||||
|
|
||||||
# Documentation: https://github.com/docker/setup-buildx-action
|
# Documentation: https://github.com/docker/setup-buildx-action
|
||||||
- name: Set up Docker Buildx
|
- name: Set up Docker Buildx
|
||||||
id: buildx
|
id: buildx
|
||||||
uses: docker/setup-buildx-action@v2
|
uses: docker/setup-buildx-action@v3
|
||||||
|
|
||||||
- name: Extract metadata (tags, labels) for Docker
|
- name: Extract metadata (tags, labels) for Docker
|
||||||
id: meta
|
id: meta
|
||||||
uses: docker/metadata-action@v4
|
uses: docker/metadata-action@v5
|
||||||
with:
|
with:
|
||||||
images: |
|
images: |
|
||||||
wallabag/wallabag
|
wallabag/wallabag
|
||||||
ghcr.io/${{ github.repository }}
|
ghcr.io/${{ github.repository }}
|
||||||
|
|
||||||
- name: Build and push Docker images
|
- name: Build and push Docker images
|
||||||
uses: docker/build-push-action@v3
|
uses: docker/build-push-action@v6
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
push: true
|
push: true
|
||||||
|
|||||||
11
.github/workflows/test.yml
vendored
11
.github/workflows/test.yml
vendored
@ -21,20 +21,21 @@ jobs:
|
|||||||
- "sqlite"
|
- "sqlite"
|
||||||
- "mariadb"
|
- "mariadb"
|
||||||
- "postgresql"
|
- "postgresql"
|
||||||
|
- "postgresql-secret"
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: "Checkout"
|
- name: "Checkout"
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 2
|
fetch-depth: 2
|
||||||
|
|
||||||
- name: Set up Python
|
- name: Set up Python
|
||||||
uses: actions/setup-python@v4
|
uses: actions/setup-python@v5
|
||||||
with:
|
with:
|
||||||
python-version: 3.11
|
python-version: 3.11
|
||||||
|
|
||||||
- name: "Build image"
|
- 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"
|
- name: "Install dependencies"
|
||||||
run: pip install pytest pytest-docker requests
|
run: pip install pytest pytest-docker requests
|
||||||
@ -44,8 +45,8 @@ jobs:
|
|||||||
|
|
||||||
- name: "Get docker logs"
|
- name: "Get docker logs"
|
||||||
if: ${{ always() }}
|
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"
|
- name: "Cleanup environment"
|
||||||
if: ${{ always() }}
|
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
|
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
||||||
|
|
||||||
ARG WALLABAG_VERSION=2.6.10
|
ARG WALLABAG_VERSION=2.6.12
|
||||||
|
|
||||||
RUN set -ex \
|
RUN set -ex \
|
||||||
&& apk add --no-cache \
|
&& apk add --no-cache \
|
||||||
@ -32,6 +32,7 @@ RUN set -ex \
|
|||||||
php81-iconv \
|
php81-iconv \
|
||||||
php81-json \
|
php81-json \
|
||||||
php81-mbstring \
|
php81-mbstring \
|
||||||
|
php81-opcache \
|
||||||
php81-openssl \
|
php81-openssl \
|
||||||
php81-pecl-amqp \
|
php81-pecl-amqp \
|
||||||
php81-pecl-imagick \
|
php81-pecl-imagick \
|
||||||
@ -83,6 +84,8 @@ ENV PATH="${PATH}:/var/www/wallabag/bin"
|
|||||||
# Set console entry path
|
# Set console entry path
|
||||||
WORKDIR /var/www/wallabag
|
WORKDIR /var/www/wallabag
|
||||||
|
|
||||||
|
HEALTHCHECK CMD curl --fail --silent --show-error --user-agent healthcheck http://localhost/api/info || exit 1
|
||||||
|
|
||||||
EXPOSE 80
|
EXPOSE 80
|
||||||
ENTRYPOINT ["/entrypoint.sh"]
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
CMD ["wallabag"]
|
CMD ["wallabag"]
|
||||||
|
|||||||
@ -43,6 +43,8 @@ Default login is `wallabag:wallabag`.
|
|||||||
- `-e SYMFONY__ENV__SERVER_NAME=...` (defaults to "Your wallabag instance". Specifies a user-friendly name for the 2FA issuer)
|
- `-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 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)
|
||||||
|
|
||||||
|
To set any of these environment variables from a file (for instance a Docker Secret), append `__FILE` to the name of the environment variable.
|
||||||
|
|
||||||
## SQLite
|
## SQLite
|
||||||
|
|
||||||
The easiest way to start wallabag is to use the SQLite backend. You can spin that up with
|
The easiest way to start wallabag is to use the SQLite backend. You can spin that up with
|
||||||
@ -109,7 +111,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:
|
An example [docker-compose](https://docs.docker.com/compose/) file can be seen below:
|
||||||
|
|
||||||
```
|
```
|
||||||
version: '3'
|
|
||||||
services:
|
services:
|
||||||
wallabag:
|
wallabag:
|
||||||
image: wallabag/wallabag
|
image: wallabag/wallabag
|
||||||
@ -132,10 +133,6 @@ services:
|
|||||||
- "80"
|
- "80"
|
||||||
volumes:
|
volumes:
|
||||||
- /opt/wallabag/images:/var/www/wallabag/web/assets/images
|
- /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:
|
depends_on:
|
||||||
- db
|
- db
|
||||||
- redis
|
- redis
|
||||||
|
|||||||
@ -2,6 +2,16 @@
|
|||||||
# Exit when any command fails
|
# Exit when any command fails
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
|
FILE_ENV_VARS="$(env | grep '__FILE=')"
|
||||||
|
for env_var in $FILE_ENV_VARS; do
|
||||||
|
var_name="$(echo $env_var | grep -o '.*__FILE=' | sed 's/__FILE=//g')"
|
||||||
|
file_path="$(echo $env_var | grep -o '__FILE=.*' | sed 's/__FILE=//g')"
|
||||||
|
file_content="$(cat $file_path)"
|
||||||
|
[[ ! $? -eq 0 ]] && exit 1 # Exit if last command failed
|
||||||
|
new_var="$(echo $var_name=$file_content)"
|
||||||
|
export $(echo $new_var | xargs)
|
||||||
|
done
|
||||||
|
|
||||||
COMMAND_ARG1="$1"
|
COMMAND_ARG1="$1"
|
||||||
COMMAND_ARG2="$2"
|
COMMAND_ARG2="$2"
|
||||||
|
|
||||||
|
|||||||
@ -35,8 +35,7 @@ http {
|
|||||||
}
|
}
|
||||||
|
|
||||||
server {
|
server {
|
||||||
listen 80;
|
listen [::]:80 ipv6only=off;
|
||||||
listen [::0]:80;
|
|
||||||
server_name _;
|
server_name _;
|
||||||
root /var/www/wallabag/web;
|
root /var/www/wallabag/web;
|
||||||
|
|
||||||
|
|||||||
1
tests/credentials/db_password
Normal file
1
tests/credentials/db_password
Normal file
@ -0,0 +1 @@
|
|||||||
|
wallapass
|
||||||
1
tests/credentials/env_secret
Normal file
1
tests/credentials/env_secret
Normal file
@ -0,0 +1 @@
|
|||||||
|
F00B4R
|
||||||
1
tests/credentials/postgres_password
Normal file
1
tests/credentials/postgres_password
Normal file
@ -0,0 +1 @@
|
|||||||
|
my-secret-pw
|
||||||
31
tests/docker-compose.postgresql-secret.yml
Normal file
31
tests/docker-compose.postgresql-secret.yml
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
version: '2'
|
||||||
|
services:
|
||||||
|
wallabag:
|
||||||
|
build:
|
||||||
|
context: ../
|
||||||
|
image: wallabag:postgresql
|
||||||
|
container_name: wallabag
|
||||||
|
environment:
|
||||||
|
- POSTGRES_PASSWORD__FILE=/run/secrets/postgres_password
|
||||||
|
- POSTGRES_USER=my-super-user
|
||||||
|
- SYMFONY__ENV__SECRET__FILE=/run/secrets/env_secret
|
||||||
|
- SYMFONY__ENV__DATABASE_DRIVER=pdo_pgsql
|
||||||
|
- SYMFONY__ENV__DATABASE_HOST=db
|
||||||
|
- SYMFONY__ENV__DATABASE_PORT=5432
|
||||||
|
- SYMFONY__ENV__DATABASE_NAME=wallabag
|
||||||
|
- SYMFONY__ENV__DATABASE_USER=wallabag
|
||||||
|
- SYMFONY__ENV__DATABASE_PASSWORD__FILE=/run/secrets/db_password
|
||||||
|
ports:
|
||||||
|
- "127.0.0.1:80:80"
|
||||||
|
# Docker Secrets require Swarm Mode, so we use volumes instead to spoof the behaviour
|
||||||
|
volumes:
|
||||||
|
- ./credentials/db_password:/run/secrets/db_password
|
||||||
|
- ./credentials/postgres_password:/run/secrets/postgres_password
|
||||||
|
- ./credentials/env_secret:/run/secrets/env_secret
|
||||||
|
db:
|
||||||
|
image: postgres:10.3
|
||||||
|
environment:
|
||||||
|
- POSTGRES_PASSWORD_FILE=/run/secrets/postgres_password
|
||||||
|
- POSTGRES_USER=my-super-user
|
||||||
|
volumes:
|
||||||
|
- ./credentials/postgres_password:/run/secrets/postgres_password
|
||||||
@ -28,7 +28,7 @@ def docker_cleanup():
|
|||||||
|
|
||||||
@pytest.fixture(scope="session")
|
@pytest.fixture(scope="session")
|
||||||
def docker_compose_command() -> str:
|
def docker_compose_command() -> str:
|
||||||
return "docker-compose"
|
return "docker compose"
|
||||||
|
|
||||||
@pytest.fixture(scope="session")
|
@pytest.fixture(scope="session")
|
||||||
def docker_compose_file(pytestconfig, database):
|
def docker_compose_file(pytestconfig, database):
|
||||||
|
|||||||
Reference in New Issue
Block a user