Compare commits

..

3 Commits

Author SHA1 Message Date
Jean-Christophe Vanhalle
95391a995c adds support for laravel and livewire 2024-10-13 00:11:48 +02:00
Jean-Christophe Vanhalle
6e0719ec50 cleans up code 2024-10-13 00:11:04 +02:00
Jean-Christophe Vanhalle
c1ae487788 cleans up code 2024-10-13 00:09:49 +02:00
8 changed files with 68 additions and 44 deletions

View File

@@ -4,6 +4,8 @@ DB_NAME=wordpress
DB_ROOT_PASSWORD=root DB_ROOT_PASSWORD=root
DB_USER=user DB_USER=user
DB_USER_PASSWORD=password DB_USER_PASSWORD=password
LARAVEL_VERSION=11.0
LIVEWIRE_VERSION=3.5.10
PHP_POST_MAX_SIZE=10m PHP_POST_MAX_SIZE=10m
PHP_UPLOAD_MAX_FILESIZE=10M PHP_UPLOAD_MAX_FILESIZE=10M
PREFIX=wpdocker PREFIX=wpdocker

View File

@@ -9,6 +9,7 @@ fi
set -a set -a
. "${PWD}/.env" . "${PWD}/.env"
. "${PWD}/env_files/certs.env" . "${PWD}/env_files/certs.env"
. "${PWD}/env_files/project.env"
set +a set +a
mkdir -p "/tmp/${PREFIX}" mkdir -p "/tmp/${PREFIX}"
@@ -22,6 +23,7 @@ docker volume create "${PREFIX}-traefik-logs"
docker volume create "${PREFIX}-traefik-static" docker volume create "${PREFIX}-traefik-static"
docker volume create "${PREFIX}-webroot" docker volume create "${PREFIX}-webroot"
docker volume create wp-cli-cache docker volume create wp-cli-cache
docker volume create composer-cache
echo "Copying SSL certificates to traefik volume" echo "Copying SSL certificates to traefik volume"
if [ ! -f "${SSL_CRT_LOCATION}/${SSL_CRT_NAME}" ] || [ ! -f "${SSL_KEY_LOCATION}/${SSL_KEY_NAME}" ]; then if [ ! -f "${SSL_CRT_LOCATION}/${SSL_CRT_NAME}" ] || [ ! -f "${SSL_KEY_LOCATION}/${SSL_KEY_NAME}" ]; then
@@ -111,15 +113,27 @@ while ! docker exec "${PREFIX}-app" /bin/sh -c "mysqladmin ping -h ${PREFIX}-db
sleep 1 sleep 1
done done
echo "Downloading WordPress core" if [ "${PROJECT_TYPE}" = "laravel" ]; then
docker exec --user www-data "${PREFIX}-app" /bin/sh -c " echo "Installing laravel"
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "composer create-project --prefer-dist laravel/laravel /var/www/html '${LAREVEL_VERSION}'"
fi
if [ "${PROJECT_TYPE}" = "livewire" ]; then
echo "Installing livewire"
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "composer create-project --prefer-dist laravel/laravel /var/www/html '${LARAVEL_VERSION}'"
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "composer require livewire/livewire ${LIVEWIRE_VERSION}"
fi
if [ "${PROJECT_TYPE}" = "wordpress" ]; then
echo "Downloading WordPress core"
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
wp core download \ wp core download \
--locale=${WP_LOCALE} \ --locale=${WP_LOCALE} \
--path=/var/www/html \ --path=/var/www/html \
--version=${WP_VERSION}" --version=${WP_VERSION}"
echo "Creating WordPress config" echo "Creating WordPress config"
docker exec --user www-data "${PREFIX}-app" /bin/sh -c ' docker exec --user www-data "${PREFIX}-app" /bin/sh -c '
wp config create \ wp config create \
--dbhost='"${PREFIX}-db"' \ --dbhost='"${PREFIX}-db"' \
--dbname='"${DB_NAME}"' \ --dbname='"${DB_NAME}"' \
@@ -129,12 +143,12 @@ docker exec --user www-data "${PREFIX}-app" /bin/sh -c '
--path=/var/www/html \ --path=/var/www/html \
--skip-check \ --skip-check \
--extra-php <<EXTRA-PHP --extra-php <<EXTRA-PHP
if (isset(\$_SERVER["HTTP_X_FORWARDED_PROTO"]) && \$_SERVER["HTTP_X_FORWARDED_PROTO"] == "https") \$_SERVER["HTTPS"]="on"; if (isset(\$_SERVER["HTTP_X_FORWARDED_PROTO"]) && \$_SERVER["HTTP_X_FORWARDED_PROTO"] == "https") \$_SERVER["HTTPS"]="on";
EXTRA-PHP EXTRA-PHP
' '
echo "Installing WordPress core" echo "Installing WordPress core"
docker exec --user www-data "${PREFIX}-app" /bin/sh -c " docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
wp core install \ wp core install \
--admin_email=no@mail.com \ --admin_email=no@mail.com \
--admin_password=${WP_ADMIN_PASSWORD} \ --admin_password=${WP_ADMIN_PASSWORD} \
@@ -144,11 +158,13 @@ docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
--title=${PREFIX} \ --title=${PREFIX} \
--url=${WP_DEFAULT_PROTOCOL}://${APP_URL}" --url=${WP_DEFAULT_PROTOCOL}://${APP_URL}"
echo "Installing WordPress "${WP_THEME}" theme" echo "Installing WordPress "${WP_THEME}" theme"
docker exec --user www-data "${PREFIX}-app" /bin/sh -c " docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
wp theme install ${WP_THEME} \ wp theme install ${WP_THEME} \
--activate \ --activate \
--path=/var/www/html" --path=/var/www/html"
fi
docker compose up -d adminer docker compose up -d adminer
docker compose up -d app
docker compose up -d traefik docker compose up -d traefik

View File

@@ -40,6 +40,7 @@ services:
- root:/root - root:/root
- webroot:/var/www/html - webroot:/var/www/html
- wp-cli-cache:/var/www/.wp-cli - wp-cli-cache:/var/www/.wp-cli
- cache:/var/www/.cache
db: db:
command: --default-authentication-plugin=mysql_native_password command: --default-authentication-plugin=mysql_native_password
container_name: ${PREFIX}-db container_name: ${PREFIX}-db
@@ -80,6 +81,8 @@ services:
version: "3.4" version: "3.4"
volumes: volumes:
cache:
name: composer-cache
db: db:
name: ${PREFIX}-db name: ${PREFIX}-db
root: root:

View File

@@ -1,4 +1,4 @@
SSL_CRT_LOCATION=<path> SSL_CRT_LOCATION=<path>
SSL_CRT_NAME<certificate filename> SSL_CRT_NAME=<certificate filename>
SSL_KEY_LOCATION=<path> SSL_KEY_LOCATION=<path>
SSL_KEY_NAME=<key filename> SSL_KEY_NAME=<key filename>

View File

@@ -0,0 +1,3 @@
PROJECT_TYPE=wordpress
PROJECT_TYPE=laravel
PROJECT_TYPE=livewire

View File

@@ -1,2 +1,2 @@
REMOTE_SSH_STRING=<sshconfig hostname> REMOTE_SSH_STRING=<sshconfig hostname>
REMOTE_WP_PATH=</var/www/example.com.be> REMOTE_WP_PATH=</var/www/example.com>

View File

@@ -1,4 +1,4 @@
local_ip_on_remote=localhost LOCAL_IP_ON_REMOTE=localhost
local_port=5432 LOCAL_PORT=5432
local_port_on_remote=5432 LOCAL_PORT_ON_REMOTE=5432
remote_host=federal-non-interactive REMOTE_HOST=federal-non-interactive

View File

@@ -20,5 +20,5 @@ ssh \
-v \ -v \
-N \ -N \
-L \ -L \
"${TRAEFIK_LISTENING_IP}:${local_port}:${local_ip_on_remote}:${local_port_on_remote}" \ "${TRAEFIK_LISTENING_IP}:${LOCAL_PORT}:${LOCAL_IP_ON_REMOTE}:${LOCAL_PORT_ON_REMOTE}" \
"${remote_host}" "${REMOTE_HOST}"