Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added alpine based dockerfile and mysql database setup via docker run… #940

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

gyurix1968
Copy link

A modification has been made during container image creation, allowing for a significantly smaller Docker image to be generated from the source by utilizing the new file (Dockerfile.alpine).

The application's startup script has been adjusted to enable the specification of the Docker runtime, including the first (admin) user's name and corresponding password (via the ADMIN_NAME and ADMIN_PASSWORD variables). Simultaneously, database initialization has been automated (currently supporting only MySQL databases) through the invocation of a separate script. This script checks whether the database server is accessible and if a database has already been created.

Copy link
Contributor

@mike-jumper mike-jumper left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please also see our contribution guidelines. In particular, every change needs a corresponding JIRA issue, and that JIRA issue needs to be included in each commit message (see established git history for the formatting convention we use for this).

Comment on lines +565 to +569
"$SQLSERVERQL_AUTO_CREATE_ACCOUNTS"

set_optional_property \
"sqlserver-instance" \
"$SQLSERVER_INSTANCE"
"$SQLSERVERQL_INSTANCE"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why were these renamed?

echo "RESPONSE: $RESPONSE";
if [ "$RESPONSE" == "" ]; then
if [[ $retries -le $RETRIES ]] ; then
echo "Retired $retries";
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What do you mean by "retired"?

Comment on lines +59 to +90
# Check database access
for retries in $(seq 0 $((RETRIES+ 1))); do
RESPONSE=$(echo "exit" | timeout $SLEEP_SHORT telnet $DB_HOST $DB_PORT|grep Connected);
echo "RESPONSE: $RESPONSE";
if [ "$RESPONSE" == "" ]; then
if [[ $retries -le $RETRIES ]] ; then
echo "Retired $retries";
echo "Expected $DB_HOST currently not available, wait $SLEEP_SHORT seconds.";
sleep $SLEEP_SHORT;
else
for retries2 in $(seq 0 $((RETRIES+ 1))); do
RESPONSE=$(echo "exit" | timeout $SLEEP_SHORT telnet $DB_HOST $DB_PORT|grep Connected);
if [ "$RESPONSE" == "" ]; then
if [[ $retries2 -le $RETRIES ]] ; then
echo "Retired $retries2";
echo "Expected $DB_HOST currently not available, wait $SLEEP_LONG seconds.";
sleep $SLEEP_LONG;
else
echo "Expected $DB_HOST currently not available, and reached all reries limit, exiting";
exit 1;
fi
else
echo "Expected $DB_HOST accessed successfuly, continue database init processes."
break;
fi
done
fi
else
echo "Expected $DB_HOST accessed successfuly, continue database init processes."
break;
fi
done
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. The logic here feels overcomplicated for what it is intended to achieve (wait for the database to come up). Why so many nested loops and layers of retrying?
  2. I'm on the fence on building this functionality into the Docker image. Perhaps adding automatic initialization into the database support within the webapp itself would make more sense? That would also allow for automatic application of schema updates while maintaining separation of concerns.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps adding automatic initialization into the database support within the webapp itself would make more sense?

+1

Comment on lines +35 to +56
if [[ "$MYSQL_USER" != "" && "$MYSQL_PASSWORD" != "" && "$MYSQL_DATABASE" != "" && "$MYSQL_HOSTNAME" != "" ]]; then

if [ "$MYSQL_PORT" == "" ]; then
DB_PORT=3306;
else
DB_PORT=$MYSQL_PORT;
fi

DB_HOST=$MYSQL_HOSTNAME;
DB_NAME=$MYSQL_DATABASE;
DB_USER=$MYSQL_USER;
DB_PASSWORD=$MYSQL_PASSWORD;
DB_ENGINE="/usr/bin/mariadb"


UUID=$(openssl rand -hex 16)
SALT=$(echo ${UUID:0:8}-${UUID:8:4}-${UUID:12:4}-${UUID:16:4}-${UUID:20:12} | openssl sha256 -hex | awk '{print toupper($2)}');
HASH=$(echo -n "$ADMIN_PASSWORD$SALT" | openssl sha256 -hex | awk '{print toupper($2)}')
cp /opt/guacamole/mysql/schema/*.sql /tmp/
sed -i "s/guacadmin/$ADMIN_NAME/g" /tmp/002-create-admin-user.sql
sed -i "s/FE24ADC5E11E2B25288D1704ABE67A79E342ECC26064CE69C5B3177795A82264/$SALT/" /tmp/002-create-admin-user.sql
sed -i "s/CA458A7D494E3BE824F5E1E175A1556C0F8EEF2C2D7DF3633BEC4A29C4411960/$HASH/" /tmp/002-create-admin-user.sql
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This would need to be implemented for each supported database, not just MySQL/MariaDB.

Comment on lines +23 to +33
if [ "$SLEEP_SHORT" == "" ]; then
SLEEP_SHORT=5
fi

if [ "$SLEEP_LONG" == "" ]; then
SLEEP_LONG=10
fi

if [ "$RETRIES" == "" ]; then
RETRIES=5
fi
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If new environment variables are to be supported by this image, the naming should be more specific. SLEEP_SHORT, SLEEP_LONG, and RETRIES are too broad.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why a second Dockerfile vs. modifying the existing Dockerfile?

Comment on lines +92 to +100
for i in $(ls /tmp/*.sql); do
CREATE_DATABASE=$($DB_ENGINE -u $DB_USER -p$DB_PASSWORD $DB_NAME -h $DB_HOST --port $DB_PORT < $i);
if [[ "$(echo $?)" == "1" ]]; then
echo "Database already exists";
exit 2;
else
echo "Database automaticaly initialized." ;
fi
done
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is dangerous. Should a user ever manage to write a file to /tmp with a .sql extension, that file would be automatically run at subsequent startup as a privileged database user. Merely writing files to /tmp is not a privileged operation, so this would be privilege escalation.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
3 participants