Compare commits
58 Commits
db86932c71
...
uvicorn
| Author | SHA1 | Date | |
|---|---|---|---|
| 2695d1f759 | |||
| 3cb9b6e925 | |||
| 4e0c2dbfc4 | |||
| 3faf8a698a | |||
| f3b9303754 | |||
| 0e1bd3246d | |||
| 184fc3dc2d | |||
| 2db44cb74e | |||
| e17103f4ab | |||
| e59e976cd9 | |||
| 33a0756530 | |||
| 5c1c94bfe2 | |||
| 46a0154871 | |||
| 25368c8408 | |||
| c37ff438d8 | |||
| b0cd920e41 | |||
| dc3b0a76a7 | |||
| 35baceb62a | |||
| f63747e59f | |||
| 1677ffe648 | |||
| 32b98ae170 | |||
| 5dcd3a131c | |||
| a3f7465955 | |||
| a244fec29a | |||
| eb64cd702a | |||
| fd7c8b9ac1 | |||
| 2049580005 | |||
| b1b2e1d501 | |||
| baa258b8fb | |||
| cea2dbb653 | |||
| 217250c0e0 | |||
| a87fc51072 | |||
| d29546cb34 | |||
| 1b35c6927c | |||
| 767aa7ba37 | |||
| 1771877fe8 | |||
| fc044a1185 | |||
| 38cb19818a | |||
| c07f142607 | |||
| ca9f40667b | |||
| 7de00f8385 | |||
| 0bbc4eedd7 | |||
| 42d0209290 | |||
| 75b35e22a9 | |||
| 97609898e1 | |||
| 15c6a8eb53 | |||
| 829107e5f5 | |||
| ee023006ff | |||
| dbe3a916f1 | |||
| 9fab9307b6 | |||
| 71d4b97c46 | |||
| c3d132b120 | |||
| d625dbb158 | |||
| aa74376503 | |||
| 9bc71f7b2d | |||
| c11eb7bf7c | |||
| b0683316de | |||
| 2b24d70652 |
26
.env.example
26
.env.example
@ -2,21 +2,35 @@
|
|||||||
DOCKER_HOST_IP=172.20.0.1
|
DOCKER_HOST_IP=172.20.0.1
|
||||||
PROJECTS_DIR=/home/youruser/PhpstormProjects
|
PROJECTS_DIR=/home/youruser/PhpstormProjects
|
||||||
|
|
||||||
|
# All options below dramastically need defined in docker-compose.*.yml
|
||||||
|
|
||||||
|
### PHP COMMON #############################################
|
||||||
|
INSTALL_REDIS=true
|
||||||
|
INSTALL_PEAR_MAIL=true
|
||||||
|
INSTALL_LIBREOFFICE=true
|
||||||
|
|
||||||
### WORKSPACE #############################################
|
### WORKSPACE #############################################
|
||||||
WORKSPACE_PUID=1000
|
WORKSPACE_PUID=1000
|
||||||
WORKSPACE_PGID=1000
|
WORKSPACE_PGID=1000
|
||||||
WORKSPACE_TIMEZONE=Europe/Moscow
|
WORKSPACE_TIMEZONE=Europe/Moscow
|
||||||
|
|
||||||
|
WORKSPACE_LEGACY_COMPOSER_VERSION=1
|
||||||
|
WORKSPACE_LEGACY_NODE_VERSION=lts/fermium
|
||||||
WORKSPACE_COMPOSER_VERSION=2
|
WORKSPACE_COMPOSER_VERSION=2
|
||||||
WORKSPACE_CUSTOM_NODE_VERSION=lts/fermium
|
WORKSPACE_NODE_VERSION=lts/hydrogen
|
||||||
|
|
||||||
|
WORKSPACE_PHP_OPT_MAX_EXECUTION_TIME=0
|
||||||
|
WORKSPACE_PHP_OPT_MEMORY_LIMIT=-1
|
||||||
|
|
||||||
|
WORKSPACE_INSTALL_SUPERVISOR=false
|
||||||
|
WORKSPACE_INSTALL_PYTHON=false
|
||||||
|
|
||||||
### PHP-FPM #############################################
|
### PHP-FPM #############################################
|
||||||
INSTALL_REDIS=true
|
|
||||||
INSTALL_PEAR_MAIL=true
|
|
||||||
PHP_OPT_SHORT_OPEN_TAG=Off
|
PHP_OPT_SHORT_OPEN_TAG=Off
|
||||||
PHP_OPT_MAX_EXECUTION_TIME=600
|
PHP_OPT_MAX_EXECUTION_TIME=600
|
||||||
PHP_OPT_MEMORY_LIMIT=500M
|
PHP_OPT_MEMORY_LIMIT=256M
|
||||||
PHP_OPT_POST_MAX_SIZE=48M
|
PHP_OPT_POST_MAX_SIZE=800M
|
||||||
PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
PHP_OPT_UPLOAD_MAX_FILESIZE=200M
|
||||||
|
|
||||||
### MINIO S3 #############################################
|
### MINIO S3 #############################################
|
||||||
MINIO_ACCESS_KEY=s3.local
|
MINIO_ACCESS_KEY=s3.local
|
||||||
|
|||||||
7
.gitignore
vendored
7
.gitignore
vendored
@ -1,6 +1,9 @@
|
|||||||
/.idea
|
/.idea
|
||||||
/dockerfiles/ypt-encoder
|
/dockerfiles/ypt-encoder
|
||||||
/docker-compose.yml
|
/docker-compose*
|
||||||
/docker-compose.elastic.yml
|
!/docker-compose.base.yml
|
||||||
|
!/docker-compose*.example
|
||||||
|
/docker-compose.nodejs.yml
|
||||||
/.env
|
/.env
|
||||||
/*.komodoproject
|
/*.komodoproject
|
||||||
|
/config/nginx/includes.d/auth.passwd
|
||||||
35
README.md
35
README.md
@ -1,3 +1,20 @@
|
|||||||
|
# Prepare
|
||||||
|
|
||||||
|
Copy all example files and dir
|
||||||
|
|
||||||
|
Cop and set your username:
|
||||||
|
`.env.example`
|
||||||
|
|
||||||
|
Choose php version and redis needed redis containers
|
||||||
|
`docker-compose.yml.example`
|
||||||
|
|
||||||
|
`dockerfiles/workspace/crontab-example`
|
||||||
|
|
||||||
|
`dockerfiles/workspace/aliases.sh.example`
|
||||||
|
|
||||||
|
Set your site(s) root-mappings
|
||||||
|
`config/nginx/conf.d/vhosts.conf.example`
|
||||||
|
|
||||||
## First
|
## First
|
||||||
Create alias for `docker-compose` command.
|
Create alias for `docker-compose` command.
|
||||||
|
|
||||||
@ -41,11 +58,11 @@ After execute created symlinks, you have some enter-points for vulnerable popula
|
|||||||
### Xdebug
|
### Xdebug
|
||||||
For start debugging in php-fpm, also in workspace
|
For start debugging in php-fpm, also in workspace
|
||||||
|
|
||||||
`./start-xdebug.sh [74|73]` - `74` by default
|
`./xdebug-start.sh [74|81]` - `74` by default
|
||||||
|
|
||||||
For start debugging in php-fpm, also in workspace
|
For start debugging in php-fpm, also in workspace
|
||||||
|
|
||||||
`./stop-xdebug.sh` or `./stop-xdebug.sh 73` if you launch start with php-version 73
|
`./xdebug-stop.sh` or `./stop-xdebug.sh 81` if you launch start new php version 81
|
||||||
|
|
||||||
#### Xdebug with profiler
|
#### Xdebug with profiler
|
||||||
|
|
||||||
@ -56,17 +73,17 @@ In this case `./data/profiler` must be have `777` chmod`s.
|
|||||||
|
|
||||||
For starting xdebug with profiler enable you might:
|
For starting xdebug with profiler enable you might:
|
||||||
|
|
||||||
`./start-xdebug.sh 74 1`
|
`./xdebug-start.sh 74 1`
|
||||||
|
|
||||||
Or
|
Or
|
||||||
|
|
||||||
`./start-xdebug.sh 74 profiler` if you like
|
`./xdebug-start.sh 74 profiler` if you like
|
||||||
|
|
||||||
Second argument must be have any string
|
Second argument must be have any string
|
||||||
|
|
||||||
For disable profiler - just simple launch
|
For disable profiler - just simple launch
|
||||||
|
|
||||||
`./quit-xdebug.sh`
|
`./xdebug-quit.sh`
|
||||||
|
|
||||||
|
|
||||||
### Mysql
|
### Mysql
|
||||||
@ -102,6 +119,14 @@ For restart `nginx` after some changes in nginx configuration, you might:
|
|||||||
|
|
||||||
`./restart-nginx.sh`
|
`./restart-nginx.sh`
|
||||||
|
|
||||||
|
### Elastic
|
||||||
|
|
||||||
|
Copy example
|
||||||
|
|
||||||
|
Launch:
|
||||||
|
|
||||||
|
`dc -f docker-compose.elastic.yml up -d elastic`
|
||||||
|
|
||||||
## Src build need DOCKER_BUILDKIT
|
## Src build need DOCKER_BUILDKIT
|
||||||
|
|
||||||
If you want build own workspace image. You need export environment variable
|
If you want build own workspace image. You need export environment variable
|
||||||
|
|||||||
15
bash/_docker-cmd.sh
Normal file
15
bash/_docker-cmd.sh
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Grab OS type
|
||||||
|
if [[ "$(uname)" == "Darwin" ]]; then
|
||||||
|
OS_TYPE="OSX"
|
||||||
|
else
|
||||||
|
OS_TYPE=$(expr substr $(uname -s) 1 5)
|
||||||
|
fi
|
||||||
|
|
||||||
|
DOCKER_CMD=docker
|
||||||
|
|
||||||
|
if [[ $OS_TYPE == "MINGW" ]]; then
|
||||||
|
DOCKER_CMD="winpty docker"
|
||||||
|
fi
|
||||||
|
|
||||||
|
export DOCKER_CMD
|
||||||
2
bash/change-hosts-on-windows.sh
Normal file
2
bash/change-hosts-on-windows.sh
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
sed -i 's/.* host.docker.internal/127.0.0.1 host.docker.internal/' /c/Windows/System32/drivers/etc/hosts
|
||||||
15
bash/db-restart.sh
Executable file
15
bash/db-restart.sh
Executable file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
. $DIR/bash/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
CONTAINER=$(docker ps | grep db | awk '{print $1}')
|
||||||
|
|
||||||
|
if [[ -z "${CONTAINER}" ]]; then
|
||||||
|
echo "Unable to find container: db"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
$DOCKER_CMD restart ${CONTAINER}
|
||||||
@ -6,4 +6,4 @@ if [[ -z "${CONTAINER}" ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
docker exec -ti ${CONTAINER} mysqldump -u root -p123456 $1 | pv > $2
|
docker exec -ti ${CONTAINER} mariadb-dump -u root -p123456 $1
|
||||||
|
|||||||
@ -1,7 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
SCRIPT_DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
||||||
|
|
||||||
|
. $SCRIPT_DIR/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
PHP_VERSION=$1 # Without dot
|
PHP_VERSION=$1 # Without dot
|
||||||
|
|
||||||
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=74; fi
|
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=81; fi
|
||||||
|
|
||||||
CONTAINER=$(docker ps | grep workspace${PHP_VERSION} | awk '{print $1}')
|
CONTAINER=$(docker ps | grep workspace${PHP_VERSION} | awk '{print $1}')
|
||||||
|
|
||||||
@ -10,4 +16,4 @@ if [[ -z "${CONTAINER}" ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
docker exec -ti ${CONTAINER} su laradock
|
$DOCKER_CMD exec -ti ${CONTAINER} su laradock
|
||||||
|
|||||||
15
bash/mariadb.sh
Executable file
15
bash/mariadb.sh
Executable file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
SCRIPT_DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
||||||
|
|
||||||
|
. $SCRIPT_DIR/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
CONTAINER=$(docker ps | grep mariadb | awk '{print $1}')
|
||||||
|
|
||||||
|
if [[ -z "${CONTAINER}" ]]; then
|
||||||
|
echo "Unable to find container: db"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
$DOCKER_CMD exec -ti ${CONTAINER} bash -c 'LANG=ru_RU.UTF-8 mariadb -u root -p123456'
|
||||||
@ -1,4 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
SCRIPT_DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
||||||
|
|
||||||
|
. $SCRIPT_DIR/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
CONTAINER=$(docker ps | grep mariadb | awk '{print $1}')
|
CONTAINER=$(docker ps | grep mariadb | awk '{print $1}')
|
||||||
|
|
||||||
if [[ -z "${CONTAINER}" ]]; then
|
if [[ -z "${CONTAINER}" ]]; then
|
||||||
@ -6,4 +12,18 @@ if [[ -z "${CONTAINER}" ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
docker exec -ti ${CONTAINER} bash -c 'LANG=ru_RU.UTF-8 mysql -u root -p123456'
|
MYSQL_CMD='mysql -u root -p123456'
|
||||||
|
|
||||||
|
SQL_QUERY=$1
|
||||||
|
|
||||||
|
if [[ -n "${SQL_QUERY}" ]]; then
|
||||||
|
MYSQL_CMD="${MYSQL_CMD} -e \"${SQL_QUERY}\""
|
||||||
|
|
||||||
|
SELECTED_DB=$2
|
||||||
|
|
||||||
|
if [[ -n "${SELECTED_DB}" ]]; then
|
||||||
|
MYSQL_CMD="${MYSQL_CMD} \"${SELECTED_DB}\""
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
$DOCKER_CMD exec -ti ${CONTAINER} bash -c "LANG=ru_RU.UTF-8 ${MYSQL_CMD}"
|
||||||
|
|||||||
6
bash/nginx-ssl-gen.sh
Normal file
6
bash/nginx-ssl-gen.sh
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
cd ${DIR}/config/nginx/ssl.d && \
|
||||||
|
openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -sha256 -days 3650 -nodes -subj \
|
||||||
|
"/C=XX/ST=RU/L=RU/O=WPS/OU=Dev/CN=test"
|
||||||
22
bash/pm2-restart.sh
Executable file
22
bash/pm2-restart.sh
Executable file
@ -0,0 +1,22 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
. $DIR/bash/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
PM2_SERVICE=$1
|
||||||
|
|
||||||
|
if [[ -z "${PM2_SERVICE}" ]]; then
|
||||||
|
echo "Usage: $(basename $0) NODEJS_PROJECT_NAME"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
CONTAINER=$(docker ps | grep "pm2-${PM2_SERVICE}" | awk '{print $1}')
|
||||||
|
|
||||||
|
if [[ -z "${CONTAINER}" ]]; then
|
||||||
|
echo "Unable to find container: db"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
$DOCKER_CMD restart ${CONTAINER}
|
||||||
@ -1,10 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
|
||||||
|
|
||||||
PHP_VERSION=$1 # Without dot
|
|
||||||
WITH_PROFILER=$2
|
|
||||||
|
|
||||||
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=74; fi
|
|
||||||
|
|
||||||
${DIR}/dockerfiles/php-fpm/xdebug.sh stop ${PHP_VERSION} ${WITH_PROFILER}
|
|
||||||
${DIR}/dockerfiles/workspace/xdebug.sh stop ${PHP_VERSION} ${WITH_PROFILER}
|
|
||||||
@ -1,4 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
SCRIPT_DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
||||||
|
|
||||||
|
. $SCRIPT_DIR/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
CONTAINER=$(docker ps | grep nginx | awk '{print $1}')
|
CONTAINER=$(docker ps | grep nginx | awk '{print $1}')
|
||||||
|
|
||||||
if [[ -z "${CONTAINER}" ]]; then
|
if [[ -z "${CONTAINER}" ]]; then
|
||||||
@ -6,4 +12,4 @@ if [[ -z "${CONTAINER}" ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
docker exec -ti ${CONTAINER} nginx -s reload
|
$DOCKER_CMD exec -ti ${CONTAINER} nginx -s reload
|
||||||
20
bash/root-onto-workspace.sh
Normal file
20
bash/root-onto-workspace.sh
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
SCRIPT_DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
||||||
|
|
||||||
|
. $SCRIPT_DIR/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
PHP_VERSION=$1 # Without dot
|
||||||
|
|
||||||
|
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=74; fi
|
||||||
|
|
||||||
|
CONTAINER=$(docker ps | grep workspace${PHP_VERSION} | awk '{print $1}')
|
||||||
|
|
||||||
|
|
||||||
|
if [[ -z "${CONTAINER}" ]]; then
|
||||||
|
echo "Unable to find container: workspace${PHP_VERSION}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
$DOCKER_CMD exec -ti ${CONTAINER}
|
||||||
@ -1,10 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
|
||||||
|
|
||||||
PHP_VERSION=$1 # Without dot
|
|
||||||
WITH_PROFILER=$2
|
|
||||||
|
|
||||||
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=74; fi
|
|
||||||
|
|
||||||
${DIR}/dockerfiles/php-fpm/xdebug.sh start ${PHP_VERSION} ${WITH_PROFILER}
|
|
||||||
${DIR}/dockerfiles/workspace/xdebug.sh start ${PHP_VERSION} ${WITH_PROFILER}
|
|
||||||
11
bash/tail-db-general-log.sh
Executable file
11
bash/tail-db-general-log.sh
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Not working on windows symlinks
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
GENERAL_LOG_FILE_PATH="${DIR}/log/mariadb/mariadb.log"
|
||||||
|
|
||||||
|
sudo truncate -s 0 $GENERAL_LOG_FILE_PATH
|
||||||
|
|
||||||
|
clear
|
||||||
|
|
||||||
|
sudo tail -f $GENERAL_LOG_FILE_PATH | grep -Ev "(Close|Prepare)"
|
||||||
9
bash/tail-nginx-access-log.sh
Executable file
9
bash/tail-nginx-access-log.sh
Executable file
@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Not working on windows symlinks
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
LOG_FILE_PATH="${DIR}/log/nginx/access.log"
|
||||||
|
|
||||||
|
clear
|
||||||
|
|
||||||
|
tail -f $LOG_FILE_PATH
|
||||||
9
bash/tail-nginx-error-log.sh
Executable file
9
bash/tail-nginx-error-log.sh
Executable file
@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Not working on windows symlinks
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
LOG_FILE_PATH="${DIR}/log/nginx/error.log"
|
||||||
|
|
||||||
|
clear
|
||||||
|
|
||||||
|
tail -f $LOG_FILE_PATH
|
||||||
24
bash/update-composer.sh
Executable file
24
bash/update-composer.sh
Executable file
@ -0,0 +1,24 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
SCRIPT_DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
||||||
|
|
||||||
|
. $SCRIPT_DIR/_docker-cmd.sh || {
|
||||||
|
echo "no docker cmd is presented" && exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
PHP_VERSION=$1 # Without dot
|
||||||
|
COMPOSER_VERSION=$2
|
||||||
|
|
||||||
|
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=74; fi
|
||||||
|
|
||||||
|
CONTAINER=$(docker ps | grep workspace${PHP_VERSION} | awk '{print $1}')
|
||||||
|
|
||||||
|
if [[ -z "${CONTAINER}" ]]; then
|
||||||
|
echo "Unable to find container: workspace${PHP_VERSION}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "${COMPOSER_VERSION}" ]]; then
|
||||||
|
COMPOSER_VERSION=1
|
||||||
|
fi
|
||||||
|
|
||||||
|
$DOCKER_CMD exec -ti "${CONTAINER}" composer self-update --${COMPOSER_VERSION}
|
||||||
17
bash/xdebug-quit.sh
Executable file
17
bash/xdebug-quit.sh
Executable file
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Not working on windows symlinks
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
PHP_VERSION=$1 # Without dot
|
||||||
|
WITH_PROFILER=$2
|
||||||
|
|
||||||
|
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=81; fi
|
||||||
|
|
||||||
|
POSSIBLE_XDEBUG_VERSION=xdebug2
|
||||||
|
|
||||||
|
if [[ $PHP_VERSION -ge 81 ]]; then
|
||||||
|
POSSIBLE_XDEBUG_VERSION=xdebug3
|
||||||
|
fi
|
||||||
|
|
||||||
|
${DIR}/dockerfiles/php-fpm/${POSSIBLE_XDEBUG_VERSION}/xdebug.sh stop ${PHP_VERSION} ${WITH_PROFILER}
|
||||||
|
${DIR}/dockerfiles/workspace/xdebug.sh stop ${PHP_VERSION} ${WITH_PROFILER}
|
||||||
27
bash/xdebug-start.sh
Executable file
27
bash/xdebug-start.sh
Executable file
@ -0,0 +1,27 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Not working on windows symlinks
|
||||||
|
DIR="$(realpath $(dirname "$(readlink -f "$0")")/..)"
|
||||||
|
|
||||||
|
PHP_VERSION=$1 # Without dot
|
||||||
|
WITH_PROFILER=$2
|
||||||
|
|
||||||
|
if [[ -z "${PHP_VERSION}" ]]; then PHP_VERSION=81; fi
|
||||||
|
|
||||||
|
POSSIBLE_XDEBUG_VERSION=xdebug2
|
||||||
|
|
||||||
|
echo "Choice PHP_VERSION: $PHP_VERSION"
|
||||||
|
|
||||||
|
if [[ $PHP_VERSION -ge 81 ]]; then
|
||||||
|
POSSIBLE_XDEBUG_VERSION=xdebug3
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Choice POSSIBLE_XDEBUG_VERSION: $POSSIBLE_XDEBUG_VERSION"
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
${DIR}/dockerfiles/php-fpm/${POSSIBLE_XDEBUG_VERSION}/xdebug.sh start ${PHP_VERSION} ${WITH_PROFILER}
|
||||||
|
|
||||||
|
echo
|
||||||
|
${DIR}/dockerfiles/workspace/xdebug.sh start ${PHP_VERSION} ${WITH_PROFILER}
|
||||||
|
|
||||||
|
echo
|
||||||
3
config/dnsmasq/.gitignore
vendored
Normal file
3
config/dnsmasq/.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
*
|
||||||
|
!.gitignore
|
||||||
|
!.example
|
||||||
9
config/dnsmasq/dnsmasq.conf.example
Normal file
9
config/dnsmasq/dnsmasq.conf.example
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
#log all dns queries
|
||||||
|
log-queries
|
||||||
|
#dont use hosts nameservers
|
||||||
|
no-resolv
|
||||||
|
#use google as default nameservers
|
||||||
|
server=8.8.4.4
|
||||||
|
server=8.8.8.8
|
||||||
|
#explicitly define host-ip mappings
|
||||||
|
address=/domain/ip
|
||||||
2
config/mariadb/.gitignore
vendored
Normal file
2
config/mariadb/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
*.cnf
|
||||||
|
*.cnf.disable
|
||||||
3
config/mariadb/90-mysqld.cnf.example
Normal file
3
config/mariadb/90-mysqld.cnf.example
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[mysqld]
|
||||||
|
explicit_defaults_for_timestamp = ON
|
||||||
|
default_time_zone = '+03:00'
|
||||||
3
config/mariadb/root-account.cnf.example
Normal file
3
config/mariadb/root-account.cnf.example
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[client]
|
||||||
|
user = root
|
||||||
|
password = 123456
|
||||||
@ -6,9 +6,13 @@ upstream php74 {
|
|||||||
server php74:9000;
|
server php74:9000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
upstream php81 {
|
||||||
|
server php81:9000;
|
||||||
|
}
|
||||||
|
|
||||||
map $http_host $root {
|
map $http_host $root {
|
||||||
octobercms.ru.local.wpstudio.ru /usr/share/nginx/html/someproject;
|
octobercms.local.wpstudio.ru /usr/share/nginx/html/someproject;
|
||||||
wordpress.ru.local.wpstudio.ru /usr/share/nginx/html/someprojectwp;
|
wordpress.local.wpstudio.ru /usr/share/nginx/html/someprojectwp;
|
||||||
}
|
}
|
||||||
|
|
||||||
# @see https://github.com/OFFLINE-GmbH/oc-responsive-images-plugin/#responsive-images
|
# @see https://github.com/OFFLINE-GmbH/oc-responsive-images-plugin/#responsive-images
|
||||||
@ -17,16 +21,41 @@ map $http_accept $webp_suffix {
|
|||||||
"~*webp" ".webp";
|
"~*webp" ".webp";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
resolver 127.0.0.11;
|
||||||
|
|
||||||
|
map $http_host $uploads_upstream {
|
||||||
|
wordpress.local.wpstudio.ru "https://somewp.site";
|
||||||
|
}
|
||||||
|
|
||||||
server {
|
server {
|
||||||
server_name
|
|
||||||
octobercms.ru.local.wpstudio.ru
|
|
||||||
;
|
|
||||||
listen 80 default;
|
listen 80 default;
|
||||||
root $root;
|
root $root;
|
||||||
#include global/auth.conf;
|
#include global/auth.conf;
|
||||||
#@see https://vcs.wpstudio.ru/wpstudio/nginx-examples
|
#@see https://vcs.wpstudio.ru/wpstudio/nginx-examples
|
||||||
include includes.d/octobercms.conf;
|
include includes.d/octobercms.conf;
|
||||||
include includes.d/staticfiles.conf;
|
include includes.d/staticfiles.conf;
|
||||||
|
client_max_body_size 300M;
|
||||||
|
large_client_header_buffers 4 32k;
|
||||||
|
location ~ ^/index.php {
|
||||||
|
fastcgi_pass php81;
|
||||||
|
include fastcgi_params;
|
||||||
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||||
|
fastcgi_param SERVER_NAME $host;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name
|
||||||
|
some-php74-site.local.wpstudio.ru
|
||||||
|
;
|
||||||
|
root $root;
|
||||||
|
#include global/auth.conf;
|
||||||
|
#@see https://vcs.wpstudio.ru/wpstudio/nginx-examples
|
||||||
|
include includes.d/octobercms.conf;
|
||||||
|
include includes.d/staticfiles.conf;
|
||||||
|
client_max_body_size 300M;
|
||||||
location ~ ^/index.php {
|
location ~ ^/index.php {
|
||||||
fastcgi_pass php74;
|
fastcgi_pass php74;
|
||||||
include fastcgi_params;
|
include fastcgi_params;
|
||||||
|
|||||||
18
config/nginx/conf.d/z-directus.conf.example
Normal file
18
config/nginx/conf.d/z-directus.conf.example
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
map $http_host $directus {
|
||||||
|
directus-mi.local.wpstudio.ru directus-mi;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name
|
||||||
|
directus-mi.local.wpstudio.ru
|
||||||
|
;
|
||||||
|
location / {
|
||||||
|
resolver 127.0.0.11;
|
||||||
|
proxy_pass http://$directus:8055;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_cache_bypass $http_upgrade;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -7,7 +7,7 @@ server {
|
|||||||
try_files $uri $uri/ /index.php?$query_string;
|
try_files $uri $uri/ /index.php?$query_string;
|
||||||
}
|
}
|
||||||
location ~ \.php$ {
|
location ~ \.php$ {
|
||||||
fastcgi_pass fpm74;
|
fastcgi_pass php74;
|
||||||
include fastcgi_params;
|
include fastcgi_params;
|
||||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||||
}
|
}
|
||||||
|
|||||||
23
config/nginx/conf.d/z-nodejs.conf.example
Normal file
23
config/nginx/conf.d/z-nodejs.conf.example
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
map $http_host $pm2 {
|
||||||
|
someprojectone.build.local.wpstudio.ru pm2-someprojectone;
|
||||||
|
someprojecttwo.build.local.wpstudio.ru pm2-someprojecttwo;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name
|
||||||
|
someprojectone.build.local.wpstudio.ru
|
||||||
|
someprojecttwo.build.local.wpstudio.ru
|
||||||
|
;
|
||||||
|
location / {
|
||||||
|
resolver 127.0.0.11;
|
||||||
|
proxy_pass http://$pm2:3000;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_cache_bypass $http_upgrade;
|
||||||
|
proxy_buffer_size 16k;
|
||||||
|
proxy_buffers 8 16k;
|
||||||
|
proxy_busy_buffers_size 32k;
|
||||||
|
}
|
||||||
|
}
|
||||||
14
config/nginx/conf.d/z-pma.conf.example
Normal file
14
config/nginx/conf.d/z-pma.conf.example
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
server {
|
||||||
|
server_name pma.e2e.10ballov.ru;
|
||||||
|
listen 80;
|
||||||
|
include includes.d/auth.conf;
|
||||||
|
client_max_body_size 300M;
|
||||||
|
location / {
|
||||||
|
#resolver 127.0.0.11;
|
||||||
|
proxy_pass http://pma;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_cache_bypass $http_upgrade;
|
||||||
|
}
|
||||||
|
}
|
||||||
32
config/nginx/conf.d/z-python.conf.example
Normal file
32
config/nginx/conf.d/z-python.conf.example
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
map $http_host $python_upstream {
|
||||||
|
someproject.local.wpstudio.ru http://workspace74:8000;
|
||||||
|
}
|
||||||
|
|
||||||
|
map $http_host $python_root {
|
||||||
|
someproject.local.wpstudio.ru /usr/share/nginx/python/someproject;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name
|
||||||
|
someproject.local.wpstudio.ru
|
||||||
|
;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
resolver 127.0.0.11;
|
||||||
|
proxy_pass $python_upstream;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
}
|
||||||
|
|
||||||
|
root $python_root;
|
||||||
|
|
||||||
|
location ~ /media {
|
||||||
|
expires max;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ /static {
|
||||||
|
expires max;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,67 +1,65 @@
|
|||||||
server {
|
server {
|
||||||
server_name
|
server_name
|
||||||
wp-with-file-proxy.local.wpstudio.ru
|
wp-with-file-proxy.local.wpstudio.ru
|
||||||
;
|
;
|
||||||
listen 80;
|
listen 80;
|
||||||
root $root;
|
root $root;
|
||||||
index index.html index.htm index.php;
|
index index.html index.htm index.php;
|
||||||
location / {
|
location / {
|
||||||
try_files $uri $uri/ /index.php?$args;
|
try_files $uri $uri/ /index.php?$args;
|
||||||
}
|
|
||||||
rewrite /wp-admin$ $scheme://$host$uri/ permanent;
|
|
||||||
location ~* ^/wp-content/uploads/.*$ {
|
|
||||||
expires max;
|
|
||||||
proxy_pass $uploads_upstream;
|
|
||||||
}
|
|
||||||
location ~* ^/uploads/.*$ {
|
|
||||||
expires max;
|
|
||||||
proxy_pass $uploads_upstream;
|
|
||||||
}
|
|
||||||
location ~* ^.+\.(ogg|ogv|svg|svgz|eot|otf|woff|mp4|ttf|rss|atom|jpg|jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|tar|mid|midi|wav|bmp|rtf)$ {
|
|
||||||
access_log off;
|
|
||||||
}
|
|
||||||
location ~ [^/]\.php(/|$) {
|
|
||||||
fastcgi_split_path_info ^(.+?\.php)(/.*)$;
|
|
||||||
if (!-f $document_root$fastcgi_script_name) {
|
|
||||||
return 404;
|
|
||||||
}
|
}
|
||||||
include fastcgi_params;
|
rewrite /wp-admin$ $scheme://$host$uri/ permanent;
|
||||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
location ~* ^/wp-content/uploads/.*$ {
|
||||||
fastcgi_param PATH_INFO $fastcgi_path_info;
|
expires max;
|
||||||
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
|
proxy_pass $uploads_upstream;
|
||||||
|
}
|
||||||
|
location ~* ^.+\.(ogg|ogv|svg|svgz|eot|otf|woff|mp4|ttf|rss|atom|jpg|jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|tar|mid|midi|wav|bmp|rtf)$ {
|
||||||
|
access_log off;
|
||||||
|
}
|
||||||
|
location ~ [^/]\.php(/|$) {
|
||||||
|
fastcgi_split_path_info ^(.+?\.php)(/.*)$;
|
||||||
|
if (!-f $document_root$fastcgi_script_name) {
|
||||||
|
return 404;
|
||||||
|
}
|
||||||
|
include fastcgi_params;
|
||||||
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||||
|
fastcgi_param PATH_INFO $fastcgi_path_info;
|
||||||
|
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
|
||||||
|
fastcgi_param SERVER_NAME $host;
|
||||||
|
|
||||||
fastcgi_pass fpm74;
|
fastcgi_pass php74;
|
||||||
fastcgi_index index.php;
|
fastcgi_index index.php;
|
||||||
fastcgi_read_timeout 3000;
|
fastcgi_read_timeout 3000;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
server {
|
server {
|
||||||
server_name
|
server_name
|
||||||
wp.local.wpstudio.ru
|
wp.local.wpstudio.ru
|
||||||
;
|
;
|
||||||
listen 80;
|
listen 80;
|
||||||
root $root;
|
root $root;
|
||||||
index index.html index.htm index.php;
|
index index.html index.htm index.php;
|
||||||
location / {
|
location / {
|
||||||
try_files $uri $uri/ /index.php?$args;
|
try_files $uri $uri/ /index.php?$args;
|
||||||
}
|
|
||||||
rewrite /wp-admin$ $scheme://$host$uri/ permanent;
|
|
||||||
location ~* ^.+\.(ogg|ogv|svg|svgz|eot|otf|woff|mp4|ttf|rss|atom|jpg|jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|tar|mid|midi|wav|bmp|rtf)$ {
|
|
||||||
access_log off;
|
|
||||||
}
|
|
||||||
location ~ [^/]\.php(/|$) {
|
|
||||||
fastcgi_split_path_info ^(.+?\.php)(/.*)$;
|
|
||||||
if (!-f $document_root$fastcgi_script_name) {
|
|
||||||
return 404;
|
|
||||||
}
|
}
|
||||||
include fastcgi_params;
|
rewrite /wp-admin$ $scheme://$host$uri/ permanent;
|
||||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
location ~* ^.+\.(ogg|ogv|svg|svgz|eot|otf|woff|mp4|ttf|rss|atom|jpg|jpeg|gif|png|ico|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|tar|mid|midi|wav|bmp|rtf)$ {
|
||||||
fastcgi_param PATH_INFO $fastcgi_path_info;
|
access_log off;
|
||||||
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
|
}
|
||||||
|
location ~ [^/]\.php(/|$) {
|
||||||
|
fastcgi_split_path_info ^(.+?\.php)(/.*)$;
|
||||||
|
if (!-f $document_root$fastcgi_script_name) {
|
||||||
|
return 404;
|
||||||
|
}
|
||||||
|
include fastcgi_params;
|
||||||
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||||
|
fastcgi_param PATH_INFO $fastcgi_path_info;
|
||||||
|
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
|
||||||
|
fastcgi_param SERVER_NAME $host;
|
||||||
|
|
||||||
fastcgi_pass fpm74;
|
fastcgi_pass php74;
|
||||||
fastcgi_index index.php;
|
fastcgi_index index.php;
|
||||||
fastcgi_read_timeout 3000;
|
fastcgi_read_timeout 3000;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -25,7 +25,7 @@ server {
|
|||||||
if (-f $document_root$fastcgi_script_name){
|
if (-f $document_root$fastcgi_script_name){
|
||||||
set $fsn $fastcgi_script_name;
|
set $fsn $fastcgi_script_name;
|
||||||
}
|
}
|
||||||
fastcgi_pass fpm74;
|
fastcgi_pass php74;
|
||||||
include fastcgi_params;
|
include fastcgi_params;
|
||||||
fastcgi_param SCRIPT_FILENAME $document_root$fsn;
|
fastcgi_param SCRIPT_FILENAME $document_root$fsn;
|
||||||
# PATH_INFO и PATH_TRANSLATED могут быть опущены, но стандарт RFC 3875 определяет для CGI
|
# PATH_INFO и PATH_TRANSLATED могут быть опущены, но стандарт RFC 3875 определяет для CGI
|
||||||
|
|||||||
5
config/nginx/includes.d/auth.conf
Normal file
5
config/nginx/includes.d/auth.conf
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
set $auth_basic Restricted;
|
||||||
|
auth_basic $auth_basic;
|
||||||
|
auth_basic_user_file includes.d/auth.passwd;
|
||||||
|
# Use openssl for generate basic password
|
||||||
|
# echo "MYUSER:$(openssl passwd -apr1 PASSWORD)" > auth.passwd
|
||||||
14
config/nginx/includes.d/https.conf
Normal file
14
config/nginx/includes.d/https.conf
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
error_page 419 = @https;
|
||||||
|
set $is_https "0";
|
||||||
|
if ( $scheme ~* "^https") {
|
||||||
|
set $is_https "${is_https}1";
|
||||||
|
}
|
||||||
|
if ( $request_uri ~* "api/v") {
|
||||||
|
set $is_https "${is_https}1";
|
||||||
|
}
|
||||||
|
if ( $is_https = "0" ) {
|
||||||
|
return 419;
|
||||||
|
}
|
||||||
|
location @https {
|
||||||
|
rewrite ^ https://$http_host$request_uri permanent;
|
||||||
|
}
|
||||||
@ -1,47 +1,56 @@
|
|||||||
|
location / {
|
||||||
|
rewrite ^/.*$ /index.php last;
|
||||||
|
}
|
||||||
|
location ~ ^/combine.*\.(css|js) {
|
||||||
|
rewrite ^/.*$ /index.php last;
|
||||||
|
expires max;
|
||||||
|
}
|
||||||
|
|
||||||
location / {
|
# Whitelist
|
||||||
rewrite ^/.*$ /index.php last;
|
|
||||||
}
|
|
||||||
location ~ ^/combine.*\.(css|js) {
|
|
||||||
rewrite ^/.*$ /index.php last;
|
|
||||||
expires max;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Whitelist
|
## Let October handle if static file not exists
|
||||||
## Let October handle if static file not exists
|
|
||||||
location = /favicon.ico { try_files $uri /index.php; }
|
|
||||||
location ~ ^/.*\.xml { try_files $uri /index.php; }
|
|
||||||
location = /robots.txt { try_files $uri /index.php; }
|
|
||||||
location = /humans.txt { try_files $uri /index.php; }
|
|
||||||
|
|
||||||
## Let nginx return 404 if static file not exists
|
location = /favicon.ico { try_files $uri /index.php; }
|
||||||
location /storage/app/uploads/public { try_files $uri /404; }
|
location ~ ^/.*\.xml { try_files $uri /index.php; }
|
||||||
location /storage/app/media { try_files $uri /404; }
|
location = /robots.txt { try_files $uri /index.php; }
|
||||||
location /storage/app/yml { try_files $uri /404; }
|
location = /humans.txt { try_files $uri /index.php; }
|
||||||
location /storage/app/docx { try_files $uri /404; }
|
|
||||||
location /storage/app/resized { try_files $uri /404; }
|
|
||||||
location /storage/temp/public { try_files $uri /404; }
|
|
||||||
|
|
||||||
location ~ ^/modules/.*/assets { try_files $uri /404; }
|
## Let nginx return 404 if static file not exists
|
||||||
location ~ ^/modules/.*/resources { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/behaviors/.*/assets { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/behaviors/.*/resources { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/widgets/.*/assets { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/widgets/.*/resources { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/formwidgets/.*/assets { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/formwidgets/.*/resources { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/reportwidgets/.*/assets { try_files $uri /404; }
|
|
||||||
location ~ ^/modules/.*/reportwidgets/.*/resources { try_files $uri /404; }
|
|
||||||
|
|
||||||
location ~ ^/plugins/.*/.*/assets { try_files $uri /404; }
|
location /storage/app/uploads/public {
|
||||||
location ~ ^/plugins/.*/.*/resources { try_files $uri /404; }
|
# add proxy cors headers
|
||||||
location ~ ^/plugins/.*/.*/behaviors/.*/assets { try_files $uri /404; }
|
add_header Access-Control-Allow-Headers "*" always;
|
||||||
location ~ ^/plugins/.*/.*/behaviors/.*/resources { try_files $uri /404; }
|
add_header Access-Control-Allow-Methods "*" always;
|
||||||
location ~ ^/plugins/.*/.*/reportwidgets/.*/assets { try_files $uri /404; }
|
add_header Access-Control-Allow-Origin "*" always;
|
||||||
location ~ ^/plugins/.*/.*/reportwidgets/.*/resources { try_files $uri /404; }
|
try_files $uri /404;
|
||||||
location ~ ^/plugins/.*/.*/formwidgets/.*/assets { try_files $uri /404; }
|
}
|
||||||
location ~ ^/plugins/.*/.*/formwidgets/.*/resources { try_files $uri /404; }
|
|
||||||
location ~ ^/plugins/.*/.*/widgets/.*/assets { try_files $uri /404; }
|
|
||||||
location ~ ^/plugins/.*/.*/widgets/.*/resources { try_files $uri /404; }
|
|
||||||
|
|
||||||
location ~ ^/themes/.*/resources { try_files $uri /404; }
|
location /storage/app/media { try_files $uri /404; }
|
||||||
|
location /storage/app/yml { try_files $uri /404; }
|
||||||
|
location /storage/app/docx { try_files $uri /404; }
|
||||||
|
location /storage/app/resized { try_files $uri /404; }
|
||||||
|
location /storage/temp/public { try_files $uri /404; }
|
||||||
|
|
||||||
|
location ~ ^/modules/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/behaviors/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/behaviors/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/widgets/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/widgets/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/formwidgets/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/formwidgets/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/reportwidgets/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/modules/.*/reportwidgets/.*/resources { try_files $uri /404; }
|
||||||
|
|
||||||
|
location ~ ^/plugins/.*/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/behaviors/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/behaviors/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/reportwidgets/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/reportwidgets/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/formwidgets/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/formwidgets/.*/resources { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/widgets/.*/assets { try_files $uri /404; }
|
||||||
|
location ~ ^/plugins/.*/.*/widgets/.*/resources { try_files $uri /404; }
|
||||||
|
|
||||||
|
location ~ ^/themes/.*/resources { try_files $uri /404; }
|
||||||
|
|||||||
@ -11,6 +11,12 @@ location ~* \.jpe?g$ {
|
|||||||
log_not_found off;
|
log_not_found off;
|
||||||
error_page 404 = /empty;
|
error_page 404 = /empty;
|
||||||
}
|
}
|
||||||
|
location ~* \.webp {
|
||||||
|
access_log off;
|
||||||
|
expires max;
|
||||||
|
log_not_found off;
|
||||||
|
error_page 404 = /empty;
|
||||||
|
}
|
||||||
location ~* \.png$ {
|
location ~* \.png$ {
|
||||||
access_log off;
|
access_log off;
|
||||||
expires max;
|
expires max;
|
||||||
|
|||||||
2
config/nginx/ssl.d/.gitignore
vendored
Normal file
2
config/nginx/ssl.d/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
*
|
||||||
|
!.gitignore
|
||||||
3
config/supervisor/.gitignore
vendored
Normal file
3
config/supervisor/.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
*
|
||||||
|
!*.example
|
||||||
|
!.gitignore
|
||||||
9
config/supervisor/uvicorn.conf.example
Normal file
9
config/supervisor/uvicorn.conf.example
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
[fcgi-program:uvicorn]
|
||||||
|
process_name=uvicorn-tourtennis-%(process_num)d
|
||||||
|
socket=tcp://localhost:8000
|
||||||
|
command=/var/python/tourtennis/.venv/bin/uvicorn --fd 0 main:App
|
||||||
|
autostart=true
|
||||||
|
autorestart=true
|
||||||
|
numprocs=1
|
||||||
|
user=laradock
|
||||||
|
redirect_stderr=true
|
||||||
@ -1,8 +1,15 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
DIR="$(realpath $(dirname "$(readlink -f "$0")"))"
|
||||||
|
|
||||||
ln -s ${DIR}/bash/start-xdebug.sh ${HOME}/
|
BASH_SCRIPTS_DIR="${DIR}/bash"
|
||||||
ln -s ${DIR}/bash/quit-xdebug.sh ${HOME}/
|
|
||||||
ln -s ${DIR}/bash/restart-nginx.sh ${HOME}/
|
BASH_SCRIPTS=(`ls $BASH_SCRIPTS_DIR`)
|
||||||
ln -s ${DIR}/bash/mysql.sh ${HOME}/
|
|
||||||
ln -s ${DIR}/bash/enter-to-workspace.sh ${HOME}/
|
for FILENAME in "${BASH_SCRIPTS[@]}"; do
|
||||||
|
BASH_SCRIPT_FILE_PATH="${BASH_SCRIPTS_DIR}/${FILENAME}"
|
||||||
|
SYMLINK_PATH="${HOME}/${FILENAME}"
|
||||||
|
|
||||||
|
if [[ ! -f "${SYMLINK_PATH}" ]]; then
|
||||||
|
ln -s "${BASH_SCRIPT_FILE_PATH}" "${SYMLINK_PATH}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
@ -1,5 +1,3 @@
|
|||||||
version: '3.6'
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
nginx:
|
nginx:
|
||||||
image: nginx
|
image: nginx
|
||||||
@ -8,18 +6,18 @@ services:
|
|||||||
- ${PROJECTS_DIR}:/usr/share/nginx/html
|
- ${PROJECTS_DIR}:/usr/share/nginx/html
|
||||||
- ./config/nginx/conf.d:/etc/nginx/conf.d
|
- ./config/nginx/conf.d:/etc/nginx/conf.d
|
||||||
- ./config/nginx/includes.d:/etc/nginx/includes.d
|
- ./config/nginx/includes.d:/etc/nginx/includes.d
|
||||||
|
- ./config/nginx/ssl.d:/etc/nginx/ssl.d
|
||||||
- ./log/nginx:/var/log/nginx
|
- ./log/nginx:/var/log/nginx
|
||||||
ports:
|
ports:
|
||||||
- "80:80"
|
- "80:80"
|
||||||
- "443:443"
|
- "443:443"
|
||||||
expose:
|
|
||||||
- 80
|
|
||||||
php:
|
php:
|
||||||
build:
|
build:
|
||||||
context: ./dockerfiles/php-fpm
|
context: ./dockerfiles/php-fpm
|
||||||
args:
|
args:
|
||||||
- INSTALL_REDIS=${INSTALL_REDIS}
|
- INSTALL_REDIS=${INSTALL_REDIS}
|
||||||
- INSTALL_PEAR_MAIL=${INSTALL_PEAR_MAIL}
|
- INSTALL_PEAR_MAIL=${INSTALL_PEAR_MAIL}
|
||||||
|
- INSTALL_LIBREOFFICE=${INSTALL_LIBREOFFICE}
|
||||||
- PHP_OPT_SHORT_OPEN_TAG=${PHP_OPT_SHORT_OPEN_TAG}
|
- PHP_OPT_SHORT_OPEN_TAG=${PHP_OPT_SHORT_OPEN_TAG}
|
||||||
- PHP_OPT_MAX_EXECUTION_TIME=${PHP_OPT_MAX_EXECUTION_TIME}
|
- PHP_OPT_MAX_EXECUTION_TIME=${PHP_OPT_MAX_EXECUTION_TIME}
|
||||||
- PHP_OPT_MEMORY_LIMIT=${PHP_OPT_MEMORY_LIMIT}
|
- PHP_OPT_MEMORY_LIMIT=${PHP_OPT_MEMORY_LIMIT}
|
||||||
@ -29,44 +27,43 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- ${PROJECTS_DIR}:/usr/share/nginx/html
|
- ${PROJECTS_DIR}:/usr/share/nginx/html
|
||||||
- ./data/profiler:/tmp/profiler
|
- ./data/profiler:/tmp/profiler
|
||||||
expose:
|
|
||||||
- 9000
|
|
||||||
workspace:
|
workspace:
|
||||||
build:
|
build:
|
||||||
context: ./dockerfiles/workspace
|
context: ./dockerfiles/workspace
|
||||||
args:
|
args:
|
||||||
|
- INSTALL_REDIS=${INSTALL_REDIS}
|
||||||
|
- INSTALL_PEAR_MAIL=${INSTALL_PEAR_MAIL}
|
||||||
|
- INSTALL_LIBREOFFICE=${INSTALL_LIBREOFFICE}
|
||||||
- CUSTOM_PUID=${WORKSPACE_PUID}
|
- CUSTOM_PUID=${WORKSPACE_PUID}
|
||||||
- CUSTOM_PGID=${WORKSPACE_PGID}
|
- CUSTOM_PGID=${WORKSPACE_PGID}
|
||||||
- CUSTOM_TZ=${WORKSPACE_TIMEZONE}
|
- CUSTOM_TZ=${WORKSPACE_TIMEZONE}
|
||||||
- COMPOSER_VERSION=${WORKSPACE_COMPOSER_VERSION}
|
|
||||||
- CUSTOM_NODE_VERSION=${WORKSPACE_CUSTOM_NODE_VERSION}
|
|
||||||
- PHP_OPT_SHORT_OPEN_TAG=${PHP_OPT_SHORT_OPEN_TAG}
|
- PHP_OPT_SHORT_OPEN_TAG=${PHP_OPT_SHORT_OPEN_TAG}
|
||||||
- PHP_OPT_MAX_EXECUTION_TIME=${PHP_OPT_MAX_EXECUTION_TIME}
|
- PHP_OPT_MAX_EXECUTION_TIME=${WORKSPACE_PHP_OPT_MAX_EXECUTION_TIME}
|
||||||
- PHP_OPT_MEMORY_LIMIT=${PHP_OPT_MEMORY_LIMIT}
|
- PHP_OPT_MEMORY_LIMIT=${WORKSPACE_PHP_OPT_MEMORY_LIMIT}
|
||||||
- PHP_OPT_POST_MAX_SIZE=${PHP_OPT_POST_MAX_SIZE}
|
- INSTALL_SUPERVISOR=${WORKSPACE_INSTALL_SUPERVISOR}
|
||||||
- PHP_OPT_UPLOAD_MAX_FILESIZE=${PHP_OPT_UPLOAD_MAX_FILESIZE}
|
- INSTALL_PYTHON=${WORKSPACE_INSTALL_PYTHON}
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${PROJECTS_DIR}:/var/www
|
- ${PROJECTS_DIR}:/var/www
|
||||||
|
- ./config/supervisor:/etc/supervisor/conf.d
|
||||||
extra_hosts:
|
extra_hosts:
|
||||||
- "dockerhost:${DOCKER_HOST_IP}"
|
- "dockerhost:${DOCKER_HOST_IP}"
|
||||||
secrets:
|
secrets:
|
||||||
- user_ssh_key
|
- user_ssh_key
|
||||||
- user_known_hosts
|
- user_known_hosts
|
||||||
- composer_auth
|
- composer_auth
|
||||||
inbucket:
|
|
||||||
image: inbucket/inbucket
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
- "2500:2500"
|
|
||||||
- "9090:9000"
|
|
||||||
db:
|
db:
|
||||||
image: mariadb
|
image: mariadb
|
||||||
restart: always
|
restart: always
|
||||||
environment:
|
environment:
|
||||||
MYSQL_ROOT_PASSWORD: 123456
|
MYSQL_ROOT_PASSWORD: 123456
|
||||||
ports:
|
volumes:
|
||||||
- "3306:3306"
|
- database:/var/lib/mysql
|
||||||
|
- ./hostfiles:/hostfiles
|
||||||
|
- ./log/mariadb:/var/log/mariadb
|
||||||
|
- ./config/mariadb:/etc/mysql/conf.d
|
||||||
|
security_opt:
|
||||||
|
- seccomp=unconfined
|
||||||
pma:
|
pma:
|
||||||
image: phpmyadmin/phpmyadmin
|
image: phpmyadmin/phpmyadmin
|
||||||
restart: always
|
restart: always
|
||||||
@ -74,23 +71,41 @@ services:
|
|||||||
PMA_HOST: db
|
PMA_HOST: db
|
||||||
PMA_USER: root
|
PMA_USER: root
|
||||||
PMA_PASSWORD: 123456
|
PMA_PASSWORD: 123456
|
||||||
ports:
|
inbucket:
|
||||||
- "81:80"
|
image: inbucket/inbucket
|
||||||
|
restart: always
|
||||||
|
expose:
|
||||||
|
- 2500
|
||||||
redis:
|
redis:
|
||||||
image: redis
|
image: redis
|
||||||
restart: always
|
restart: always
|
||||||
command: [ "redis-server", "/usr/local/etc/redis/redis.conf" ]
|
command: [ "redis-server", "/usr/local/etc/redis/redis.conf" ]
|
||||||
volumes:
|
volumes:
|
||||||
- ./config/redis/redis.conf:/usr/local/etc/redis/redis.conf
|
- ./config/redis/redis.conf:/usr/local/etc/redis/redis.conf
|
||||||
|
elastic:
|
||||||
# Must be copied into main docker-compose yml-file
|
build:
|
||||||
volumes:
|
context: ./dockerfiles/elastic
|
||||||
database:
|
restart: on-failure
|
||||||
|
environment:
|
||||||
secrets:
|
- discovery.type=single-node
|
||||||
user_ssh_key:
|
- "ES_JAVA_OPTS=-Xms512m -Xmx512m"
|
||||||
file: ~/.ssh/id_rsa
|
ulimits:
|
||||||
user_known_hosts:
|
memlock:
|
||||||
file: ~/.ssh/known_hosts
|
soft: -1
|
||||||
composer_auth:
|
hard: -1
|
||||||
file: ~/.config/composer/auth.json
|
expose:
|
||||||
|
- "9200"
|
||||||
|
- "9300"
|
||||||
|
minio:
|
||||||
|
image: minio/minio:RELEASE.2020-06-12T00-06-19Z
|
||||||
|
restart: always
|
||||||
|
environment:
|
||||||
|
MINIO_ACCESS_KEY: ${MINIO_ACCESS_KEY}
|
||||||
|
MINIO_SECRET_KEY: ${MINIO_SECRET_KEY}
|
||||||
|
command: server /minio
|
||||||
|
pm2:
|
||||||
|
build:
|
||||||
|
context: ./dockerfiles/pm2
|
||||||
|
restart: always
|
||||||
|
expose:
|
||||||
|
- 3000
|
||||||
42
docker-compose.directus.yml.example
Normal file
42
docker-compose.directus.yml.example
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
services:
|
||||||
|
directus-mi:
|
||||||
|
image: directus/directus:11.1.0
|
||||||
|
ports:
|
||||||
|
- 8055:8055
|
||||||
|
volumes:
|
||||||
|
- ./data/directus/mi/uploads:/directus/uploads
|
||||||
|
- ./data/directus/mi/extensions:/directus/extensions
|
||||||
|
depends_on:
|
||||||
|
- db
|
||||||
|
- redis-mi
|
||||||
|
environment:
|
||||||
|
KEY: ""
|
||||||
|
SECRET: ""
|
||||||
|
|
||||||
|
DB_CLIENT: "mysql"
|
||||||
|
DB_HOST: "db"
|
||||||
|
DB_PORT: "3306"
|
||||||
|
DB_DATABASE: "directus"
|
||||||
|
DB_USER: "directus"
|
||||||
|
DB_PASSWORD: "directus"
|
||||||
|
|
||||||
|
CACHE_ENABLED: "true"
|
||||||
|
CACHE_AUTO_PURGE: "true"
|
||||||
|
CACHE_STORE: "redis"
|
||||||
|
REDIS: "redis://redis-mi:6379"
|
||||||
|
|
||||||
|
CACHE_TTL: 1d
|
||||||
|
|
||||||
|
ADMIN_EMAIL: "info@wpstudio.ru"
|
||||||
|
ADMIN_PASSWORD: ""
|
||||||
|
|
||||||
|
TELEMETRY: false
|
||||||
|
ACCESS_TOKEN_TTL: 15m
|
||||||
|
REFRESH_TOKEN_TTL: 7d
|
||||||
|
LOG_LEVEL: debug
|
||||||
|
FLOWS_EXEC_ALLOWED_MODULES: "array:@elastic/elasticsearch"
|
||||||
|
WEBSOCKETS_ENABLED: true
|
||||||
|
|
||||||
|
# Make sure to set this in production
|
||||||
|
# (see https://docs.directus.io/self-hosted/config-options#general)
|
||||||
|
# PUBLIC_URL: "https://directus.example.com"
|
||||||
10
docker-compose.e2e.yml.example
Executable file
10
docker-compose.e2e.yml.example
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
services:
|
||||||
|
browserless:
|
||||||
|
image: browserless/chrome:latest
|
||||||
|
environment:
|
||||||
|
- HOST=0.0.0.0
|
||||||
|
- PORT=3000
|
||||||
|
container_name: "browserless"
|
||||||
|
restart: always
|
||||||
|
ports:
|
||||||
|
- "3000:3000"
|
||||||
@ -1,18 +0,0 @@
|
|||||||
version: '3.6'
|
|
||||||
|
|
||||||
services:
|
|
||||||
elastic:
|
|
||||||
build:
|
|
||||||
context: ./dockerfiles/elastic
|
|
||||||
restart: on-failure
|
|
||||||
environment:
|
|
||||||
- discovery.type=single-node
|
|
||||||
- "ES_JAVA_OPTS=-Xms512m -Xmx512m"
|
|
||||||
ulimits:
|
|
||||||
memlock:
|
|
||||||
soft: -1
|
|
||||||
hard: -1
|
|
||||||
mem_limit: 2g
|
|
||||||
expose:
|
|
||||||
- "9200"
|
|
||||||
- "9300"
|
|
||||||
@ -1,23 +1,15 @@
|
|||||||
version: '3.6'
|
version: '3.6'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
elastic732:
|
elastic:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.elastic.base.yml
|
file: docker-compose.base.yml
|
||||||
service: elastic
|
|
||||||
build:
|
|
||||||
dockerfile: elastic732.Dockerfile
|
|
||||||
volumes:
|
|
||||||
- elastic732:/usr/share/elastic/data
|
|
||||||
elastic752:
|
|
||||||
extends:
|
|
||||||
file: docker-compose.elastic.base.yml
|
|
||||||
service: elastic
|
service: elastic
|
||||||
|
restart: always
|
||||||
build:
|
build:
|
||||||
dockerfile: elastic752.Dockerfile
|
dockerfile: elastic752.Dockerfile
|
||||||
volumes:
|
volumes:
|
||||||
- elastic752:/usr/share/elastic/data
|
- elastic:/usr/share/elastic/data
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
elastic732:
|
elastic:
|
||||||
elastic752:
|
|
||||||
|
|||||||
@ -1,10 +0,0 @@
|
|||||||
version: '3.6'
|
|
||||||
|
|
||||||
services:
|
|
||||||
minio:
|
|
||||||
image: minio/minio:RELEASE.2020-06-12T00-06-19Z
|
|
||||||
restart: always
|
|
||||||
environment:
|
|
||||||
MINIO_ACCESS_KEY: ${MINIO_ACCESS_KEY}
|
|
||||||
MINIO_SECRET_KEY: ${MINIO_SECRET_KEY}
|
|
||||||
command: server /minio
|
|
||||||
@ -3,7 +3,7 @@ version: '3.6'
|
|||||||
services:
|
services:
|
||||||
minio:
|
minio:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.minio.base.yml
|
file: docker-compose.base.yml
|
||||||
service: minio
|
service: minio
|
||||||
volumes:
|
volumes:
|
||||||
- minio:/minio
|
- minio:/minio
|
||||||
|
|||||||
12
docker-compose.minio.yml.example
Executable file
12
docker-compose.minio.yml.example
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
version: '3.6'
|
||||||
|
|
||||||
|
services:
|
||||||
|
minio:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: minio
|
||||||
|
volumes:
|
||||||
|
- minio:/minio
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
minio:
|
||||||
15
docker-compose.nodejs.yml.example
Executable file
15
docker-compose.nodejs.yml.example
Executable file
@ -0,0 +1,15 @@
|
|||||||
|
version: '3.6'
|
||||||
|
|
||||||
|
services:
|
||||||
|
pm2-someprojectone:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: pm2
|
||||||
|
volumes:
|
||||||
|
- ${PROJECTS_DIR}/someprojectone/.output:/.output
|
||||||
|
pm2-someprojecttwo:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: pm2
|
||||||
|
volumes:
|
||||||
|
- ${PROJECTS_DIR}/someprojecttwo/.output:/.output
|
||||||
@ -9,11 +9,13 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- databasepg:/var/lib/postgresql/data
|
- databasepg:/var/lib/postgresql/data
|
||||||
- ./hostfiles:/hostfiles
|
- ./hostfiles:/hostfiles
|
||||||
|
ports:
|
||||||
|
- "5432:5432"
|
||||||
adminer:
|
adminer:
|
||||||
image: adminer
|
image: adminer
|
||||||
restart: always
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 8080:8080
|
- 8081:8080
|
||||||
pgadmin:
|
pgadmin:
|
||||||
image: dpage/pgadmin4
|
image: dpage/pgadmin4
|
||||||
restart: always
|
restart: always
|
||||||
29
docker-compose.redis-ui.yml.example
Executable file
29
docker-compose.redis-ui.yml.example
Executable file
@ -0,0 +1,29 @@
|
|||||||
|
version: '3.6'
|
||||||
|
|
||||||
|
services:
|
||||||
|
redis-ui:
|
||||||
|
image: marian/rebrow
|
||||||
|
restart: always
|
||||||
|
ports:
|
||||||
|
- "5001:5001"
|
||||||
|
links:
|
||||||
|
- redis-example:redis-example
|
||||||
|
redis-stack:
|
||||||
|
image: redis/redis-stack:latest
|
||||||
|
restart: always
|
||||||
|
ports:
|
||||||
|
- "8001:8001"
|
||||||
|
expose:
|
||||||
|
- 6379
|
||||||
|
redis-commander:
|
||||||
|
container_name: redis-commander
|
||||||
|
hostname: redis-commander
|
||||||
|
image: ghcr.io/joeferner/redis-commander:latest
|
||||||
|
restart: always
|
||||||
|
environment:
|
||||||
|
- REDIS_HOSTS=intai:redis-intai:6379
|
||||||
|
ports:
|
||||||
|
- "8081:8081"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
elastic:
|
||||||
11
docker-compose.redis.yml.example
Executable file
11
docker-compose.redis.yml.example
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
version: '3.6'
|
||||||
|
|
||||||
|
services:
|
||||||
|
redis-someprojectone:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: redis
|
||||||
|
redis-someprojecttwo:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: redis
|
||||||
@ -1,5 +1,3 @@
|
|||||||
version: '3.9'
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
nginx:
|
nginx:
|
||||||
extends:
|
extends:
|
||||||
@ -8,54 +6,71 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
default:
|
default:
|
||||||
aliases:
|
aliases:
|
||||||
- loc.yoursite.ru
|
- someproject.local.wpstudio.ru
|
||||||
php73:
|
depends_on:
|
||||||
extends:
|
- php74
|
||||||
file: docker-compose.base.yml
|
- php81
|
||||||
service: php
|
|
||||||
build:
|
|
||||||
dockerfile: php73.Dockerfile
|
|
||||||
php74:
|
php74:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: php
|
service: php
|
||||||
build:
|
build:
|
||||||
dockerfile: php74.Dockerfile
|
dockerfile: php74.Dockerfile
|
||||||
workspace73:
|
php81:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: workspace
|
service: php
|
||||||
build:
|
build:
|
||||||
dockerfile: workspace73.Dockerfile
|
dockerfile: php81.Dockerfile
|
||||||
|
php82:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: php
|
||||||
|
build:
|
||||||
|
dockerfile: php82.Dockerfile
|
||||||
|
volumes:
|
||||||
workspace74:
|
workspace74:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: workspace
|
service: workspace
|
||||||
build:
|
build:
|
||||||
dockerfile: workspace74.Dockerfile
|
dockerfile: workspace74.Dockerfile
|
||||||
inbucket:
|
workspace81:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: inbucket
|
service: workspace
|
||||||
|
build:
|
||||||
|
dockerfile: workspace81.Dockerfile
|
||||||
|
workspace82:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: workspace
|
||||||
|
build:
|
||||||
|
dockerfile: workspace82.Dockerfile
|
||||||
db:
|
db:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: db
|
service: db
|
||||||
volumes:
|
|
||||||
- database:/var/lib/mysql
|
|
||||||
- ./hostfiles:/hostfiles
|
|
||||||
pma:
|
pma:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: pma
|
service: pma
|
||||||
redis:
|
ports:
|
||||||
|
- "81:80"
|
||||||
|
inbucket:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: redis
|
service: inbucket
|
||||||
redis-some:
|
ports:
|
||||||
extends:
|
- "82:9000"
|
||||||
file: docker-compose.base.yml
|
dnsmasq:
|
||||||
service: redis
|
restart: always
|
||||||
|
build:
|
||||||
|
context: ./dockerfiles/dnsmasq
|
||||||
|
volumes:
|
||||||
|
- ./config/dnsmasq/dnsmasq.conf:/etc/dnsmasq.conf
|
||||||
|
cap_add:
|
||||||
|
- NET_ADMIN # @see https://man7.org/linux/man-pages/man7/capabilities.7.html
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
database:
|
database:
|
||||||
|
|||||||
9
dockerfiles/dnsmasq/Dockerfile
Normal file
9
dockerfiles/dnsmasq/Dockerfile
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
|
# @see https://github.com/mcmar/docker-dnsmasq
|
||||||
|
|
||||||
|
RUN apk --no-cache add dnsmasq
|
||||||
|
|
||||||
|
EXPOSE 53/tcp 53/udp 67/udp
|
||||||
|
|
||||||
|
CMD ["dnsmasq", "-k"]
|
||||||
@ -1 +0,0 @@
|
|||||||
RUN elasticsearch-plugin install analysis-icu
|
|
||||||
@ -1,5 +1,3 @@
|
|||||||
# syntax = edrevo/dockerfile-plus
|
|
||||||
FROM docker.elastic.co/elasticsearch/elasticsearch:7.3.2
|
FROM docker.elastic.co/elasticsearch/elasticsearch:7.3.2
|
||||||
|
|
||||||
#INCLUDE+ ./elastic.base.Dockerfile
|
|
||||||
RUN elasticsearch-plugin install analysis-icu
|
RUN elasticsearch-plugin install analysis-icu
|
||||||
|
|||||||
@ -1,5 +1,7 @@
|
|||||||
# syntax = edrevo/dockerfile-plus
|
FROM elasticsearch:7.5.2
|
||||||
FROM docker.elastic.co/elasticsearch/elasticsearch:7.5.2
|
|
||||||
|
|
||||||
#INCLUDE+ ./elastic.base.Dockerfile
|
COPY ./plugins /plugins
|
||||||
RUN elasticsearch-plugin install analysis-icu
|
|
||||||
|
RUN elasticsearch-plugin install file:///plugins/analysis-icu-7.5.2.zip
|
||||||
|
|
||||||
|
RUN rm -rf /plugins
|
||||||
|
|||||||
BIN
dockerfiles/elastic/plugins/analysis-icu-7.5.2.zip
Normal file
BIN
dockerfiles/elastic/plugins/analysis-icu-7.5.2.zip
Normal file
Binary file not shown.
43
dockerfiles/php-fpm/php56.Dockerfile
Normal file
43
dockerfiles/php-fpm/php56.Dockerfile
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
FROM dimti/php:5.6
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Pear Mail and Mail_Mime:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_PEAR_MAIL=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_PEAR_MAIL} = true ]; then \
|
||||||
|
pear install Mail && pear install Mail_Mime \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# xDebug (termporary):
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
# Copy xdebug configuration for remote debugging
|
||||||
|
COPY ./xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Permission denied on /tmp folder:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
RUN chmod 1777 /tmp
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Tune opts:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG PHP_OPT_SHORT_OPEN_TAG=Off
|
||||||
|
RUN sed -i "s/^short_open_tag = .*/short_open_tag = $PHP_OPT_SHORT_OPEN_TAG/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_MAX_EXECUTION_TIME=600
|
||||||
|
RUN sed -i "s/^max_execution_time = .*/max_execution_time = $PHP_OPT_MAX_EXECUTION_TIME/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_MEMORY_LIMIT=256M
|
||||||
|
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_POST_MAX_SIZE=48M
|
||||||
|
RUN sed -i "s/^post_max_size = .*/post_max_size = $PHP_OPT_POST_MAX_SIZE/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
||||||
|
RUN sed -i "s/^upload_max_filesize = .*/upload_max_filesize = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" "$PHP_INI_DIR/php.ini"
|
||||||
@ -30,7 +30,17 @@ RUN if [ ${INSTALL_PEAR_MAIL} = true ]; then \
|
|||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
# Copy xdebug configuration for remote debugging
|
# Copy xdebug configuration for remote debugging
|
||||||
COPY ./xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
|
COPY ./xdebug2/xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# НУЦ:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
RUN mkdir /usr/local/share/ca-certificates/extra && \
|
||||||
|
cd /usr/local/share/ca-certificates/extra && \
|
||||||
|
curl -O https://gu-st.ru/content/lending/russian_trusted_root_ca_pem.crt && \
|
||||||
|
curl -O https://gu-st.ru/content/lending/russian_trusted_sub_ca_pem.crt && \
|
||||||
|
update-ca-certificates
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Tune opts:
|
# Tune opts:
|
||||||
|
|||||||
66
dockerfiles/php-fpm/php81.Dockerfile
Normal file
66
dockerfiles/php-fpm/php81.Dockerfile
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
FROM dimti/php:8.1
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Redis and igbinary:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_REDIS=false
|
||||||
|
|
||||||
|
COPY ./igbinary.ini /usr/local/etc/php/conf.d/igbinary.ini
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_REDIS} = true ]; then \
|
||||||
|
pecl install -a igbinary \
|
||||||
|
&& docker-php-ext-enable igbinary \
|
||||||
|
&& printf "yes\n" | pecl install redis \
|
||||||
|
&& docker-php-ext-enable redis \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Pear Mail and Mail_Mime:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_PEAR_MAIL=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_PEAR_MAIL} = true ]; then \
|
||||||
|
pear install Mail && pear install Mail_Mime \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# xDebug (termporary):
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
# Copy xdebug configuration for remote debugging
|
||||||
|
COPY ./xdebug3/xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Libreoffice
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_LIBREOFFICE=false
|
||||||
|
|
||||||
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_LIBREOFFICE} = true ]; then \
|
||||||
|
apt-get update \
|
||||||
|
&& apt-get install -y libreoffice-nogui --no-install-recommends \
|
||||||
|
&& apt-get clean \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Tune opts:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG PHP_OPT_SHORT_OPEN_TAG=Off
|
||||||
|
RUN sed -i "s/^short_open_tag = .*/short_open_tag = $PHP_OPT_SHORT_OPEN_TAG/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_MAX_EXECUTION_TIME=600
|
||||||
|
RUN sed -i "s/^max_execution_time = .*/max_execution_time = $PHP_OPT_MAX_EXECUTION_TIME/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_MEMORY_LIMIT=256M
|
||||||
|
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_POST_MAX_SIZE=48M
|
||||||
|
RUN sed -i "s/^post_max_size = .*/post_max_size = $PHP_OPT_POST_MAX_SIZE/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
||||||
|
RUN sed -i "s/^upload_max_filesize = .*/upload_max_filesize = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" "$PHP_INI_DIR/php.ini"
|
||||||
@ -1,4 +1,4 @@
|
|||||||
FROM dimti/php:7.3
|
FROM dimti/php:8.2
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Redis and igbinary:
|
# Redis and igbinary:
|
||||||
@ -30,13 +30,7 @@ RUN if [ ${INSTALL_PEAR_MAIL} = true ]; then \
|
|||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
# Copy xdebug configuration for remote debugging
|
# Copy xdebug configuration for remote debugging
|
||||||
COPY ./xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
|
COPY ./xdebug3/xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Permission denied on /tmp folder:
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
RUN chmod 1777 /tmp
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Tune opts:
|
# Tune opts:
|
||||||
@ -56,3 +50,9 @@ RUN sed -i "s/^post_max_size = .*/post_max_size = $PHP_OPT_POST_MAX_SIZE/g" "$PH
|
|||||||
|
|
||||||
ARG PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
ARG PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
||||||
RUN sed -i "s/^upload_max_filesize = .*/upload_max_filesize = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" "$PHP_INI_DIR/php.ini"
|
RUN sed -i "s/^upload_max_filesize = .*/upload_max_filesize = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Libreoffice:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install -y libreoffice-nogui --no-install-recommends && apt-get clean
|
||||||
@ -27,7 +27,7 @@ xdebug_status ()
|
|||||||
|
|
||||||
xdebug_start ()
|
xdebug_start ()
|
||||||
{
|
{
|
||||||
echo 'Start xDebug'
|
echo 'Start xDebug2'
|
||||||
|
|
||||||
# And uncomment line with xdebug extension, thus enabling it
|
# And uncomment line with xdebug extension, thus enabling it
|
||||||
ON_CMD="sed -i 's/^;zend_extension=/zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini"
|
ON_CMD="sed -i 's/^;zend_extension=/zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini"
|
||||||
@ -48,7 +48,7 @@ xdebug_start ()
|
|||||||
|
|
||||||
xdebug_stop ()
|
xdebug_stop ()
|
||||||
{
|
{
|
||||||
echo 'Stop xDebug'
|
echo 'Stop xDebug2'
|
||||||
|
|
||||||
# Comment out xdebug extension line
|
# Comment out xdebug extension line
|
||||||
OFF_CMD="sed -i 's/^zend_extension=/;zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini"
|
OFF_CMD="sed -i 's/^zend_extension=/;zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini"
|
||||||
4
dockerfiles/php-fpm/xdebug3/xdebug.ini
Normal file
4
dockerfiles/php-fpm/xdebug3/xdebug.ini
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
xdebug.mode=off
|
||||||
|
xdebug.discover_client_host=1
|
||||||
|
xdebug.start_with_request=yes
|
||||||
|
xdebug.output_dir=/tmp/profiler
|
||||||
84
dockerfiles/php-fpm/xdebug3/xdebug.sh
Executable file
84
dockerfiles/php-fpm/xdebug3/xdebug.sh
Executable file
@ -0,0 +1,84 @@
|
|||||||
|
#! /bin/bash
|
||||||
|
|
||||||
|
# NOTE: At the moment, this has only been confirmed to work with PHP 7
|
||||||
|
|
||||||
|
PHP_VERSION=$2 # Without dot
|
||||||
|
WITH_PROFILER=$3
|
||||||
|
|
||||||
|
# Grab full name of php-fpm container
|
||||||
|
PHP_FPM_CONTAINER=$(docker ps | grep php${PHP_VERSION} | awk '{print $1}')
|
||||||
|
|
||||||
|
if [[ -z "${PHP_FPM_CONTAINER}" ]]; then
|
||||||
|
echo "Unable to find php fpm container: php${PHP_VERSION}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -z "${WITH_PROFILER}" ]]; then
|
||||||
|
echo "With profiler option".
|
||||||
|
fi
|
||||||
|
|
||||||
|
xdebug_status ()
|
||||||
|
{
|
||||||
|
echo 'xDebug status'
|
||||||
|
|
||||||
|
docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v'
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xdebug_start ()
|
||||||
|
{
|
||||||
|
echo 'Start xDebug3'
|
||||||
|
|
||||||
|
# And uncomment line with xdebug extension, thus enabling it
|
||||||
|
ON_CMD="sed -i 's/^;zend_extension=/zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini"
|
||||||
|
|
||||||
|
if [[ -n "${WITH_PROFILER}" ]]; then
|
||||||
|
XDEBUG_MODE='profile'
|
||||||
|
else
|
||||||
|
XDEBUG_MODE='debug'
|
||||||
|
fi
|
||||||
|
|
||||||
|
MODE_DEBUG_CMD="sed -i 's/^xdebug.mode.*/xdebug.mode=${XDEBUG_MODE}/g' /usr/local/etc/php/conf.d/xdebug.ini"
|
||||||
|
|
||||||
|
docker exec -it $PHP_FPM_CONTAINER bash -c "${ON_CMD}"
|
||||||
|
docker exec -it $PHP_FPM_CONTAINER bash -c "${MODE_DEBUG_CMD}"
|
||||||
|
docker restart $PHP_FPM_CONTAINER
|
||||||
|
docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v'
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xdebug_stop ()
|
||||||
|
{
|
||||||
|
echo 'Stop xDebug3'
|
||||||
|
|
||||||
|
# Comment out xdebug extension line
|
||||||
|
OFF_CMD="sed -i 's/^zend_extension=/;zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini"
|
||||||
|
MODE_OFF_CMD="sed -i 's/^xdebug.mode.*/xdebug.mode=off/g' /usr/local/etc/php/conf.d/xdebug.ini"
|
||||||
|
|
||||||
|
docker exec -it $PHP_FPM_CONTAINER bash -c "${OFF_CMD}"
|
||||||
|
docker exec -it $PHP_FPM_CONTAINER bash -c "${MODE_OFF_CMD}"
|
||||||
|
# docker-compose restart php-fpm
|
||||||
|
docker restart $PHP_FPM_CONTAINER
|
||||||
|
docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v'
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
stop|STOP)
|
||||||
|
xdebug_stop
|
||||||
|
;;
|
||||||
|
start|START)
|
||||||
|
xdebug_start
|
||||||
|
;;
|
||||||
|
status|STATUS)
|
||||||
|
xdebug_status
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "xDebug [Stop | Start | Status] in the ${PHP_FPM_CONTAINER} container."
|
||||||
|
echo "xDebug must have already been installed."
|
||||||
|
echo "Usage:"
|
||||||
|
echo " .php-fpm/xdebug.sh 73|74 stop|start|status"
|
||||||
|
|
||||||
|
esac
|
||||||
|
|
||||||
|
exit 1
|
||||||
5
dockerfiles/pm2/Dockerfile
Normal file
5
dockerfiles/pm2/Dockerfile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FROM keymetrics/pm2:18-buster
|
||||||
|
|
||||||
|
COPY ./ecosystem.config.js /ecosystem.config.js
|
||||||
|
|
||||||
|
CMD ["pm2-runtime", "start", "ecosystem.config.js"]
|
||||||
11
dockerfiles/pm2/ecosystem.config.js
Normal file
11
dockerfiles/pm2/ecosystem.config.js
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
module.exports = {
|
||||||
|
apps: [
|
||||||
|
{
|
||||||
|
name: 'NuxtAppName',
|
||||||
|
port: '3000',
|
||||||
|
exec_mode: 'cluster',
|
||||||
|
instances: '2',
|
||||||
|
script: './.output/server/index.mjs',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
};
|
||||||
6
dockerfiles/workspace/.bash_aliases.example
Normal file
6
dockerfiles/workspace/.bash_aliases.example
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
alias gst='git status'
|
||||||
|
alias ga='git add'
|
||||||
|
alias gc='git commit -m'
|
||||||
|
alias gush='git push'
|
||||||
|
alias gull='git pull'
|
||||||
|
alias gb='git branch'
|
||||||
4
dockerfiles/workspace/.gitignore
vendored
4
dockerfiles/workspace/.gitignore
vendored
@ -1 +1,3 @@
|
|||||||
/aliases.sh
|
/.bash_*
|
||||||
|
!/.bash_.example
|
||||||
|
/crontab
|
||||||
|
|||||||
@ -1,30 +0,0 @@
|
|||||||
#! /bin/bash
|
|
||||||
|
|
||||||
# Colors used for status updates
|
|
||||||
ESC_SEQ="\x1b["
|
|
||||||
COL_RESET=$ESC_SEQ"39;49;00m"
|
|
||||||
COL_RED=$ESC_SEQ"31;01m"
|
|
||||||
COL_GREEN=$ESC_SEQ"32;01m"
|
|
||||||
COL_YELLOW=$ESC_SEQ"33;01m"
|
|
||||||
COL_BLUE=$ESC_SEQ"34;01m"
|
|
||||||
COL_MAGENTA=$ESC_SEQ"35;01m"
|
|
||||||
COL_CYAN=$ESC_SEQ"36;01m"
|
|
||||||
|
|
||||||
# Detect which `ls` flavor is in use
|
|
||||||
if ls --color > /dev/null 2>&1; then # GNU `ls`
|
|
||||||
colorflag="--color"
|
|
||||||
export LS_COLORS='no=00:fi=00:di=01;31:ln=01;36:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.avi=01;35:*.fli=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.ogg=01;35:*.mp3=01;35:*.wav=01;35:'
|
|
||||||
else # macOS `ls`
|
|
||||||
colorflag="-G"
|
|
||||||
export LSCOLORS='BxBxhxDxfxhxhxhxhxcxcx'
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Always use color output for `ls`
|
|
||||||
alias ls="command ls ${colorflag}"
|
|
||||||
|
|
||||||
alias gst='git status'
|
|
||||||
alias ga='git add'
|
|
||||||
alias gc='git commit -m'
|
|
||||||
alias gush='git push'
|
|
||||||
alias gull='git pull'
|
|
||||||
alias gb='git branch'
|
|
||||||
@ -1 +0,0 @@
|
|||||||
#* * * * * laradock /usr/bin/php /var/www/artisan schedule:run >> /dev/null 2>&1
|
|
||||||
@ -34,14 +34,12 @@ RUN pecl install -a redis
|
|||||||
RUN echo "extension=redis.so" > /etc/php/${PHP_VERSION}/cli/conf.d/20-redis.ini
|
RUN echo "extension=redis.so" > /etc/php/${PHP_VERSION}/cli/conf.d/20-redis.ini
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Update composer version
|
# S3 config
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
USER root
|
USER laradock
|
||||||
|
|
||||||
ARG COMPOSER_VERSION=2
|
COPY ./minio/auth.json /home/laradock/.mc/config.json
|
||||||
ENV COMPOSER_VERSION ${COMPOSER_VERSION}
|
|
||||||
RUN composer self-update --${COMPOSER_VERSION}
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Install custom node version
|
# Install custom node version
|
||||||
@ -49,43 +47,96 @@ RUN composer self-update --${COMPOSER_VERSION}
|
|||||||
|
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
ARG CUSTOM_NODE_VERSION
|
ARG NODE_VERSION
|
||||||
ENV CUSTOM_NODE_VERSION ${CUSTOM_NODE_VERSION}
|
ENV NODE_VERSION ${NODE_VERSION}
|
||||||
|
|
||||||
RUN if [ ! -z "${CUSTOM_NODE_VERSION}" ]; then \
|
RUN if [ ! -z "${NODE_VERSION}" ]; then \
|
||||||
. ~/.bashrc && nvm install ${CUSTOM_NODE_VERSION} \
|
. ~/.bashrc && nvm install ${NODE_VERSION} \
|
||||||
&& . ~/.bashrc && nvm alias default ${CUSTOM_NODE_VERSION} \
|
&& . ~/.bashrc && nvm alias default ${NODE_VERSION} \
|
||||||
|
&& npm i -g yarn \
|
||||||
&& cp -R ~/.nvm/alias /home/laradock/.nvm \
|
&& cp -R ~/.nvm/alias /home/laradock/.nvm \
|
||||||
&& cp -R ~/.nvm/versions /home/laradock/.nvm \
|
&& cp -R ~/.nvm/versions /home/laradock/.nvm \
|
||||||
&& chown -R ${CUSTOM_PUID}:${CUSTOM_PGID} /home/laradock/.nvm \
|
&& chown -R ${CUSTOM_PUID}:${CUSTOM_PGID} /home/laradock/.nvm \
|
||||||
;fi
|
;fi
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Remove DST_Root_CA3
|
# Update composer version
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
RUN sed -i 's/^mozilla\/DST_Root_CA_X3\.crt/!mozilla\/DST_Root_CA_X3.crt/g' /etc/ca-certificates.conf && update-ca-certificates
|
USER root
|
||||||
|
|
||||||
|
ARG COMPOSER_VERSION=1
|
||||||
|
ENV COMPOSER_VERSION ${COMPOSER_VERSION}
|
||||||
|
RUN composer self-update # Need for correctly update to actual old branch
|
||||||
|
RUN composer self-update --${COMPOSER_VERSION}
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Laradock Aliases
|
# YADM
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
|
# once please
|
||||||
|
RUN apt update
|
||||||
|
|
||||||
|
RUN apt install -y direnv yadm
|
||||||
|
RUN curl -sS https://starship.rs/install.sh | sh -s -- -f
|
||||||
|
|
||||||
USER laradock
|
USER laradock
|
||||||
|
|
||||||
COPY ./aliases.sh /home/laradock/aliases.sh
|
RUN yadm clone --bootstrap https://vcs.wpstudio.ru/gitea/dotfiles.git
|
||||||
|
|
||||||
RUN echo "" >> ~/.bashrc && \
|
RUN sed -i 's/#/\\$/g' ${HOME}/.config/starship.toml
|
||||||
echo "# Load Custom Aliases" >> ~/.bashrc && \
|
|
||||||
echo "source ~/aliases.sh" >> ~/.bashrc && \
|
|
||||||
echo "" >> ~/.bashrc
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# S3 config
|
# SUPERVISOR:
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
ARG INSTALL_SUPERVISOR=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_SUPERVISOR} = true ]; then \
|
||||||
|
apt install -y supervisor \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
RUN apt install -y liblzma-dev libbz2-dev libffi-dev libreadline-dev
|
||||||
|
|
||||||
USER laradock
|
USER laradock
|
||||||
|
|
||||||
COPY ./minio/auth.json /home/laradock/.mc/config.json
|
RUN curl https://pyenv.run | bash
|
||||||
|
|
||||||
|
RUN echo '' >> ~/.shell-env.local && \
|
||||||
|
echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.shell-env.local && \
|
||||||
|
echo '[[ -d $PYENV_ROOT/bin ]] && export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.shell-env.local && \
|
||||||
|
echo 'eval "$(pyenv init -)"' >> ~/.shell-env.local && \
|
||||||
|
echo '' >> ~/.shell-env.local && \
|
||||||
|
echo 'eval "$(pyenv virtualenv-init -)"' >> ~/.shell-env.local && \
|
||||||
|
echo '' >> ~/.shell-env.local
|
||||||
|
|
||||||
|
RUN $HOME/.pyenv/bin/pyenv install 3.9
|
||||||
|
|
||||||
|
ARG INSTALL_PYTHON=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_PYTHON} = true ]; then \
|
||||||
|
export PYENV_VERSION=3.9 && \
|
||||||
|
python -m pip install uvicorn \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
RUN if [ false = true ]; then \
|
||||||
|
export PYENV_VERSION=3.9 && \
|
||||||
|
python -m pip install uvicorn && \
|
||||||
|
python -m pip install --upgrade supervisor && \
|
||||||
|
echo_supervisord_conf > /etc/supervisord.conf && \
|
||||||
|
sed -i 's/\;\[include\]/\[include\]/g' /etc/supervisord.conf && \
|
||||||
|
sed -i 's/\;files\s.*/files = supervisord.d\/*.conf/g' /etc/supervisord.conf \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
RUN apt install -y htop
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Tune opts:
|
# Tune opts:
|
||||||
@ -102,18 +153,19 @@ RUN sed -i "s/^max_execution_time = .*/max_execution_time = $PHP_OPT_MAX_EXECUTI
|
|||||||
ARG PHP_OPT_MEMORY_LIMIT=256M
|
ARG PHP_OPT_MEMORY_LIMIT=256M
|
||||||
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
||||||
|
|
||||||
ARG PHP_OPT_POST_MAX_SIZE=48M
|
|
||||||
RUN sed -i "s/^post_max_size = .*/post_max_size = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
|
||||||
|
|
||||||
ARG PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
|
||||||
RUN sed -i "s/^upload_max_filesize = .*/upload_max_filesize = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Crontab
|
# Crontab
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
COPY ./crontab74 /etc/cron.d
|
# Clean up
|
||||||
|
RUN apt-get clean && \
|
||||||
|
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
|
|
||||||
|
COPY ./crontab /etc/cron.d
|
||||||
|
|
||||||
RUN chmod -R 644 /etc/cron.d
|
RUN chmod -R 644 /etc/cron.d
|
||||||
|
|
||||||
|
|
||||||
|
#ENTRYPOINT ["/bin/bash","-c","service supervisor start"]
|
||||||
127
dockerfiles/workspace/workspace81.Dockerfile
Normal file
127
dockerfiles/workspace/workspace81.Dockerfile
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
FROM dimti/workspace:8.1
|
||||||
|
|
||||||
|
ARG PHP_VERSION=8.1
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Laradock non-root user:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG CUSTOM_PUID=1000
|
||||||
|
ENV PUID ${CUSTOM_PUID}
|
||||||
|
ARG CUSTOM_PGID=1000
|
||||||
|
ENV PGID ${CUSTOM_PGID}
|
||||||
|
|
||||||
|
RUN usermod -u ${CUSTOM_PUID} laradock && groupmod -g ${CUSTOM_PGID} laradock
|
||||||
|
|
||||||
|
RUN chown -R ${CUSTOM_PUID}:${CUSTOM_PGID} /home/laradock
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Set Timezone
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG CUSTOM_TZ=Europe/Moscow
|
||||||
|
ENV TZ ${CUSTOM_TZ}
|
||||||
|
|
||||||
|
RUN ln -snf /usr/share/zoneinfo/$CUSTOM_TZ /etc/localtime && echo $CUSTOM_TZ > /etc/timezone
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Additional PHP-extensions:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_REDIS=false
|
||||||
|
|
||||||
|
#RUN pecl install igbinary
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_REDIS} = true ]; then \
|
||||||
|
pecl install -a redis \
|
||||||
|
echo "extension=redis.so" > /etc/php/${PHP_VERSION}/cli/conf.d/20-redis.ini \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Libreoffice
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_LIBREOFFICE=false
|
||||||
|
|
||||||
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_LIBREOFFICE} = true ]; then \
|
||||||
|
add-apt-repository ppa:libreoffice/ppa \
|
||||||
|
&& apt update \
|
||||||
|
&& apt install libreoffice-nogui -y --no-install-recommends \
|
||||||
|
&& apt clean \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# S3 config
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER laradock
|
||||||
|
|
||||||
|
COPY ./minio/auth.json /home/laradock/.mc/config.json
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Install custom node version
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
ARG NODE_VERSION
|
||||||
|
ENV NODE_VERSION ${NODE_VERSION}
|
||||||
|
|
||||||
|
RUN if [ ! -z "${NODE_VERSION}" ]; then \
|
||||||
|
. ~/.bashrc && nvm install ${NODE_VERSION} \
|
||||||
|
&& . ~/.bashrc && nvm alias default ${NODE_VERSION} \
|
||||||
|
&& npm i -g yarn \
|
||||||
|
&& cp -R ~/.nvm/alias /home/laradock/.nvm \
|
||||||
|
&& cp -R ~/.nvm/versions /home/laradock/.nvm \
|
||||||
|
&& chown -R ${CUSTOM_PUID}:${CUSTOM_PGID} /home/laradock/.nvm \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Update composer version
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
ARG COMPOSER_VERSION=2
|
||||||
|
ENV COMPOSER_VERSION ${COMPOSER_VERSION}
|
||||||
|
RUN composer self-update --${COMPOSER_VERSION}
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Laradock Aliases
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER laradock
|
||||||
|
|
||||||
|
COPY ./aliases.sh /home/laradock/aliases.sh
|
||||||
|
|
||||||
|
RUN echo "" >> ~/.bashrc && \
|
||||||
|
echo "# Load Custom Aliases" >> ~/.bashrc && \
|
||||||
|
echo "source ~/aliases.sh" >> ~/.bashrc && \
|
||||||
|
echo "" >> ~/.bashrc
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Tune opts:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
ARG PHP_OPT_SHORT_OPEN_TAG=Off
|
||||||
|
RUN sed -i "s/^short_open_tag = .*/short_open_tag = $PHP_OPT_SHORT_OPEN_TAG/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
||||||
|
|
||||||
|
ARG PHP_OPT_MAX_EXECUTION_TIME=600
|
||||||
|
RUN sed -i "s/^max_execution_time = .*/max_execution_time = $PHP_OPT_MAX_EXECUTION_TIME/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
||||||
|
|
||||||
|
ARG PHP_OPT_MEMORY_LIMIT=256M
|
||||||
|
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Crontab
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
COPY ./crontab /etc/cron.d
|
||||||
|
|
||||||
|
RUN chmod -R 644 /etc/cron.d
|
||||||
@ -1,6 +1,6 @@
|
|||||||
FROM dimti/workspace:7.3
|
FROM dimti/workspace:8.2
|
||||||
|
|
||||||
ARG PHP_VERSION=7.3
|
ARG PHP_VERSION=8.2
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Laradock non-root user:
|
# Laradock non-root user:
|
||||||
@ -34,6 +34,32 @@ RUN pecl install -a redis
|
|||||||
RUN echo "extension=redis.so" > /etc/php/${PHP_VERSION}/cli/conf.d/20-redis.ini
|
RUN echo "extension=redis.so" > /etc/php/${PHP_VERSION}/cli/conf.d/20-redis.ini
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
# S3 config
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER laradock
|
||||||
|
|
||||||
|
COPY ./minio/auth.json /home/laradock/.mc/config.json
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Install custom node version
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
ARG NODE_VERSION
|
||||||
|
ENV NODE_VERSION ${NODE_VERSION}
|
||||||
|
|
||||||
|
RUN if [ ! -z "${NODE_VERSION}" ]; then \
|
||||||
|
. ~/.bashrc && nvm install ${NODE_VERSION} \
|
||||||
|
&& . ~/.bashrc && nvm alias default ${NODE_VERSION} \
|
||||||
|
&& npm i -g yarn \
|
||||||
|
&& cp -R ~/.nvm/alias /home/laradock/.nvm \
|
||||||
|
&& cp -R ~/.nvm/versions /home/laradock/.nvm \
|
||||||
|
&& chown -R ${CUSTOM_PUID}:${CUSTOM_PGID} /home/laradock/.nvm \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
# Update composer version
|
# Update composer version
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
@ -44,29 +70,6 @@ ENV COMPOSER_VERSION ${COMPOSER_VERSION}
|
|||||||
RUN composer self-update --${COMPOSER_VERSION}
|
RUN composer self-update --${COMPOSER_VERSION}
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Install custom node version
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
USER root
|
|
||||||
|
|
||||||
ARG CUSTOM_NODE_VERSION
|
|
||||||
ENV CUSTOM_NODE_VERSION ${CUSTOM_NODE_VERSION}
|
|
||||||
|
|
||||||
RUN if [ ! -z "${CUSTOM_NODE_VERSION}" ]; then \
|
|
||||||
. ~/.bashrc && nvm install ${CUSTOM_NODE_VERSION} \
|
|
||||||
&& . ~/.bashrc && nvm alias default ${CUSTOM_NODE_VERSION} \
|
|
||||||
&& cp -R ~/.nvm/alias /home/laradock/.nvm \
|
|
||||||
&& cp -R ~/.nvm/versions /home/laradock/.nvm \
|
|
||||||
&& chown -R ${CUSTOM_PUID}:${CUSTOM_PGID} /home/laradock/.nvm \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Remove DST_Root_CA3
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
RUN sed -i 's/^mozilla\/DST_Root_CA_X3\.crt/!mozilla\/DST_Root_CA_X3.crt/g' /etc/ca-certificates.conf && update-ca-certificates
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Laradock Aliases
|
# Laradock Aliases
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
@ -80,14 +83,6 @@ RUN echo "" >> ~/.bashrc && \
|
|||||||
echo "" >> ~/.bashrc
|
echo "" >> ~/.bashrc
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# S3 config
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
USER laradock
|
|
||||||
|
|
||||||
COPY ./minio/auth.json /home/laradock/.mc/config.json
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Tune opts:
|
# Tune opts:
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
@ -102,18 +97,19 @@ RUN sed -i "s/^max_execution_time = .*/max_execution_time = $PHP_OPT_MAX_EXECUTI
|
|||||||
ARG PHP_OPT_MEMORY_LIMIT=256M
|
ARG PHP_OPT_MEMORY_LIMIT=256M
|
||||||
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
||||||
|
|
||||||
ARG PHP_OPT_POST_MAX_SIZE=48M
|
|
||||||
RUN sed -i "s/^post_max_size = .*/post_max_size = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
|
||||||
|
|
||||||
ARG PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
|
||||||
RUN sed -i "s/^upload_max_filesize = .*/upload_max_filesize = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" /etc/php/${PHP_VERSION}/cli/php.ini
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Crontab
|
# Crontab
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
COPY ./crontab73 /etc/cron.d
|
COPY ./crontab /etc/cron.d
|
||||||
|
|
||||||
RUN chmod -R 644 /etc/cron.d
|
RUN chmod -R 644 /etc/cron.d
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Libreoffice:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
|
RUN add-apt-repository ppa:libreoffice/ppa && apt update && apt install libreoffice-nogui -y --no-install-recommends && apt clean
|
||||||
@ -1,11 +1,11 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
FILE=${HOME}/.config/composer/auth.json
|
#FILE=${HOME}/.config/composer/auth.json
|
||||||
|
#
|
||||||
if [[ -f "${FILE}" ]]; then
|
#if [[ -f "${FILE}" ]]; then
|
||||||
if [[ ! -z "$(cat $FILE | grep github)" ]]; then
|
# if [[ ! -z "$(cat $FILE | grep github)" ]]; then
|
||||||
exit 0
|
# exit 0
|
||||||
fi
|
# fi
|
||||||
fi
|
#fi
|
||||||
|
|
||||||
echo "Get token: https://github.com/settings/tokens/new?scopes=repo&description=Composer"
|
echo "Get token: https://github.com/settings/tokens/new?scopes=repo&description=Composer"
|
||||||
|
|
||||||
|
|||||||
10
src/.env
10
src/.env
@ -6,18 +6,14 @@ WORKSPACE_INSTALL_SSH=true
|
|||||||
WORKSPACE_INSTALL_MYSQL_CLIENT=true
|
WORKSPACE_INSTALL_MYSQL_CLIENT=true
|
||||||
WORKSPACE_INSTALL_FSWATCH=false
|
WORKSPACE_INSTALL_FSWATCH=false
|
||||||
WORKSPACE_INSTALL_PING=true
|
WORKSPACE_INSTALL_PING=true
|
||||||
WORKSPACE_INSTALL_S3_MINIO_CLIENT=true
|
WORKSPACE_INSTALL_S3_MINIO_CLIENT=false
|
||||||
WORKSPACE_INSTALL_XDEBUG=true
|
|
||||||
WORKSPACE_INSTALL_BZ2=true
|
WORKSPACE_INSTALL_BZ2=true
|
||||||
# PHP-extensions already installed: INTL, PGSQL, BCMATH
|
# PHP-extensions already installed: INTL, PGSQL, BCMATH
|
||||||
WORKSPACE_INSTALL_WP_CLI=true
|
WORKSPACE_INSTALL_WP_CLI=true
|
||||||
WORKSPACE_INSTALL_NODE=true
|
WORKSPACE_INSTALL_NODE=true
|
||||||
WORKSPACE_INSTALL_GULP=true
|
WORKSPACE_INSTALL_GULP=false
|
||||||
WORKSPACE_INSTALL_YARN=true
|
WORKSPACE_INSTALL_YARN=true
|
||||||
WORKSPACE_COMPOSER_VERSION=1
|
WORKSPACE_NODE_VERSION=lts/hydrogen
|
||||||
WORKSPACE_COMPOSER_GLOBAL_INSTALL=true
|
|
||||||
WORKSPACE_COMPOSER_REPO_PACKAGIST=
|
|
||||||
WORKSPACE_NODE_VERSION=lts/dubnium
|
|
||||||
WORKSPACE_NPM_REGISTRY=
|
WORKSPACE_NPM_REGISTRY=
|
||||||
WORKSPACE_YARN_VERSION=latest
|
WORKSPACE_YARN_VERSION=latest
|
||||||
|
|
||||||
|
|||||||
@ -32,8 +32,12 @@ For use visualization with `/usr/bin/dot`
|
|||||||
|
|
||||||
### Containers
|
### Containers
|
||||||
|
|
||||||
|
This is not usefully, but if your externally needs...
|
||||||
|
|
||||||
`dockviz containers -d | dot -Tpng -o ~/containers.png`
|
`dockviz containers -d | dot -Tpng -o ~/containers.png`
|
||||||
|
|
||||||
### Images
|
### Images
|
||||||
|
|
||||||
|
Proof technology
|
||||||
|
|
||||||
`dockviz images -d | dot -Tpng -o ~/images.png`
|
`dockviz images -d | dot -Tpng -o ~/images.png`
|
||||||
|
|||||||
@ -28,18 +28,8 @@ services:
|
|||||||
- INSTALL_FSWATCH=${WORKSPACE_INSTALL_FSWATCH}
|
- INSTALL_FSWATCH=${WORKSPACE_INSTALL_FSWATCH}
|
||||||
- INSTALL_PING=${WORKSPACE_INSTALL_PING}
|
- INSTALL_PING=${WORKSPACE_INSTALL_PING}
|
||||||
- INSTALL_S3_MINIO_CLIENT=${WORKSPACE_INSTALL_S3_MINIO_CLIENT}
|
- INSTALL_S3_MINIO_CLIENT=${WORKSPACE_INSTALL_S3_MINIO_CLIENT}
|
||||||
- INSTALL_XDEBUG=${WORKSPACE_INSTALL_XDEBUG}
|
|
||||||
- INSTALL_BZ2=${WORKSPACE_INSTALL_BZ2}
|
- INSTALL_BZ2=${WORKSPACE_INSTALL_BZ2}
|
||||||
- COMPOSER_VERSION=${WORKSPACE_COMPOSER_VERSION}
|
|
||||||
- COMPOSER_GLOBAL_INSTALL=${WORKSPACE_COMPOSER_GLOBAL_INSTALL}
|
|
||||||
- COMPOSER_REPO_PACKAGIST=${WORKSPACE_COMPOSER_REPO_PACKAGIST}
|
|
||||||
- INSTALL_WP_CLI=${WORKSPACE_INSTALL_WP_CLI}
|
- INSTALL_WP_CLI=${WORKSPACE_INSTALL_WP_CLI}
|
||||||
- INSTALL_NODE=${WORKSPACE_INSTALL_NODE}
|
|
||||||
- INSTALL_GULP=${WORKSPACE_INSTALL_GULP}
|
|
||||||
- INSTALL_YARN=${WORKSPACE_INSTALL_YARN}
|
|
||||||
- NODE_VERSION=${WORKSPACE_NODE_VERSION}
|
|
||||||
- NPM_REGISTRY=${WORKSPACE_NPM_REGISTRY}
|
|
||||||
- YARN_VERSION=${WORKSPACE_YARN_VERSION}
|
|
||||||
- PHP_OPT_MAX_EXECUTION_TIME=${PHP_OPT_MAX_EXECUTION_TIME}
|
- PHP_OPT_MAX_EXECUTION_TIME=${PHP_OPT_MAX_EXECUTION_TIME}
|
||||||
- PHP_OPT_MEMORY_LIMIT=${PHP_OPT_MEMORY_LIMIT}
|
- PHP_OPT_MEMORY_LIMIT=${PHP_OPT_MEMORY_LIMIT}
|
||||||
- PHP_OPT_POST_MAX_SIZE=${PHP_OPT_POST_MAX_SIZE}
|
- PHP_OPT_POST_MAX_SIZE=${PHP_OPT_POST_MAX_SIZE}
|
||||||
|
|||||||
@ -1,35 +1,45 @@
|
|||||||
version: '3.6'
|
version: '3.6'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
php73:
|
php56:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: php-fpm
|
service: php-fpm
|
||||||
build:
|
build:
|
||||||
dockerfile: php73.Dockerfile
|
dockerfile: php56.Dockerfile
|
||||||
php74:
|
php74:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: php-fpm
|
service: php-fpm
|
||||||
build:
|
build:
|
||||||
dockerfile: php74.Dockerfile
|
dockerfile: php74.Dockerfile
|
||||||
workspace73:
|
php81:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: workspace
|
service: php-fpm
|
||||||
build:
|
build:
|
||||||
dockerfile: workspace73.Dockerfile
|
dockerfile: php81.Dockerfile
|
||||||
|
php82:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: php-fpm
|
||||||
|
build:
|
||||||
|
dockerfile: php82.Dockerfile
|
||||||
workspace74:
|
workspace74:
|
||||||
extends:
|
extends:
|
||||||
file: docker-compose.base.yml
|
file: docker-compose.base.yml
|
||||||
service: workspace
|
service: workspace
|
||||||
build:
|
build:
|
||||||
dockerfile: workspace74.Dockerfile
|
dockerfile: workspace74.Dockerfile
|
||||||
|
workspace81:
|
||||||
secrets:
|
extends:
|
||||||
user_ssh_key:
|
file: docker-compose.base.yml
|
||||||
file: ~/.ssh/id_rsa
|
service: workspace
|
||||||
user_known_hosts:
|
build:
|
||||||
file: ~/.ssh/known_hosts
|
dockerfile: workspace81.Dockerfile
|
||||||
composer_auth:
|
workspace82:
|
||||||
file: ~/.composer/auth.json
|
extends:
|
||||||
|
file: docker-compose.base.yml
|
||||||
|
service: workspace
|
||||||
|
build:
|
||||||
|
dockerfile: workspace82.Dockerfile
|
||||||
|
|||||||
@ -14,15 +14,20 @@ RUN apt-get update && docker-php-ext-install pdo pdo_mysql \
|
|||||||
# xDebug:
|
# xDebug:
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
# Copy xdebug configuration for remote debugging
|
|
||||||
COPY ./xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
|
|
||||||
|
|
||||||
ARG INSTALL_XDEBUG=false
|
ARG INSTALL_XDEBUG=false
|
||||||
|
|
||||||
RUN if [ ${INSTALL_XDEBUG} = true ]; then \
|
RUN if [ ${INSTALL_XDEBUG} = true ]; then \
|
||||||
# Install the xdebug extension
|
# Install the xdebug extension
|
||||||
if [ $(php -r "echo PHP_MAJOR_VERSION;") = "5" ]; then \
|
if [ $(php -r "echo PHP_MAJOR_VERSION;") = "5" ]; then \
|
||||||
pecl install xdebug-2.5.5; \
|
pecl install xdebug-2.5.5; \
|
||||||
|
elif [ $(php -r "echo PHP_MAJOR_VERSION;") = "8" ]; then \
|
||||||
|
if [ $(php -r "echo PHP_MINOR_VERSION;") = "1" ]; then \
|
||||||
|
pecl install xdebug-3.1.6; \
|
||||||
|
elif [ $(php -r "echo PHP_MINOR_VERSION;") = "2" ]; then \
|
||||||
|
pecl install xdebug-3.3.1; \
|
||||||
|
else \
|
||||||
|
pecl install xdebug; \
|
||||||
|
fi \
|
||||||
else \
|
else \
|
||||||
pecl install xdebug-2.9.8; \
|
pecl install xdebug-2.9.8; \
|
||||||
fi && \
|
fi && \
|
||||||
|
|||||||
136
src/dockerfiles/php-fpm/php.base56.Dockerfile
Normal file
136
src/dockerfiles/php-fpm/php.base56.Dockerfile
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
|
libfreetype6-dev \
|
||||||
|
libjpeg62-turbo-dev \
|
||||||
|
libpng-dev \
|
||||||
|
libwebp-dev \
|
||||||
|
&& docker-php-ext-install -j$(nproc) iconv \
|
||||||
|
&& docker-php-ext-install mysqli \
|
||||||
|
&& docker-php-ext-enable mysqli
|
||||||
|
|
||||||
|
RUN apt-get update && docker-php-ext-install pdo pdo_mysql \
|
||||||
|
&& docker-php-ext-enable pdo pdo_mysql
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# xDebug:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_XDEBUG=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_XDEBUG} = true ]; then \
|
||||||
|
# Install the xdebug extension
|
||||||
|
if [ $(php -r "echo PHP_MAJOR_VERSION;") = "5" ]; then \
|
||||||
|
pecl install xdebug-2.5.5; \
|
||||||
|
else \
|
||||||
|
pecl install xdebug-2.9.8; \
|
||||||
|
fi && \
|
||||||
|
docker-php-ext-enable xdebug && \
|
||||||
|
sed -i 's/^zend_extension=/;zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Zip:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_ZIP=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_ZIP} = true ]; then \
|
||||||
|
apt update && apt install -y libzip-dev \
|
||||||
|
&& docker-php-ext-install zip \
|
||||||
|
&& docker-php-ext-enable zip \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# BZ2:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_BZ2=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_BZ2} = true ]; then \
|
||||||
|
apt update && apt install -y libbz2-ocaml-dev \
|
||||||
|
&& docker-php-ext-install bz2 \
|
||||||
|
&& docker-php-ext-enable bz2 \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# OPCACHE:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_OPCACHE=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_OPCACHE} = true ]; then \
|
||||||
|
docker-php-ext-install opcache \
|
||||||
|
&& docker-php-ext-enable opcache \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# INTL:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_INTL=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_INTL} = true ]; then \
|
||||||
|
apt update && apt install -y libicu-dev \
|
||||||
|
&& docker-php-ext-install intl \
|
||||||
|
&& docker-php-ext-enable intl \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# PGSQL:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_PGSQL=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_PGSQL} = true ]; then \
|
||||||
|
apt update && apt install -y libpq-dev \
|
||||||
|
&& docker-php-ext-install pgsql \
|
||||||
|
&& docker-php-ext-install pdo_pgsql \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# BCMATH:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG INSTALL_BCMATH=false
|
||||||
|
|
||||||
|
RUN if [ ${INSTALL_BCMATH} = true ]; then \
|
||||||
|
docker-php-ext-install bcmath \
|
||||||
|
;fi
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Locales:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
RUN apt install -y locales && \
|
||||||
|
sed -i 's/# en_US.UTF-8 UTF-8/en_US.UTF-8 UTF-8/' /etc/locale.gen && \
|
||||||
|
sed -i 's/# ru_RU.UTF-8 UTF-8/ru_RU.UTF-8 UTF-8/' /etc/locale.gen && \
|
||||||
|
locale-gen
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Prepend nginx 502 on showing errors:
|
||||||
|
# @see https://stackoverflow.com/questions/55260221/laravel-php-7-3-nginx-502-upstream-prematurely-closed-fastcgi-stdout
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
RUN sed -i "s/^log_limit = .*/log_limit = 1024/g" "$PHP_INI_DIR/../php-fpm.d/docker.conf"
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# php.ini opts:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
# https://github.com/php/php-src/blob/master/php.ini-development
|
||||||
|
RUN mv "$PHP_INI_DIR/php.ini-development" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
|
# Tune opts:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
ARG PHP_OPT_MAX_EXECUTION_TIME=600
|
||||||
|
RUN sed -i "s/^max_execution_time = .*/max_execution_time = $PHP_OPT_MAX_EXECUTION_TIME/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_MEMORY_LIMIT=256M
|
||||||
|
RUN sed -i "s/^memory_limit = .*/memory_limit = $PHP_OPT_MEMORY_LIMIT/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_POST_MAX_SIZE=48M
|
||||||
|
RUN sed -i "s/^post_max_size = .*/post_max_size = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" "$PHP_INI_DIR/php.ini"
|
||||||
|
|
||||||
|
ARG PHP_OPT_UPLOAD_MAX_FILESIZE=16M
|
||||||
|
RUN sed -i "s/^upload_max_filesize = .*/upload_max_filesize = $PHP_OPT_UPLOAD_MAX_FILESIZE/g" "$PHP_INI_DIR/php.ini"
|
||||||
@ -1,7 +1,7 @@
|
|||||||
# syntax = edrevo/dockerfile-plus
|
# syntax = edrevo/dockerfile-plus
|
||||||
FROM php:7.3-fpm
|
FROM php:5.6-fpm
|
||||||
|
|
||||||
INCLUDE+ ./php.base.Dockerfile
|
INCLUDE+ ./php.base56.Dockerfile
|
||||||
|
|
||||||
RUN docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-webp-dir=/usr/include/ \
|
RUN docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-webp-dir=/usr/include/ \
|
||||||
&& docker-php-ext-install -j$(nproc) gd
|
&& docker-php-ext-install -j$(nproc) gd
|
||||||
8
src/dockerfiles/php-fpm/php81.Dockerfile
Normal file
8
src/dockerfiles/php-fpm/php81.Dockerfile
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# syntax = edrevo/dockerfile-plus
|
||||||
|
# https://github.com/docker-library/php/blob/52062af5056d0cd91fa5ded64fad8f9c82847b49/8.1/bookworm/fpm/Dockerfile
|
||||||
|
FROM php:8.1-fpm
|
||||||
|
|
||||||
|
INCLUDE+ ./php.base.Dockerfile
|
||||||
|
|
||||||
|
RUN docker-php-ext-configure gd --with-freetype --with-jpeg --with-webp \
|
||||||
|
&& docker-php-ext-install -j$(nproc) gd
|
||||||
7
src/dockerfiles/php-fpm/php82.Dockerfile
Normal file
7
src/dockerfiles/php-fpm/php82.Dockerfile
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
# syntax = edrevo/dockerfile-plus
|
||||||
|
FROM php:8.2-fpm
|
||||||
|
|
||||||
|
INCLUDE+ ./php.base.Dockerfile
|
||||||
|
|
||||||
|
RUN docker-php-ext-configure gd --with-freetype --with-jpeg --with-webp \
|
||||||
|
&& docker-php-ext-install -j$(nproc) gd
|
||||||
@ -1,25 +0,0 @@
|
|||||||
; NOTE: The actual xdebug.so extension is NOT SET HERE but rather (/usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini)
|
|
||||||
|
|
||||||
;xdebug.remote_host=dockerhost
|
|
||||||
xdebug.remote_connect_back=1
|
|
||||||
xdebug.remote_port=9000
|
|
||||||
xdebug.idekey=PHPSTORM
|
|
||||||
|
|
||||||
xdebug.remote_autostart=1
|
|
||||||
xdebug.remote_enable=1
|
|
||||||
xdebug.cli_color=0
|
|
||||||
xdebug.profiler_enable=1
|
|
||||||
xdebug.profiler_enable_trigger=1
|
|
||||||
xdebug.profiler_output_dir=/tmp
|
|
||||||
|
|
||||||
xdebug.remote_handler=dbgp
|
|
||||||
xdebug.remote_mode=req
|
|
||||||
|
|
||||||
xdebug.var_display_max_children=-1
|
|
||||||
xdebug.var_display_max_data=-1
|
|
||||||
xdebug.var_display_max_depth=-1
|
|
||||||
|
|
||||||
xdebug.trace_enable_trigger=1
|
|
||||||
xdebug.trace_output_dir=/tmp
|
|
||||||
xdebug.trace_output_name="trace.%t"
|
|
||||||
|
|
||||||
84
src/dockerfiles/workspace/completion.sh
Normal file
84
src/dockerfiles/workspace/completion.sh
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
# This file is part of the Symfony package.
|
||||||
|
#
|
||||||
|
# (c) Fabien Potencier <fabien@symfony.com>
|
||||||
|
#
|
||||||
|
# For the full copyright and license information, please view
|
||||||
|
# https://symfony.com/doc/current/contributing/code/license.html
|
||||||
|
|
||||||
|
_sf_artisan() {
|
||||||
|
# Use newline as only separator to allow space in completion values
|
||||||
|
IFS=$'\n'
|
||||||
|
local sf_cmd="${COMP_WORDS[0]}"
|
||||||
|
|
||||||
|
# for an alias, get the real script behind it
|
||||||
|
sf_cmd_type=$(type -t $sf_cmd)
|
||||||
|
if [[ $sf_cmd_type == "alias" ]]; then
|
||||||
|
sf_cmd=$(alias $sf_cmd | sed -E "s/alias $sf_cmd='(.*)'/\1/")
|
||||||
|
elif [[ $sf_cmd_type == "file" ]]; then
|
||||||
|
sf_cmd=$(type -p $sf_cmd)
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $sf_cmd_type != "function" && ! -x $sf_cmd ]]; then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local cur prev words cword
|
||||||
|
_get_comp_words_by_ref -n := cur prev words cword
|
||||||
|
|
||||||
|
local completecmd=("$sf_cmd" "_complete" "--no-interaction" "-sbash" "-c$cword" "-a1")
|
||||||
|
for w in ${words[@]}; do
|
||||||
|
w=$(printf -- '%b' "$w")
|
||||||
|
# remove quotes from typed values
|
||||||
|
quote="${w:0:1}"
|
||||||
|
if [ "$quote" == \' ]; then
|
||||||
|
w="${w%\'}"
|
||||||
|
w="${w#\'}"
|
||||||
|
elif [ "$quote" == \" ]; then
|
||||||
|
w="${w%\"}"
|
||||||
|
w="${w#\"}"
|
||||||
|
fi
|
||||||
|
# empty values are ignored
|
||||||
|
if [ ! -z "$w" ]; then
|
||||||
|
completecmd+=("-i$w")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
local sfcomplete
|
||||||
|
if sfcomplete=$(${completecmd[@]} 2>&1); then
|
||||||
|
local quote suggestions
|
||||||
|
quote=${cur:0:1}
|
||||||
|
|
||||||
|
# Use single quotes by default if suggestions contains backslash (FQCN)
|
||||||
|
if [ "$quote" == '' ] && [[ "$sfcomplete" =~ \\ ]]; then
|
||||||
|
quote=\'
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$quote" == \' ]; then
|
||||||
|
# single quotes: no additional escaping (does not accept ' in values)
|
||||||
|
suggestions=$(for s in $sfcomplete; do printf $'%q%q%q\n' "$quote" "$s" "$quote"; done)
|
||||||
|
elif [ "$quote" == \" ]; then
|
||||||
|
# double quotes: double escaping for \ $ ` "
|
||||||
|
suggestions=$(for s in $sfcomplete; do
|
||||||
|
s=${s//\\/\\\\}
|
||||||
|
s=${s//\$/\\\$}
|
||||||
|
s=${s//\`/\\\`}
|
||||||
|
s=${s//\"/\\\"}
|
||||||
|
printf $'%q%q%q\n' "$quote" "$s" "$quote";
|
||||||
|
done)
|
||||||
|
else
|
||||||
|
# no quotes: double escaping
|
||||||
|
suggestions=$(for s in $sfcomplete; do printf $'%q\n' $(printf '%q' "$s"); done)
|
||||||
|
fi
|
||||||
|
COMPREPLY=($(IFS=$'\n' compgen -W "$suggestions" -- $(printf -- "%q" "$cur")))
|
||||||
|
__ltrim_colon_completions "$cur"
|
||||||
|
else
|
||||||
|
if [[ "$sfcomplete" != *"Command \"_complete\" is not defined."* ]]; then
|
||||||
|
>&2 echo
|
||||||
|
>&2 echo $sfcomplete
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
complete -F _sf_artisan artisan
|
||||||
13
src/dockerfiles/workspace/composer.Dockerfile
Normal file
13
src/dockerfiles/workspace/composer.Dockerfile
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
###########################################################################
|
||||||
|
# Composer:
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
USER laradock
|
||||||
|
|
||||||
|
# Create composer dir for store composer2_auth secret
|
||||||
|
RUN mkdir -p /home/laradock/.config/composer
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
# Symlink to composer auth secret
|
||||||
|
RUN ln -s /run/secrets/composer_auth /home/laradock/.config/composer/auth.json
|
||||||
@ -1,5 +0,0 @@
|
|||||||
{
|
|
||||||
"require": {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
3
src/dockerfiles/workspace/tmux.conf
Normal file
3
src/dockerfiles/workspace/tmux.conf
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
set-option -g status-interval 1
|
||||||
|
set-option -g automatic-rename on
|
||||||
|
set-option -g automatic-rename-format "#{?#{==:#{pane_current_command},bash},#{b:pane_current_path},#{pane_current_command}}"
|
||||||
@ -1,18 +1,3 @@
|
|||||||
#
|
|
||||||
#--------------------------------------------------------------------------
|
|
||||||
# Image Setup
|
|
||||||
#--------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# To edit the 'workspace' base Image, visit its repository on Github
|
|
||||||
# https://github.com/Laradock/workspace
|
|
||||||
#
|
|
||||||
# To change its version, see the available Tags on the Docker Hub:
|
|
||||||
# https://hub.docker.com/r/laradock/workspace/tags/
|
|
||||||
#
|
|
||||||
# Note: Base Image name format {image-tag}-{php-version}
|
|
||||||
#
|
|
||||||
LABEL maintainer="Mahmoud Zalt <mahmoud@zalt.me>"
|
|
||||||
|
|
||||||
# Set Environment Variables
|
# Set Environment Variables
|
||||||
ENV DEBIAN_FRONTEND noninteractive
|
ENV DEBIAN_FRONTEND noninteractive
|
||||||
|
|
||||||
@ -89,7 +74,7 @@ RUN sed -i 's/\r//' /root/aliases.sh && \
|
|||||||
echo "" >> ~/.bashrc && \
|
echo "" >> ~/.bashrc && \
|
||||||
echo "# Load Custom Aliases" >> ~/.bashrc && \
|
echo "# Load Custom Aliases" >> ~/.bashrc && \
|
||||||
echo "source ~/aliases.sh" >> ~/.bashrc && \
|
echo "source ~/aliases.sh" >> ~/.bashrc && \
|
||||||
echo "" >> ~/.bashrc \
|
echo "" >> ~/.bashrc
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# ssh:
|
# ssh:
|
||||||
@ -170,16 +155,21 @@ RUN if [ ${INSTALL_S3_MINIO_CLIENT} = true ]; then \
|
|||||||
# xDebug:
|
# xDebug:
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
# Copy xdebug configuration for remote debugging
|
RUN if [ $(php -r "echo PHP_MAJOR_VERSION;") = "5" ]; then \
|
||||||
COPY ./xdebug.ini /etc/php/${PHP_VERSION}/cli/conf.d/xdebug.ini
|
pecl install xdebug-2.5.5; \
|
||||||
|
elif [ $(php -r "echo PHP_MAJOR_VERSION;") = "8" ]; then \
|
||||||
ARG INSTALL_XDEBUG=false
|
if [ $(php -r "echo PHP_MINOR_VERSION;") = "1" ]; then \
|
||||||
|
pecl install xdebug-3.1.6; \
|
||||||
RUN if [ ${INSTALL_XDEBUG} = true ]; then \
|
elif [ $(php -r "echo PHP_MINOR_VERSION;") = "2" ]; then \
|
||||||
pecl install xdebug-2.8.1 && \
|
pecl install xdebug-3.3.1; \
|
||||||
|
else \
|
||||||
|
pecl install xdebug; \
|
||||||
|
fi \
|
||||||
|
else \
|
||||||
|
pecl install xdebug-2.9.8; \
|
||||||
|
fi && \
|
||||||
echo ';zend_extension=xdebug.so' > /etc/php/${PHP_VERSION}/cli/conf.d/20-xdebug.ini && \
|
echo ';zend_extension=xdebug.so' > /etc/php/${PHP_VERSION}/cli/conf.d/20-xdebug.ini && \
|
||||||
echo "alias phpunit='php -dzend_extension=xdebug.so /var/www/vendor/bin/phpunit'" >> ~/.bashrc \
|
echo "alias phpunit='php -dzend_extension=xdebug.so /var/www/vendor/bin/phpunit'" >> ~/.bashrc
|
||||||
;fi
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# BZ2:
|
# BZ2:
|
||||||
@ -192,51 +182,6 @@ RUN if [ ${INSTALL_BZ2} = true ]; then \
|
|||||||
;fi
|
;fi
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Composer:
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
USER root
|
|
||||||
|
|
||||||
# Add the composer.json
|
|
||||||
COPY ./composer.json /home/laradock/.composer/composer.json
|
|
||||||
|
|
||||||
# Make sure that ~/.composer belongs to laradock
|
|
||||||
RUN chown -R laradock:laradock /home/laradock/.composer
|
|
||||||
|
|
||||||
RUN ln -s /run/secrets/composer_auth /home/laradock/.composer/auth.json
|
|
||||||
|
|
||||||
# Export composer vendor path
|
|
||||||
RUN echo "" >> ~/.bashrc && \
|
|
||||||
echo 'export PATH="$HOME/.composer/vendor/bin:$PATH"' >> ~/.bashrc
|
|
||||||
|
|
||||||
# Update composer
|
|
||||||
ARG COMPOSER_VERSION=2
|
|
||||||
ENV COMPOSER_VERSION ${COMPOSER_VERSION}
|
|
||||||
RUN composer self-update --${COMPOSER_VERSION}
|
|
||||||
|
|
||||||
USER laradock
|
|
||||||
|
|
||||||
# Check if global install need to be ran
|
|
||||||
ARG COMPOSER_GLOBAL_INSTALL=false
|
|
||||||
ENV COMPOSER_GLOBAL_INSTALL ${COMPOSER_GLOBAL_INSTALL}
|
|
||||||
|
|
||||||
RUN if [ ${COMPOSER_GLOBAL_INSTALL} = true ]; then \
|
|
||||||
# run the install
|
|
||||||
composer global install \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
ARG COMPOSER_REPO_PACKAGIST
|
|
||||||
ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
|
|
||||||
|
|
||||||
RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
|
|
||||||
composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
# Export composer vendor path
|
|
||||||
RUN echo "" >> ~/.bashrc && \
|
|
||||||
echo 'export PATH="~/.composer/vendor/bin:$PATH"' >> ~/.bashrc
|
|
||||||
|
|
||||||
###########################################################################
|
|
||||||
# Non-root user : PHPUnit path
|
# Non-root user : PHPUnit path
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
@ -273,131 +218,36 @@ RUN if [ ${INSTALL_WP_CLI} = true ]; then \
|
|||||||
|
|
||||||
USER laradock
|
USER laradock
|
||||||
|
|
||||||
# Check if NVM needs to be installed
|
|
||||||
ARG INSTALL_NODE=false
|
|
||||||
ENV INSTALL_NODE ${INSTALL_NODE}
|
|
||||||
ARG NODE_VERSION=node
|
|
||||||
ENV NODE_VERSION ${NODE_VERSION}
|
|
||||||
ARG INSTALL_NPM_GULP=false
|
|
||||||
ARG INSTALL_NPM_BOWER=false
|
|
||||||
ARG INSTALL_NPM_VUE_CLI=false
|
|
||||||
ARG INSTALL_NPM_ANGULAR_CLI=false
|
|
||||||
ARG NPM_REGISTRY
|
|
||||||
ENV NPM_REGISTRY ${NPM_REGISTRY}
|
|
||||||
ENV NVM_DIR /home/laradock/.nvm
|
ENV NVM_DIR /home/laradock/.nvm
|
||||||
|
|
||||||
RUN if [ ${INSTALL_NODE} = true ]; then \
|
RUN mkdir -p $NVM_DIR && \
|
||||||
# Install nvm (A Node Version Manager)
|
|
||||||
mkdir -p $NVM_DIR && \
|
|
||||||
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.11/install.sh | bash \
|
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.11/install.sh | bash \
|
||||||
&& . $NVM_DIR/nvm.sh \
|
&& . $NVM_DIR/nvm.sh
|
||||||
&& nvm install ${NODE_VERSION} \
|
|
||||||
&& nvm use ${NODE_VERSION} \
|
|
||||||
&& nvm alias ${NODE_VERSION} \
|
|
||||||
&& if [ ${NPM_REGISTRY} ]; then \
|
|
||||||
npm config set registry ${NPM_REGISTRY} \
|
|
||||||
;fi \
|
|
||||||
&& if [ ${INSTALL_NPM_GULP} = true ]; then \
|
|
||||||
npm install -g gulp \
|
|
||||||
;fi \
|
|
||||||
&& if [ ${INSTALL_NPM_BOWER} = true ]; then \
|
|
||||||
npm install -g bower \
|
|
||||||
;fi \
|
|
||||||
&& if [ ${INSTALL_NPM_VUE_CLI} = true ]; then \
|
|
||||||
npm install -g @vue/cli \
|
|
||||||
;fi \
|
|
||||||
&& if [ ${INSTALL_NPM_ANGULAR_CLI} = true ]; then \
|
|
||||||
npm install -g @angular/cli \
|
|
||||||
;fi \
|
|
||||||
&& ln -s `npm bin --global` /home/laradock/.node-bin \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
# Wouldn't execute when added to the RUN statement in the above block
|
# Wouldn't execute when added to the RUN statement in the above block
|
||||||
# Source NVM when loading bash since ~/.profile isn't loaded on non-login shell
|
# Source NVM when loading bash since ~/.profile isn't loaded on non-login shell
|
||||||
RUN if [ ${INSTALL_NODE} = true ]; then \
|
RUN echo "" >> ~/.bashrc && \
|
||||||
echo "" >> ~/.bashrc && \
|
|
||||||
echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc && \
|
echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc && \
|
||||||
echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm' >> ~/.bashrc \
|
echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm' >> ~/.bashrc
|
||||||
;fi
|
|
||||||
|
|
||||||
# Add NVM binaries to root's .bashrc
|
# Add NVM binaries to root's .bashrc
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
RUN if [ ${INSTALL_NODE} = true ]; then \
|
RUN cp -R /home/laradock/.nvm /root/ && \
|
||||||
cp -R /home/laradock/.nvm /root/ && \
|
|
||||||
chown -R root:root /root/.nvm && \
|
chown -R root:root /root/.nvm && \
|
||||||
echo "" >> ~/.bashrc && \
|
echo "" >> ~/.bashrc && \
|
||||||
echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc && \
|
echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc && \
|
||||||
echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm' >> ~/.bashrc \
|
echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm' >> ~/.bashrc
|
||||||
;fi
|
|
||||||
|
|
||||||
# Add PATH for node
|
|
||||||
ENV PATH $PATH:/home/laradock/.node-bin
|
|
||||||
|
|
||||||
# Make it so the node modules can be executed with 'docker-compose exec'
|
|
||||||
# We'll create symbolic links into '/usr/local/bin'.
|
|
||||||
RUN if [ ${INSTALL_NODE} = true ]; then \
|
|
||||||
find $NVM_DIR -type f -name node -exec ln -s {} /usr/local/bin/node \; && \
|
|
||||||
NODE_MODS_DIR="$NVM_DIR/versions/node/$(node -v)/lib/node_modules" && \
|
|
||||||
ln -s $NODE_MODS_DIR/bower/bin/bower /usr/local/bin/bower && \
|
|
||||||
ln -s $NODE_MODS_DIR/gulp/bin/gulp.js /usr/local/bin/gulp && \
|
|
||||||
ln -s $NODE_MODS_DIR/npm/bin/npm-cli.js /usr/local/bin/npm && \
|
|
||||||
ln -s $NODE_MODS_DIR/npm/bin/npx-cli.js /usr/local/bin/npx && \
|
|
||||||
ln -s $NODE_MODS_DIR/vue-cli/bin/vue /usr/local/bin/vue && \
|
|
||||||
ln -s $NODE_MODS_DIR/vue-cli/bin/vue-init /usr/local/bin/vue-init && \
|
|
||||||
ln -s $NODE_MODS_DIR/vue-cli/bin/vue-list /usr/local/bin/vue-list \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
RUN if [ ${NPM_REGISTRY} ]; then \
|
|
||||||
. ~/.bashrc && npm config set registry ${NPM_REGISTRY} \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# GULP:
|
# Tmux
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
ARG INSTALL_GULP=false
|
|
||||||
ENV INSTALL_GULP ${INSTALL_GULP}
|
|
||||||
|
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
RUN if [ ${INSTALL_GULP} = true ]; then \
|
RUN apt-get update -yqq && apt-get install -y tmux
|
||||||
npm i -g gulp gulp-cli \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
###########################################################################
|
COPY ./tmux.conf /etc/tmux.conf
|
||||||
# YARN:
|
|
||||||
###########################################################################
|
|
||||||
|
|
||||||
USER laradock
|
|
||||||
|
|
||||||
ARG INSTALL_YARN=false
|
|
||||||
ENV INSTALL_YARN ${INSTALL_YARN}
|
|
||||||
ARG YARN_VERSION=latest
|
|
||||||
ENV YARN_VERSION ${YARN_VERSION}
|
|
||||||
|
|
||||||
RUN if [ ${INSTALL_YARN} = true ]; then \
|
|
||||||
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" && \
|
|
||||||
if [ ${YARN_VERSION} = "latest" ]; then \
|
|
||||||
curl -o- -L https://yarnpkg.com/install.sh | bash; \
|
|
||||||
else \
|
|
||||||
curl -o- -L https://yarnpkg.com/install.sh | bash -s -- --version ${YARN_VERSION}; \
|
|
||||||
fi && \
|
|
||||||
echo "" >> ~/.bashrc && \
|
|
||||||
echo 'export PATH="$HOME/.yarn/bin:$PATH"' >> ~/.bashrc \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
# Add YARN binaries to root's .bashrc
|
|
||||||
USER root
|
|
||||||
|
|
||||||
RUN if [ ${INSTALL_YARN} = true ]; then \
|
|
||||||
echo "" >> ~/.bashrc && \
|
|
||||||
echo 'export YARN_DIR="/home/laradock/.yarn"' >> ~/.bashrc && \
|
|
||||||
echo 'export PATH="$YARN_DIR/bin:$PATH"' >> ~/.bashrc \
|
|
||||||
;fi
|
|
||||||
|
|
||||||
# Add PATH for YARN
|
|
||||||
ENV PATH $PATH:/home/laradock/.yarn/bin
|
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Remove DST_Root_CA3
|
# Remove DST_Root_CA3
|
||||||
@ -408,6 +258,14 @@ USER root
|
|||||||
RUN sed -i 's/^mozilla\/DST_Root_CA_X3\.crt/!mozilla\/DST_Root_CA_X3.crt/g' /etc/ca-certificates.conf && update-ca-certificates
|
RUN sed -i 's/^mozilla\/DST_Root_CA_X3\.crt/!mozilla\/DST_Root_CA_X3.crt/g' /etc/ca-certificates.conf && update-ca-certificates
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
# Artisan bash autocompletion from symphony
|
||||||
|
# @see https://wintercms.com/docs/v1.2/docs/console/introduction#autocompletion--suggested-input-values
|
||||||
|
###########################################################################
|
||||||
|
|
||||||
|
RUN apt install bash-completion
|
||||||
|
COPY /completion.sh /etc/bash_completion.d/artisan
|
||||||
|
|
||||||
|
###########################################################################
|
||||||
# Tune opts:
|
# Tune opts:
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
|
|||||||
@ -1,7 +0,0 @@
|
|||||||
# syntax = edrevo/dockerfile-plus
|
|
||||||
FROM laradock/workspace:latest-7.3
|
|
||||||
|
|
||||||
ARG PHP_VERSION=7.3
|
|
||||||
ENV PHP_VERSION ${PHP_VERSION}
|
|
||||||
|
|
||||||
INCLUDE+ ./workspace.base.Dockerfile
|
|
||||||
@ -5,3 +5,5 @@ ARG PHP_VERSION=7.4
|
|||||||
ENV PHP_VERSION ${PHP_VERSION}
|
ENV PHP_VERSION ${PHP_VERSION}
|
||||||
|
|
||||||
INCLUDE+ ./workspace.base.Dockerfile
|
INCLUDE+ ./workspace.base.Dockerfile
|
||||||
|
INCLUDE+ ./composer.Dockerfile
|
||||||
|
INCLUDE+ ./xdebug2.Dockerfile
|
||||||
|
|||||||
9
src/dockerfiles/workspace/workspace81.Dockerfile
Normal file
9
src/dockerfiles/workspace/workspace81.Dockerfile
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# syntax = edrevo/dockerfile-plus
|
||||||
|
FROM laradock/workspace:latest-8.1
|
||||||
|
|
||||||
|
ARG PHP_VERSION=8.1
|
||||||
|
ENV PHP_VERSION ${PHP_VERSION}
|
||||||
|
|
||||||
|
INCLUDE+ ./workspace.base.Dockerfile
|
||||||
|
INCLUDE+ ./composer.Dockerfile
|
||||||
|
INCLUDE+ ./xdebug3.Dockerfile
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user