| author | Riwad Salim <riwad.salim@yahoo.fr> |
| Wed, 04 Sep 2019 17:01:28 +0200 | |
| changeset 36 | 2cb2ab7d1b7d |
| parent 7 | 3ecf94cab400 |
| permissions | -rw-r--r-- |
| 0 | 1 |
#!/bin/bash |
2 |
set -euo pipefail |
|
3 |
||
4 |
# usage: file_env VAR [DEFAULT] |
|
5 |
# ie: file_env 'XYZ_DB_PASSWORD' 'example' |
|
6 |
# (will allow for "$XYZ_DB_PASSWORD_FILE" to fill in the value of |
|
7 |
# "$XYZ_DB_PASSWORD" from a file, especially for Docker's secrets feature) |
|
8 |
file_env() { |
|
9 |
local var="$1" |
|
10 |
local fileVar="${var}_FILE" |
|
11 |
local def="${2:-}" |
|
12 |
if [ "${!var:-}" ] && [ "${!fileVar:-}" ]; then |
|
13 |
echo >&2 "error: both $var and $fileVar are set (but are exclusive)" |
|
14 |
exit 1 |
|
15 |
fi |
|
16 |
local val="$def" |
|
17 |
if [ "${!var:-}" ]; then |
|
18 |
val="${!var}" |
|
19 |
elif [ "${!fileVar:-}" ]; then |
|
20 |
val="$(< "${!fileVar}")" |
|
21 |
fi |
|
22 |
export "$var"="$val" |
|
23 |
unset "$fileVar" |
|
24 |
} |
|
25 |
||
26 |
generate_rnd() { |
|
27 |
head /dev/urandom | tr -dc A-Za-z0-9 | head -c 64 |
|
28 |
} |
|
29 |
||
| 1 | 30 |
# allow any of these "Authentication Unique Keys and Salts." to be specified via |
31 |
# environment variables with a "WORDPRESS_" prefix (ie, "WORDPRESS_AUTH_KEY") |
|
32 |
uniqueEnvs=( |
|
33 |
AUTH_KEY |
|
34 |
SECURE_AUTH_KEY |
|
35 |
LOGGED_IN_KEY |
|
36 |
NONCE_KEY |
|
37 |
AUTH_SALT |
|
38 |
SECURE_AUTH_SALT |
|
39 |
LOGGED_IN_SALT |
|
40 |
NONCE_SALT |
|
41 |
) |
|
42 |
envs=( |
|
43 |
WORDPRESS_DB_HOST |
|
44 |
WORDPRESS_DB_USER |
|
45 |
WORDPRESS_DB_PASSWORD |
|
46 |
WORDPRESS_DB_NAME |
|
47 |
WORDPRESS_DB_CHARSET |
|
48 |
WORDPRESS_DB_COLLATE |
|
49 |
"${uniqueEnvs[@]/#/WORDPRESS_}" |
|
50 |
WORDPRESS_TABLE_PREFIX |
|
51 |
WORDPRESS_DEBUG |
|
52 |
WORDPRESS_CONFIG_EXTRA |
|
53 |
) |
|
54 |
haveConfig= |
|
55 |
for e in "${envs[@]}"; do |
|
56 |
file_env "$e" |
|
57 |
if [ -z "$haveConfig" ] && [ -n "${!e}" ]; then |
|
58 |
haveConfig=1 |
|
59 |
fi |
|
60 |
done |
|
61 |
||
62 |
# linking backwards-compatibility |
|
63 |
if [ -n "${!MYSQL_ENV_MYSQL_*}" ]; then |
|
64 |
haveConfig=1 |
|
65 |
# host defaults to "mysql" below if unspecified |
|
66 |
: "${WORDPRESS_DB_USER:=${MYSQL_ENV_MYSQL_USER:-root}}" |
|
67 |
if [ "$WORDPRESS_DB_USER" = 'root' ]; then |
|
68 |
: "${WORDPRESS_DB_PASSWORD:=${MYSQL_ENV_MYSQL_ROOT_PASSWORD:-}}" |
|
69 |
else |
|
70 |
: "${WORDPRESS_DB_PASSWORD:=${MYSQL_ENV_MYSQL_PASSWORD:-}}" |
|
71 |
fi |
|
72 |
: "${WORDPRESS_DB_NAME:=${MYSQL_ENV_MYSQL_DATABASE:-}}" |
|
73 |
fi |
|
74 |
||
75 |
# linking backwards-compatibility |
|
76 |
if [ -n "${!MYSQL_ENV_MYSQL_*}" ]; then |
|
77 |
haveConfig=1 |
|
78 |
# host defaults to "mysql" below if unspecified |
|
79 |
: "${WORDPRESS_DB_USER:=${MYSQL_ENV_MYSQL_USER:-root}}" |
|
80 |
if [ "$WORDPRESS_DB_USER" = 'root' ]; then |
|
81 |
: "${WORDPRESS_DB_PASSWORD:=${MYSQL_ENV_MYSQL_ROOT_PASSWORD:-}}" |
|
82 |
else |
|
83 |
: "${WORDPRESS_DB_PASSWORD:=${MYSQL_ENV_MYSQL_PASSWORD:-}}" |
|
84 |
fi |
|
85 |
: "${WORDPRESS_DB_NAME:=${MYSQL_ENV_MYSQL_DATABASE:-}}" |
|
86 |
fi |
|
87 |
||
88 |
: "${WORDPRESS_DB_HOST:=mysql}" |
|
89 |
: "${WORDPRESS_DB_USER:=root}" |
|
90 |
: "${WORDPRESS_DB_PASSWORD:=}" |
|
91 |
: "${WORDPRESS_DB_NAME:=wordpress}" |
|
92 |
: "${WORDPRESS_DB_CHARSET:=utf8}" |
|
93 |
: "${WORDPRESS_DB_COLLATE:=}" |
|
94 |
||
95 |
# Wait |
|
96 |
||
|
3
d7dec707cbee
Add silent flag to mysql cli command
ymh <ymh.work@gmail.com>
parents:
1
diff
changeset
|
97 |
until mysql -s -h ${WORDPRESS_DB_HOST} -u ${WORDPRESS_DB_USER} -p${WORDPRESS_DB_PASSWORD} -e"quit" ${WORDPRESS_DB_NAME}; do |
| 1 | 98 |
>&2 echo "Mysql is unavailable - sleeping" |
99 |
sleep 1 |
|
100 |
done |
|
101 |
||
102 |
>&2 echo "Mysql is up - proceeding" |
|
103 |
||
| 0 | 104 |
if [[ "$1" == apache2* ]] || [ "$1" == php-fpm ]; then |
105 |
if [ "$(id -u)" = '0' ]; then |
|
106 |
case "$1" in |
|
107 |
apache2*) |
|
108 |
user="${APACHE_RUN_USER:-www-data}" |
|
109 |
group="${APACHE_RUN_GROUP:-www-data}" |
|
110 |
||
111 |
# strip off any '#' symbol ('#1000' is valid syntax for Apache) |
|
112 |
pound='#' |
|
113 |
user="${user#$pound}" |
|
114 |
group="${group#$pound}" |
|
115 |
;; |
|
116 |
*) # php-fpm |
|
117 |
user='www-data' |
|
118 |
group='www-data' |
|
119 |
;; |
|
120 |
esac |
|
121 |
else |
|
122 |
user="$(id -u)" |
|
123 |
group="$(id -g)" |
|
124 |
fi |
|
125 |
||
126 |
# TODO : create .env file if needed |
|
127 |
if [ ! -e .env ] && [ "$haveConfig" ]; then |
|
128 |
cat > .env <<-EOF |
|
129 |
DB_NAME=${WORDPRESS_DB_NAME} |
|
130 |
DB_USER=${WORDPRESS_DB_USER} |
|
131 |
DB_PASSWORD=${WORDPRESS_DB_PASSWORD} |
|
132 |
DB_HOST=db:3306 |
|
| 7 | 133 |
WP_HOME=http://recherchecontributive.test:8080 |
| 0 | 134 |
|
135 |
WP_SITEURL=\${WP_HOME}/wp |
|
136 |
WP_ENV=development |
|
137 |
|
|
138 |
AUTH_KEY='$(generate_rnd)' |
|
139 |
SECURE_AUTH_KEY='$(generate_rnd)' |
|
140 |
LOGGED_IN_KEY='$(generate_rnd)' |
|
141 |
NONCE_KEY='$(generate_rnd)' |
|
142 |
AUTH_SALT='$(generate_rnd)' |
|
143 |
SECURE_AUTH_SALT='$(generate_rnd)' |
|
144 |
LOGGED_IN_SALT='$(generate_rnd)' |
|
145 |
NONCE_SALT='$(generate_rnd)' |
|
146 |
EOF |
|
147 |
||
148 |
||
149 |
chown "$user:$group" .env |
|
150 |
||
151 |
||
152 |
if ! TERM=dumb php -- <<'EOPHP' |
|
153 |
<?php |
|
154 |
// database might not exist, so let's try creating it (just to be safe) |
|
155 |
||
156 |
$stderr = fopen('php://stderr', 'w'); |
|
157 |
||
158 |
// https://codex.wordpress.org/Editing_wp-config.php#MySQL_Alternate_Port |
|
159 |
// "hostname:port" |
|
160 |
// https://codex.wordpress.org/Editing_wp-config.php#MySQL_Sockets_or_Pipes |
|
161 |
// "hostname:unix-socket-path" |
|
162 |
list($host, $socket) = explode(':', getenv('WORDPRESS_DB_HOST'), 2); |
|
163 |
$port = 0; |
|
164 |
if (is_numeric($socket)) { |
|
165 |
$port = (int) $socket; |
|
166 |
$socket = null; |
|
167 |
} |
|
168 |
$user = getenv('WORDPRESS_DB_USER'); |
|
169 |
$pass = getenv('WORDPRESS_DB_PASSWORD'); |
|
170 |
$dbName = getenv('WORDPRESS_DB_NAME'); |
|
171 |
||
172 |
$maxTries = 10; |
|
173 |
do { |
|
174 |
$mysql = new mysqli($host, $user, $pass, '', $port, $socket); |
|
175 |
if ($mysql->connect_error) { |
|
176 |
fwrite($stderr, "\n" . 'MySQL Connection Error: (' . $mysql->connect_errno . ') ' . $mysql->connect_error . "\n"); |
|
177 |
--$maxTries; |
|
178 |
if ($maxTries <= 0) { |
|
179 |
exit(1); |
|
180 |
} |
|
181 |
sleep(3); |
|
182 |
} |
|
183 |
} while ($mysql->connect_error); |
|
184 |
||
185 |
if (!$mysql->query('CREATE DATABASE IF NOT EXISTS `' . $mysql->real_escape_string($dbName) . '`')) { |
|
186 |
fwrite($stderr, "\n" . 'MySQL "CREATE DATABASE" Error: ' . $mysql->error . "\n"); |
|
187 |
$mysql->close(); |
|
188 |
exit(1); |
|
189 |
} |
|
190 |
||
191 |
$mysql->close(); |
|
192 |
EOPHP |
|
193 |
then |
|
194 |
echo >&2 |
|
195 |
echo >&2 "WARNING: unable to establish a database connection to '$WORDPRESS_DB_HOST'" |
|
196 |
echo >&2 ' continuing anyways (which might have unexpected results)' |
|
197 |
echo >&2 |
|
198 |
fi |
|
199 |
fi |
|
200 |
||
201 |
# now that we're definitely done writing configuration, let's clear out the relevant envrionment variables (so that stray "phpinfo()" calls don't leak secrets from our code) |
|
202 |
for e in "${envs[@]}"; do |
|
203 |
unset "$e" |
|
204 |
done |
|
205 |
fi |
|
206 |
||
|
4
f0b7075b9496
Always launch composer install and add composer plugin prestissomo to speed up install
ymh <ymh.work@gmail.com>
parents:
3
diff
changeset
|
207 |
# Always lauch composer to install or update dependencies |
|
f0b7075b9496
Always launch composer install and add composer plugin prestissomo to speed up install
ymh <ymh.work@gmail.com>
parents:
3
diff
changeset
|
208 |
composer --no-interaction install |
| 0 | 209 |
|
210 |
# first arg is `-f` or `--some-option` |
|
211 |
if [ "${1#-}" != "$1" ]; then |
|
212 |
set -- composer exec wp "$@" |
|
213 |
fi |
|
214 |
||
215 |
# if our command is a valid wp-cli subcommand, let's invoke it through wp-cli instead |
|
216 |
# (this allows for "docker run wordpress:cli help", etc) |
|
217 |
if composer exec wp --path=/dev/null help "$1" > /dev/null 2>&1; then |
|
218 |
set -- composer exec wp "$@" |
|
219 |
fi |
|
220 |
||
221 |
||
222 |
exec "$@" |