mirror of
https://github.com/wallabag/docker.git
synced 2026-02-27 12:17:37 +01:00
Compare commits
11 Commits
2.6.12
...
2e343d18fa
| Author | SHA1 | Date | |
|---|---|---|---|
| 2e343d18fa | |||
| 488814d187 | |||
| a2ed3534e1 | |||
| 3808b524fc | |||
| dd237ec16e | |||
| 84756ac1fd | |||
| 60ce6d2e4f | |||
| 424642d3b9 | |||
| dfc3a38db1 | |||
| 1b9008040e | |||
| 36b8864ca3 |
1
.github/workflows/test.yml
vendored
1
.github/workflows/test.yml
vendored
@ -21,6 +21,7 @@ jobs:
|
||||
- "sqlite"
|
||||
- "mariadb"
|
||||
- "postgresql"
|
||||
- "postgresql-secret"
|
||||
|
||||
steps:
|
||||
- name: "Checkout"
|
||||
|
||||
@ -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"]
|
||||
|
||||
@ -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 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
|
||||
|
||||
The easiest way to start wallabag is to use the SQLite backend. You can spin that up with
|
||||
@ -131,10 +133,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
|
||||
|
||||
@ -2,6 +2,16 @@
|
||||
# Exit when any command fails
|
||||
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_ARG2="$2"
|
||||
|
||||
|
||||
@ -35,8 +35,7 @@ http {
|
||||
}
|
||||
|
||||
server {
|
||||
listen 80;
|
||||
listen [::0]:80;
|
||||
listen [::]:80 ipv6only=off;
|
||||
server_name _;
|
||||
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
|
||||
Reference in New Issue
Block a user