adds support for laravel and livewire
This commit is contained in:
@@ -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
|
||||||
|
|||||||
86
create.sh
86
create.sh
@@ -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,44 +113,58 @@ 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"
|
||||||
wp core download \
|
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}'"
|
||||||
--locale=${WP_LOCALE} \
|
fi
|
||||||
--path=/var/www/html \
|
|
||||||
--version=${WP_VERSION}"
|
|
||||||
|
|
||||||
echo "Creating WordPress config"
|
if [ "${PROJECT_TYPE}" = "livewire" ]; then
|
||||||
docker exec --user www-data "${PREFIX}-app" /bin/sh -c '
|
echo "Installing livewire"
|
||||||
wp config create \
|
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}'"
|
||||||
--dbhost='"${PREFIX}-db"' \
|
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "composer require livewire/livewire ${LIVEWIRE_VERSION}"
|
||||||
--dbname='"${DB_NAME}"' \
|
fi
|
||||||
--dbpass='"${DB_USER_PASSWORD}"' \
|
|
||||||
--dbuser='"${DB_USER}"' \
|
|
||||||
--force \
|
|
||||||
--path=/var/www/html \
|
|
||||||
--skip-check \
|
|
||||||
--extra-php <<EXTRA-PHP
|
|
||||||
if (isset(\$_SERVER["HTTP_X_FORWARDED_PROTO"]) && \$_SERVER["HTTP_X_FORWARDED_PROTO"] == "https") \$_SERVER["HTTPS"]="on";
|
|
||||||
EXTRA-PHP
|
|
||||||
'
|
|
||||||
|
|
||||||
echo "Installing WordPress core"
|
if [ "${PROJECT_TYPE}" = "wordpress" ]; then
|
||||||
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
|
echo "Downloading WordPress core"
|
||||||
wp core install \
|
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
|
||||||
--admin_email=no@mail.com \
|
wp core download \
|
||||||
--admin_password=${WP_ADMIN_PASSWORD} \
|
--locale=${WP_LOCALE} \
|
||||||
--admin_user=${WP_ADMIN_USERNAME} \
|
--path=/var/www/html \
|
||||||
--path=/var/www/html \
|
--version=${WP_VERSION}"
|
||||||
--skip-email \
|
|
||||||
--title=${PREFIX} \
|
|
||||||
--url=${WP_DEFAULT_PROTOCOL}://${APP_URL}"
|
|
||||||
|
|
||||||
echo "Installing WordPress "${WP_THEME}" theme"
|
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 theme install ${WP_THEME} \
|
wp config create \
|
||||||
--activate \
|
--dbhost='"${PREFIX}-db"' \
|
||||||
--path=/var/www/html"
|
--dbname='"${DB_NAME}"' \
|
||||||
|
--dbpass='"${DB_USER_PASSWORD}"' \
|
||||||
|
--dbuser='"${DB_USER}"' \
|
||||||
|
--force \
|
||||||
|
--path=/var/www/html \
|
||||||
|
--skip-check \
|
||||||
|
--extra-php <<EXTRA-PHP
|
||||||
|
if (isset(\$_SERVER["HTTP_X_FORWARDED_PROTO"]) && \$_SERVER["HTTP_X_FORWARDED_PROTO"] == "https") \$_SERVER["HTTPS"]="on";
|
||||||
|
EXTRA-PHP
|
||||||
|
'
|
||||||
|
|
||||||
|
echo "Installing WordPress core"
|
||||||
|
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
|
||||||
|
wp core install \
|
||||||
|
--admin_email=no@mail.com \
|
||||||
|
--admin_password=${WP_ADMIN_PASSWORD} \
|
||||||
|
--admin_user=${WP_ADMIN_USERNAME} \
|
||||||
|
--path=/var/www/html \
|
||||||
|
--skip-email \
|
||||||
|
--title=${PREFIX} \
|
||||||
|
--url=${WP_DEFAULT_PROTOCOL}://${APP_URL}"
|
||||||
|
|
||||||
|
echo "Installing WordPress "${WP_THEME}" theme"
|
||||||
|
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
|
||||||
|
wp theme install ${WP_THEME} \
|
||||||
|
--activate \
|
||||||
|
--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
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
Reference in New Issue
Block a user