Compare commits
16 Commits
d582d4c7f0
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
062c764c9b | ||
|
|
c5716b8f7a | ||
|
|
7331fcf2d0 | ||
|
|
8997df6327 | ||
|
|
fbcba7cde4 | ||
|
|
07368aff02 | ||
|
|
e61b00b184 | ||
|
|
22a6286487 | ||
|
|
a51f2ae8f3 | ||
|
|
441dc6b371 | ||
|
|
cde2a715fb | ||
|
|
c55c46df0d | ||
|
|
4971511309 | ||
|
|
95391a995c | ||
|
|
6e0719ec50 | ||
|
|
c1ae487788 |
@@ -4,6 +4,8 @@ DB_NAME=wordpress
|
||||
DB_ROOT_PASSWORD=root
|
||||
DB_USER=user
|
||||
DB_USER_PASSWORD=password
|
||||
LARAVEL_VERSION=11.0
|
||||
LIVEWIRE_VERSION=3.5.10
|
||||
PHP_POST_MAX_SIZE=10m
|
||||
PHP_UPLOAD_MAX_FILESIZE=10M
|
||||
PREFIX=wpdocker
|
||||
|
||||
8
TODO.md
8
TODO.md
@@ -3,3 +3,11 @@
|
||||
- [ ] ajouter un moyen d'accéder à la db via un port
|
||||
- [ ] ajouter une option pour créer sans traefik et sans adminer (via override compose)
|
||||
- [ ] remplacer -a par --recursive,etc pour éviter qu'rsync n'affiche un transfert si atime, ctime, mtime a changé pour un fichier
|
||||
|
||||
# wintercms
|
||||
|
||||
- [ ] configurer l'écran de login du back-end en HTTPS
|
||||
|
||||
# wordpress
|
||||
|
||||
- [ ] documenter wppb-cli
|
||||
|
||||
20
backup.sh
20
backup.sh
@@ -10,11 +10,14 @@ set -a
|
||||
. "${PWD}/.env"
|
||||
set +a
|
||||
|
||||
now="$(date +%Y-%m_%d-%H-%M-%S)"
|
||||
docker compose stop
|
||||
|
||||
now="$(date +%Y-%m-%d_%H-%M-%S)"
|
||||
backup_path="${PWD}/backup-volumes/${now}"
|
||||
mkdir -p "${backup_path}"
|
||||
|
||||
volumes="db root traefik-dynamic traefik-certs traefik-logs traefik-static webroot"
|
||||
volumes="db"
|
||||
for volume in ${volumes}; do
|
||||
mkdir -p "${backup_path}/${volume}"
|
||||
docker run \
|
||||
@@ -25,9 +28,24 @@ for volume in ${volumes}; do
|
||||
tar -cvzf "/destination/${volume}.tar.gz" -C "/${volume}" .
|
||||
done
|
||||
|
||||
docker compose restart db
|
||||
docker compose restart app
|
||||
while ! docker ps -q -f name="${PREFIX}-db"; do
|
||||
echo "Waiting for the db container to be up and running..."
|
||||
sleep 1
|
||||
done
|
||||
|
||||
while ! docker exec "${PREFIX}-app" /bin/sh -c "mysqladmin ping -h ${PREFIX}-db -P 3306 --protocol=tcp -u user -puser --silent"; do
|
||||
echo "Waiting for the mysql server in the db container to be up and running and reachable from the app container..."
|
||||
sleep 1
|
||||
done
|
||||
|
||||
mkdir -p "${backup_path}/db"
|
||||
docker exec "${PREFIX}-db" \
|
||||
/usr/bin/mysqldump \
|
||||
-u root \
|
||||
--password="${DB_ROOT_PASSWORD}" \
|
||||
"${DB_NAME}" > "${backup_path}/db/${DB_NAME}.sql"
|
||||
|
||||
docker compose stop db
|
||||
docker compose stop app
|
||||
|
||||
35
check-diff.sh
Normal file
35
check-diff.sh
Normal file
@@ -0,0 +1,35 @@
|
||||
#! /bin/sh
|
||||
#
|
||||
|
||||
set -x
|
||||
if [ "$#" -eq 0 ] || [ "$#" -gt 1 ]; then
|
||||
echo takes only one argument
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ ! -e "${1}" ]; then
|
||||
echo cannot find "${1}"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# shellcheck source=./env_files/checkdiff-example.env
|
||||
. "${1}"
|
||||
|
||||
remote_copy_path=$(mktemp -d)
|
||||
rsync \
|
||||
--archive \
|
||||
--checksum \
|
||||
--human-readable \
|
||||
"${REMOTE_SSH_STRING}":"${REMOTE_ROOT_PATH}${FOLDER_PATH}/" \
|
||||
"${remote_copy_path}"
|
||||
|
||||
local_copy_path=$(mktemp -d)
|
||||
rsync \
|
||||
--archive \
|
||||
--checksum \
|
||||
--exclude-from="${EXCLUDEFILE_PATH}" \
|
||||
--human-readable \
|
||||
"${LOCAL_ROOT_PATH}${FOLDER_PATH}/" \
|
||||
"${local_copy_path}"
|
||||
|
||||
kdiff3 "${local_copy_path}" "${remote_copy_path}"
|
||||
138
create.sh
138
create.sh
@@ -9,6 +9,7 @@ fi
|
||||
set -a
|
||||
. "${PWD}/.env"
|
||||
. "${PWD}/env_files/certs.env"
|
||||
. "${PWD}/env_files/project.env"
|
||||
set +a
|
||||
|
||||
mkdir -p "/tmp/${PREFIX}"
|
||||
@@ -22,6 +23,7 @@ docker volume create "${PREFIX}-traefik-logs"
|
||||
docker volume create "${PREFIX}-traefik-static"
|
||||
docker volume create "${PREFIX}-webroot"
|
||||
docker volume create wp-cli-cache
|
||||
docker volume create composer-cache
|
||||
|
||||
echo "Copying SSL certificates to traefik volume"
|
||||
if [ ! -f "${SSL_CRT_LOCATION}/${SSL_CRT_NAME}" ] || [ ! -f "${SSL_KEY_LOCATION}/${SSL_KEY_NAME}" ]; then
|
||||
@@ -111,44 +113,112 @@ while ! docker exec "${PREFIX}-app" /bin/sh -c "mysqladmin ping -h ${PREFIX}-db
|
||||
sleep 1
|
||||
done
|
||||
|
||||
echo "Downloading WordPress core"
|
||||
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
|
||||
wp core download \
|
||||
--locale=${WP_LOCALE} \
|
||||
--path=/var/www/html \
|
||||
--version=${WP_VERSION}"
|
||||
if [ "${PROJECT_TYPE}" = "laravel" ]; then
|
||||
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
|
||||
|
||||
echo "Creating WordPress config"
|
||||
docker exec --user www-data "${PREFIX}-app" /bin/sh -c '
|
||||
wp config create \
|
||||
--dbhost='"${PREFIX}-db"' \
|
||||
--dbname='"${DB_NAME}"' \
|
||||
--dbpass='"${DB_USER_PASSWORD}"' \
|
||||
--dbuser='"${DB_USER}"' \
|
||||
--force \
|
||||
--path=/var/www/html \
|
||||
--skip-check \
|
||||
--extra-php <<EXTRA-PHP
|
||||
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}" = "wintercms" ]; then
|
||||
echo "Installing wintercms"
|
||||
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "composer create-project wintercms/winter /var/www/html"
|
||||
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "echo ASSET_URL=https://${APP_URL} >> /var/www/html/.env"
|
||||
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "echo DB_DATABASE=${DB_NAME} >> /var/www/html/.env"
|
||||
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "echo DB_USERNAME=${DB_USER} >> /var/www/html/.env"
|
||||
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "echo DB_PASSWORD=${DB_USER_PASSWORD} >> /var/www/html/.env"
|
||||
docker exec --user www-data --workdir "/var/www/html" "${PREFIX}-app" /bin/sh -c "echo DB_HOST=${PREFIX}-db >> /var/www/html/.env"
|
||||
docker exec --user root "${PREFIX}-app" /bin/sh -c "sed -i 's|/var/www/html/public|/var/www/html|g' /etc/apache2/sites-available/000-default.conf"
|
||||
docker restart "${PREFIX}-app"
|
||||
docker exec --user www-data --workdir "/var/www/html" -it "${PREFIX}-app" /bin/sh -c "php artisan winter:install"
|
||||
fi
|
||||
|
||||
if [ "${PROJECT_TYPE}" = "laravel" ] || [ "${PROJECT_TYPE}" = "livewire" ] || [ "${PROJECT_TYPE}" = "php" ]; then
|
||||
echo "Generating vscode launch.json file"
|
||||
cat << EOF > /tmp/${PREFIX}/launch.json
|
||||
{
|
||||
"version": "0.2.0",
|
||||
"configurations": [
|
||||
{
|
||||
"hostname": "${TRAEFIK_LISTENING_IP}",
|
||||
"name": "Listen for Xdebug (${TRAEFIK_LISTENING_IP})",
|
||||
"pathMappings": {
|
||||
"/var/www/html/": "\${workspaceRoot}/",
|
||||
},
|
||||
"port": 9003,
|
||||
"request": "launch",
|
||||
"type": "php"
|
||||
}
|
||||
]
|
||||
}
|
||||
EOF
|
||||
docker run \
|
||||
--rm \
|
||||
--user www-data \
|
||||
--volume "${PREFIX}-app":/destination \
|
||||
ubuntu \
|
||||
mkdir --parents /destination/.vscode
|
||||
docker run \
|
||||
--rm \
|
||||
--user www-data \
|
||||
--volume "${PREFIX}-app":/destination \
|
||||
ubuntu \
|
||||
cp /source/launch.json /destination/.vscode
|
||||
docker run \
|
||||
--rm \
|
||||
--user root \
|
||||
--volume "${PREFIX}-app":/destination \
|
||||
ubuntu \
|
||||
chown www-data:www-data /destination/.vscode -r
|
||||
fi
|
||||
|
||||
if [ "${PROJECT_TYPE}" = "wordpress" ]; then
|
||||
echo "Installing wppb-cli"
|
||||
composer global require tmeister/wppb-cli
|
||||
echo "Downloading WordPress core"
|
||||
docker exec --user www-data "${PREFIX}-app" /bin/sh -c "
|
||||
wp core download \
|
||||
--locale=${WP_LOCALE} \
|
||||
--path=/var/www/html \
|
||||
--version=${WP_VERSION}"
|
||||
|
||||
echo "Creating WordPress config"
|
||||
docker exec --user www-data "${PREFIX}-app" /bin/sh -c '
|
||||
wp config create \
|
||||
--dbhost='"${PREFIX}-db"' \
|
||||
--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"
|
||||
|
||||
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 app
|
||||
docker compose up -d traefik
|
||||
|
||||
@@ -40,6 +40,7 @@ services:
|
||||
- root:/root
|
||||
- webroot:/var/www/html
|
||||
- wp-cli-cache:/var/www/.wp-cli
|
||||
- cache:/var/www/.cache
|
||||
db:
|
||||
command: --default-authentication-plugin=mysql_native_password
|
||||
container_name: ${PREFIX}-db
|
||||
@@ -77,22 +78,31 @@ services:
|
||||
- traefik-logs:/logs
|
||||
- traefik-static:/etc/traefik/static:ro
|
||||
|
||||
version: "3.4"
|
||||
|
||||
volumes:
|
||||
cache:
|
||||
external: true
|
||||
name: composer-cache
|
||||
db:
|
||||
external: true
|
||||
name: ${PREFIX}-db
|
||||
root:
|
||||
external: true
|
||||
name: ${PREFIX}-root
|
||||
traefik-certs:
|
||||
external: true
|
||||
name: ${PREFIX}-traefik-certs
|
||||
traefik-dynamic:
|
||||
external: true
|
||||
name: ${PREFIX}-traefik-dynamic
|
||||
traefik-logs:
|
||||
external: true
|
||||
name: ${PREFIX}-traefik-logs
|
||||
traefik-static:
|
||||
external: true
|
||||
name: ${PREFIX}-traefik-static
|
||||
webroot:
|
||||
external: true
|
||||
name: ${PREFIX}-webroot
|
||||
wp-cli-cache:
|
||||
external: true
|
||||
name: wp-cli-cache
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
SSL_CRT_LOCATION=<path>
|
||||
SSL_CRT_NAME<certificate filename>
|
||||
SSL_CRT_NAME=<certificate filename>
|
||||
SSL_KEY_LOCATION=<path>
|
||||
SSL_KEY_NAME=<key filename>
|
||||
|
||||
5
env_files/checkdiff-example.env
Normal file
5
env_files/checkdiff-example.env
Normal file
@@ -0,0 +1,5 @@
|
||||
REMOTE_SSH_STRING=<sshconfig hostname>
|
||||
REMOTE_ROOT_PATH=</var/www/example.com/www>
|
||||
LOCAL_ROOT_PATH=</home/user/dev/www>
|
||||
FOLDER_PATH=</wp-content/themes/bar>
|
||||
EXCLUDEFILE_PATH=<./deployment/example.com.bar.exclude>
|
||||
5
env_files/project-example.env
Normal file
5
env_files/project-example.env
Normal file
@@ -0,0 +1,5 @@
|
||||
PROJECT_TYPE=laravel
|
||||
PROJECT_TYPE=livewire
|
||||
PROJECT_TYPE=php
|
||||
PROJECT_TYPE=wintercms
|
||||
PROJECT_TYPE=wordpress
|
||||
@@ -1,2 +1,2 @@
|
||||
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_port=5432
|
||||
local_port_on_remote=5432
|
||||
remote_host=federal-non-interactive
|
||||
LOCAL_IP_ON_REMOTE=localhost
|
||||
LOCAL_PORT=5432
|
||||
LOCAL_PORT_ON_REMOTE=5432
|
||||
REMOTE_HOST=federal-non-interactive
|
||||
|
||||
@@ -20,5 +20,5 @@ ssh \
|
||||
-v \
|
||||
-N \
|
||||
-L \
|
||||
"${TRAEFIK_LISTENING_IP}:${local_port}:${local_ip_on_remote}:${local_port_on_remote}" \
|
||||
"${remote_host}"
|
||||
"${TRAEFIK_LISTENING_IP}:${LOCAL_PORT}:${LOCAL_IP_ON_REMOTE}:${LOCAL_PORT_ON_REMOTE}" \
|
||||
"${REMOTE_HOST}"
|
||||
|
||||
@@ -6,8 +6,8 @@ set -a
|
||||
set +a
|
||||
|
||||
docker exec \
|
||||
-e SHELLOPTS=vi \
|
||||
-e HISTFILE=/var/www/html/.bash_history \
|
||||
-e SHELLOPTS=vi \
|
||||
-it --user www-data \
|
||||
"${PREFIX}-app" \
|
||||
/bin/bash
|
||||
Reference in New Issue
Block a user