Compare commits

...

10 Commits

Author SHA1 Message Date
Markus Opolka
54b9c6b533 Upgrading to Version 3.14.2+180807 2018-08-15 20:01:12 +02:00
Markus Opolka
92291c81ae Merge pull request #11 from martialblog/alpine-fpm
Add fpm-alpine Dockerfile
2018-08-15 14:40:22 +02:00
Markus Opolka
af02bb1f8c Add fpm-alpine Dockerfile 2018-08-15 14:36:32 +02:00
Markus Opolka
cd8f4b825e Updating to Version 3.14.2+180807 2018-08-09 19:23:17 +02:00
Markus Opolka
2683fcee3c Add example docker-compose.yaml for Postgres 2018-08-09 19:22:20 +02:00
Markus Opolka
bef4ac9ae3 Improve entrypoint to check if database is already provisioned 2018-08-09 19:22:17 +02:00
Markus Opolka
4279818967 Fix docker-compose files
- context needed to change
2018-08-08 09:04:17 +02:00
Markus Opolka
481e72194a Updating to Version 3.14.1+180731 2018-08-08 09:02:14 +02:00
Markus Opolka
3f2f632edd Updating to Version 3.14.0+180730 2018-07-31 19:25:16 +02:00
Markus Opolka
13064859d8 Fix Travis build 2018-07-30 10:38:55 +02:00
12 changed files with 268 additions and 49 deletions

View File

@@ -6,6 +6,8 @@ services:
matrix: matrix:
include: include:
- env: TAG=martialblog/limesurvey-apache - env: TAG=martialblog/limesurvey-apache
script: docker build -q -t $TAG -f apache/Dockerfile . && tests/run.sh $TAG script: cd apache; docker build -q -t $TAG . && cd ..; ./tests/run.sh $TAG
- env: TAG=martialblog/limesurvey-fpm - env: TAG=martialblog/limesurvey-fpm
script: docker build -q -t $TAG -f fpm/Dockerfile . && tests/run.sh $TAG script: cd fpm; docker build -q -t $TAG . && cd ..; ./tests/run.sh $TAG
- env: TAG=martialblog/limesurvey-alpine
script: cd fpm; docker build -q -t $TAG . && cd ..; ./tests/run.sh $TAG

View File

@@ -45,7 +45,7 @@ To change to LimeSurvey configuration, you can mount a Volume into the Container
| Parameter | Description | | Parameter | Description |
| --------- | ----------- | | --------- | ----------- |
| DB_TYPE | Database Type to use. mysql or postgresql | | DB_TYPE | Database Type to use. mysql or pgsql |
| DB_HOST | Database server hostname | | DB_HOST | Database server hostname |
| DB_PORT | Database server port | | DB_PORT | Database server port |
| DB_NAME | Database name | | DB_NAME | Database name |

View File

@@ -1,6 +1,6 @@
FROM php:7.2-apache FROM php:7.2-apache
LABEL maintainer="markus@martialblog.de" LABEL maintainer="markus@martialblog.de"
ARG version='3.13.1+180629' ARG version='3.14.4+180810'
# Install OS dependencies # Install OS dependencies
RUN apt-get update && \ RUN apt-get update && \

View File

@@ -1,6 +1,6 @@
#!/bin/bash #!/bin/bash
# Entrypoint for Docker Container
set -e
DB_TYPE=${DB_TYPE:-'mysql'} DB_TYPE=${DB_TYPE:-'mysql'}
DB_HOST=${DB_HOST:-'mysql'} DB_HOST=${DB_HOST:-'mysql'}
@@ -19,17 +19,13 @@ PUBLIC_URL=${PUBLIC_URL:-}
URL_FORMAT=${URL_FORMAT:-'path'} URL_FORMAT=${URL_FORMAT:-'path'}
# Check if DB_PASSWORD is set # Check if database is available
if [ -z "$DB_PASSWORD" ]; then until nc -z -v -w30 $DB_HOST $DB_PORT
echo >&2 'Error: Missing DB_PASSWORD' do
exit 1 echo "Info: Waiting for database connection..."
fi sleep 5
done
# Check if DB_PASSWORD is set
if [ -z "$ADMIN_PASSWORD" ]; then
echo >&2 'Error: Missing ADMIN_PASSWORD'
exit 1
fi
# Check if already provisioned # Check if already provisioned
if [ -f application/config/config.php ]; then if [ -f application/config/config.php ]; then
@@ -43,7 +39,7 @@ else
cp application/config/config-sample-mysql.php application/config/config.php cp application/config/config-sample-mysql.php application/config/config.php
fi fi
if [ "$DB_TYPE" = 'postgresql' ]; then if [ "$DB_TYPE" = 'pgsql' ]; then
echo 'Info: Using PostgreSQL configuration' echo 'Info: Using PostgreSQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8'} DB_CHARSET=${DB_CHARSET:-'utf8'}
cp application/config/config-sample-pgsql.php application/config/config.php cp application/config/config-sample-pgsql.php application/config/config.php
@@ -66,14 +62,30 @@ else
fi fi
fi fi
until nc -z -v -w30 $DB_HOST $DB_PORT
do
echo "Info: Waiting for database connection..."
sleep 5
done
echo 'Running console.php install' # Check if LimeSurvey database is provisioned
# Hint: The console.php script seems to always exit with 1, so that is why echo 'Info: Check if database already provisioned. Nevermind the Stack trace.'
php application/commands/console.php install $ADMIN_USER $ADMIN_PASSWORD $ADMIN_NAME $ADMIN_EMAIL || true php application/commands/console.php updatedb
if [ $? -eq 0 ]; then
echo 'Info: Database already provisioned'
else
# Check if DB_PASSWORD is set
if [ -z "$DB_PASSWORD" ]; then
echo >&2 'Error: Missing DB_PASSWORD'
exit 1
fi
# Check if DB_PASSWORD is set
if [ -z "$ADMIN_PASSWORD" ]; then
echo >&2 'Error: Missing ADMIN_PASSWORD'
exit 1
fi
echo ''
echo 'Running console.php install'
php application/commands/console.php install $ADMIN_USER $ADMIN_PASSWORD $ADMIN_NAME $ADMIN_EMAIL
fi
exec "$@" exec "$@"

View File

@@ -0,0 +1,35 @@
version: "3.0"
services:
limesurvey:
build:
context: fpm-alpine/
dockerfile: Dockerfile
volumes:
- /tmp/upload/:/var/www/html/upload/
- lime:/var/www/html
links:
- lime-db
depends_on:
- lime-db
environment:
- "DB_HOST=docker-limesurvey_lime-db_1"
- "DB_PASSWORD=secret"
- "ADMIN_PASSWORD=foobar"
lime-web:
image: nginx:alpine
links:
- limesurvey
ports:
- "8080:80"
volumes:
- ./examples/nginx.conf:/etc/nginx/nginx.conf:ro
- lime:/var/www/html
lime-db:
image: mysql:5.7
environment:
- "MYSQL_USER=limesurvey"
- "MYSQL_DATABASE=limesurvey"
- "MYSQL_PASSWORD=secret"
- "MYSQL_ROOT_PASSWORD=secret"
volumes:
lime:

View File

@@ -2,8 +2,8 @@ version: "3.0"
services: services:
limesurvey: limesurvey:
build: build:
context: . context: fpm/
dockerfile: fpm/Dockerfile dockerfile: Dockerfile
volumes: volumes:
- /tmp/upload/:/var/www/html/upload/ - /tmp/upload/:/var/www/html/upload/
- lime:/var/www/html - lime:/var/www/html

26
docker-compose.pgsql.yml Normal file
View File

@@ -0,0 +1,26 @@
version: "3.0"
services:
limesurvey:
build:
context: apache/
dockerfile: Dockerfile
volumes:
- /tmp/upload/:/var/www/html/upload/
links:
- lime-db
depends_on:
- lime-db
ports:
- "8080:80"
environment:
- "DB_TYPE=pgsql"
- "DB_PORT=5432"
- "DB_HOST=docker-limesurvey_lime-db_1"
- "DB_PASSWORD=secret"
- "ADMIN_PASSWORD=foobar"
lime-db:
image: postgres:10
environment:
- "POSTGRES_USER=limesurvey"
- "POSTGRES_DB=limesurvey"
- "POSTGRES_PASSWORD=secret"

View File

@@ -2,8 +2,8 @@ version: "3.0"
services: services:
limesurvey: limesurvey:
build: build:
context: . context: apache/
dockerfile: apache/Dockerfile dockerfile: Dockerfile
volumes: volumes:
- /tmp/upload/:/var/www/html/upload/ - /tmp/upload/:/var/www/html/upload/
links: links:

41
fpm-alpine/Dockerfile Normal file
View File

@@ -0,0 +1,41 @@
FROM php:7.2-fpm-alpine
LABEL maintainer="markus@martialblog.de"
ARG version='3.14.4+180810'
# Install OS dependencies
RUN apk add --no-cache --virtual .build-deps \
libpng-dev \
openldap-dev \
imap-dev \
postgresql-dev && \
apk add --no-cache netcat-openbsd bash
# Install PHP Plugins
RUN docker-php-ext-configure imap --with-imap-ssl && \
docker-php-ext-install \
gd \
imap \
ldap \
mbstring \
pdo \
pdo_mysql \
pdo_pgsql \
pgsql \
zip
# Download, unzip and chmod of LimeSurvey
ADD "https://github.com/LimeSurvey/LimeSurvey/archive/${version}.tar.gz" /tmp
RUN tar xzvf "/tmp/${version}.tar.gz" --strip-components=1 -C /var/www/html/ && \
rm -rf "/tmp/${version}.tar.gz" \
/var/www/html/docs \
/var/www/html/tests \
/var/www/html/*.md && \
chown -R www-data:root /var/www/ ; \
chmod -R g=u /var/www
EXPOSE 9000
COPY entrypoint.sh entrypoint.sh
ENTRYPOINT ["/var/www/html/entrypoint.sh"]
CMD ["php-fpm"]

91
fpm-alpine/entrypoint.sh Executable file
View File

@@ -0,0 +1,91 @@
#!/bin/sh
# Entrypoint for Docker Container
DB_TYPE=${DB_TYPE:-'mysql'}
DB_HOST=${DB_HOST:-'mysql'}
DB_PORT=${DB_PORT:-'3306'}
DB_NAME=${DB_NAME:-'limesurvey'}
DB_TABLE_PREFIX=${DB_TABLE_PREFIX:-'lime_'}
DB_USERNAME=${DB_USERNAME:-'limesurvey'}
DB_PASSWORD=${DB_PASSWORD:-}
ADMIN_USER=${ADMIN_USER:-'admin'}
ADMIN_NAME=${ADMIN_NAME:-'admin'}
ADMIN_EMAIL=${ADMIN_EMAIL:-'foobar@example.com'}
ADMIN_PASSWORD=${ADMIN_PASSWORD:-'-'}
PUBLIC_URL=${PUBLIC_URL:-}
URL_FORMAT=${URL_FORMAT:-'path'}
# Check if database is available
until nc -z -v -w30 $DB_HOST $DB_PORT
do
echo "Info: Waiting for database connection..."
sleep 5
done
# Check if already provisioned
if [ -f application/config/config.php ]; then
echo 'Info: config.php already provisioned'
else
echo 'Info: Generating config.php'
if [ "$DB_TYPE" = 'mysql' ]; then
echo 'Info: Using MySQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8mb4'}
cp application/config/config-sample-mysql.php application/config/config.php
fi
if [ "$DB_TYPE" = 'pgsql' ]; then
echo 'Info: Using PostgreSQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8'}
cp application/config/config-sample-pgsql.php application/config/config.php
fi
# Set Database config
sed -i "s#\('connectionString' => \).*,\$#\\1'${DB_TYPE}:host=${DB_HOST};port=${DB_PORT};dbname=${DB_NAME};',#g" application/config/config.php
sed -i "s#\('username' => \).*,\$#\\1'${DB_USERNAME}',#g" application/config/config.php
sed -i "s#\('password' => \).*,\$#\\1'${DB_PASSWORD}',#g" application/config/config.php
sed -i "s#\('charset' => \).*,\$#\\1'${DB_CHARSET}',#g" application/config/config.php
sed -i "s#\('tablePrefix' => \).*,\$#\\1'${DB_TABLE_PREFIX}',#g" application/config/config.php
# Set URL config
sed -i "s#\('urlFormat' => \).*,\$#\\1'${URL_FORMAT}',#g" application/config/config.php
# Set Public URL
if [ -z "$PUBLIC_URL" ]; then
echo 'Info: Setting PublicURL'
sed -i "s#\('debug'=>0,\)\$#'publicurl'=>'${PUBLIC_URL}',\n\t\t\\1 #g" application/config/config.php
fi
fi
# Check if LimeSurvey database is provisioned
echo 'Info: Check if database already provisioned. Nevermind the Stack trace.'
php application/commands/console.php updatedb
if [ $? -eq 0 ]; then
echo 'Info: Database already provisioned'
else
# Check if DB_PASSWORD is set
if [ -z "$DB_PASSWORD" ]; then
echo >&2 'Error: Missing DB_PASSWORD'
exit 1
fi
# Check if DB_PASSWORD is set
if [ -z "$ADMIN_PASSWORD" ]; then
echo >&2 'Error: Missing ADMIN_PASSWORD'
exit 1
fi
echo ''
echo 'Running console.php install'
php application/commands/console.php install $ADMIN_USER $ADMIN_PASSWORD $ADMIN_NAME $ADMIN_EMAIL
fi
exec "$@"

View File

@@ -1,6 +1,6 @@
FROM php:7.2-fpm FROM php:7.2-fpm
LABEL maintainer="markus@martialblog.de" LABEL maintainer="markus@martialblog.de"
ARG version='3.13.1+180629' ARG version='3.14.4+180810'
# Install OS dependencies # Install OS dependencies
RUN apt-get update && \ RUN apt-get update && \

View File

@@ -1,6 +1,6 @@
#!/bin/bash #!/bin/bash
# Entrypoint for Docker Container
set -e
DB_TYPE=${DB_TYPE:-'mysql'} DB_TYPE=${DB_TYPE:-'mysql'}
DB_HOST=${DB_HOST:-'mysql'} DB_HOST=${DB_HOST:-'mysql'}
@@ -19,17 +19,13 @@ PUBLIC_URL=${PUBLIC_URL:-}
URL_FORMAT=${URL_FORMAT:-'path'} URL_FORMAT=${URL_FORMAT:-'path'}
# Check if DB_PASSWORD is set # Check if database is available
if [ -z "$DB_PASSWORD" ]; then until nc -z -v -w30 $DB_HOST $DB_PORT
echo >&2 'Error: Missing DB_PASSWORD' do
exit 1 echo "Info: Waiting for database connection..."
fi sleep 5
done
# Check if DB_PASSWORD is set
if [ -z "$ADMIN_PASSWORD" ]; then
echo >&2 'Error: Missing ADMIN_PASSWORD'
exit 1
fi
# Check if already provisioned # Check if already provisioned
if [ -f application/config/config.php ]; then if [ -f application/config/config.php ]; then
@@ -43,7 +39,7 @@ else
cp application/config/config-sample-mysql.php application/config/config.php cp application/config/config-sample-mysql.php application/config/config.php
fi fi
if [ "$DB_TYPE" = 'postgresql' ]; then if [ "$DB_TYPE" = 'pgsql' ]; then
echo 'Info: Using PostgreSQL configuration' echo 'Info: Using PostgreSQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8'} DB_CHARSET=${DB_CHARSET:-'utf8'}
cp application/config/config-sample-pgsql.php application/config/config.php cp application/config/config-sample-pgsql.php application/config/config.php
@@ -66,14 +62,30 @@ else
fi fi
fi fi
until nc -z -v -w30 $DB_HOST $DB_PORT
do
echo "Info: Waiting for database connection..."
sleep 5
done
echo 'Running console.php install' # Check if LimeSurvey database is provisioned
# Hint: The console.php script seems to always exit with 1, so that is why echo 'Info: Check if database already provisioned. Nevermind the Stack trace.'
php application/commands/console.php install $ADMIN_USER $ADMIN_PASSWORD $ADMIN_NAME $ADMIN_EMAIL || true php application/commands/console.php updatedb
if [ $? -eq 0 ]; then
echo 'Info: Database already provisioned'
else
# Check if DB_PASSWORD is set
if [ -z "$DB_PASSWORD" ]; then
echo >&2 'Error: Missing DB_PASSWORD'
exit 1
fi
# Check if DB_PASSWORD is set
if [ -z "$ADMIN_PASSWORD" ]; then
echo >&2 'Error: Missing ADMIN_PASSWORD'
exit 1
fi
echo ''
echo 'Running console.php install'
php application/commands/console.php install $ADMIN_USER $ADMIN_PASSWORD $ADMIN_NAME $ADMIN_EMAIL
fi
exec "$@" exec "$@"