Compare commits
3 Commits
d582d4c7f0
...
95391a995c
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
95391a995c | ||
|
|
6e0719ec50 | ||
|
|
c1ae487788 |
@@ -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
|
||||||
|
|||||||
88
create.sh
88
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} \
|
echo "Creating WordPress config"
|
||||||
--url=${WP_DEFAULT_PROTOCOL}://${APP_URL}"
|
docker exec --user www-data "${PREFIX}-app" /bin/sh -c '
|
||||||
|
wp config create \
|
||||||
echo "Installing WordPress "${WP_THEME}" theme"
|
--dbhost='"${PREFIX}-db"' \
|
||||||
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
|
--dbname='"${DB_NAME}"' \
|
||||||
wp theme install ${WP_THEME} \
|
--dbpass='"${DB_USER_PASSWORD}"' \
|
||||||
--activate \
|
--dbuser='"${DB_USER}"' \
|
||||||
--path=/var/www/html"
|
--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:
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
3
env_files/project-example.env
Normal file
3
env_files/project-example.env
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
PROJECT_TYPE=wordpress
|
||||||
|
PROJECT_TYPE=laravel
|
||||||
|
PROJECT_TYPE=livewire
|
||||||
@@ -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>
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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}"
|
||||||
|
|||||||
Reference in New Issue
Block a user