FROM debian:trixie ARG MOODLE_DATABASE_ROOT_PASSWORD ARG MOODLE_DATABASE_NAME ARG MOODLE_DATABASE_USER ARG MOODLE_DATABASE_PASSWORD ARG MOODLE_DATABASE_HOST ARG MOODLE_BASE_DIR ARG MOODLE_BASE_DIR_DATA ENV MOODLE_DATABASE_ROOT_PASSWORD ${MOODLE_DATABASE_ROOT_PASSWORD} ENV MOODLE_DATABASE_NAME ${MOODLE_DATABASE_NAME} ENV MOODLE_DATABASE_USER ${MOODLE_DATABASE_USER} ENV MOODLE_DATABASE_PASSWORD ${MOODLE_DATABASE_PASSWORD} ENV MOODLE_DATABASE_HOST ${MOODLE_DATABASE_HOST} ENV MOODLE_BASE_DIR ${MOODLE_BASE_DIR} ENV MOODLE_BASE_DIR_DATA ${MOODLE_BASE_DIR_DATA} # Installing necessary packages RUN apt-get update && apt-get upgrade -y && \ apt-get install -y apache2 php libapache2-mod-php php-mysqli php-mysql php-xml php-pdo php-pdo-mysql mariadb-client mariadb-server wget unzip p7zip-full iputils-ping php-mbstring graphviz aspell ghostscript clamav php8.2-pspell php8.2-curl php8.2-gd php8.2-intl php8.2-mysql php8.2-xml php8.2-xmlrpc php8.2-ldap php8.2-zip php8.2-soap php8.2-mbstring openssl git nano supervisor php-xdebug && \ apt-get clean && rm -rf /var/lib/apt/lists/* # Setting necessary php params #RUN echo "mysql.default_socket=/run/mysqld/mysqld.sock" >> /etc/php/8.2/cli/php.ini RUN echo "mysql.default_socket=/run/mysqld/mysqld.sock" >> /etc/php/8.2/apache2/php.ini RUN echo "max_input_vars = 5000" >> /etc/php/8.2/apache2/php.ini RUN echo "max_input_vars = 5000" >> /etc/php/8.2/cli/php.ini # Setting Xdebug #RUN echo "zend_extension=xdebug.so" >> /etc/php/8.2/apache2/php.ini #RUN echo "xdebug.mode=debug" >> /etc/php/8.2/apache2/php.ini #RUN echo "xdebug.start_with_request=yes" >> /etc/php/8.2/apache2/php.ini #RUN echo "xdebug.client_host=host.docker.internal" >> /etc/php/8.2/apache2/php.ini #RUN echo "xdebug.client_port=9003" >> /etc/php/8.2/apache2/php.ini RUN chmod 1777 /tmp # Installing Moodle Setting correct acces rules #RUN cd /var/www/html && mkdir -p moodle #RUN mkdir -p ${MOODLE_BASE_DIR} RUN echo ${MOODLE_BASE_DIR} RUN mkdir -p /var/www/html/moodle WORKDIR ${MOODLE_BASE_DIR} #RUN #mkdir -p ${MOODLE_BASE_DIR} && \ RUN wget -qO- https://packaging.moodle.org/stable403/moodle-4.3.4.tgz | tar xz -C ${MOODLE_BASE_DIR} --strip-components=1 #RUN wget -qO- https://packaging.moodle.org/stable403/moodle-4.3.4.tgz | tar xz --strip-components=1 -C /var/www/html/moodle RUN chown -R www-data:www-data ${MOODLE_BASE_DIR} && \ find ${MOODLE_BASE_DIR} -type d -exec chmod 755 {} \; && \ find ${MOODLE_BASE_DIR} -type f -exec chmod 644 {} \; && \ mkdir -p ${MOODLE_BASE_DIR_DATA} && \ chown -R www-data:www-data ${MOODLE_BASE_DIR_DATA} && \ chmod -R 755 ${MOODLE_BASE_DIR_DATA} # Copying of beeing developed Plugin COPY asystgrade ${MOODLE_BASE_DIR}/local/asystgrade # Setting correct acces rules for Plugin #RUN chown -R www-data:www-data ${MOODLE_BASE_DIR}/local/asystgrade && \ RUN chmod -R 755 ${MOODLE_BASE_DIR}/local/asystgrade # Making Symlink for MariaDB Socket RUN ln -s /run/mysqld/mysqld.sock /tmp/mysql.sock RUN echo "ServerName modhost" >> /etc/apache2/apache2.conf # Apache Settings for HTTP RUN echo \ "\n" \ "ServerName www.moodle.loc\n" \ "ServerAlias www.moodle.loc\n" \ "DocumentRoot ${MOODLE_BASE_DIR}\n" \ "\n" \ " Options +FollowSymlinks\n" \ " AllowOverride All\n" \ " Require all granted\n" \ "\n" \ "\n" \ "ErrorLog /var/log/apache2/error.log\n" \ "CustomLog /var/log/apache2/access.log combined\n" \ # "RewriteEngine On\n" \ # "RewriteCond %{HTTPS} !=on\n" \ # "RewriteRule ^/?(.*) https://%{SERVER_NAME}/$1 [R,L]\n" \ > /etc/apache2/sites-enabled/000-default.conf # Setting Apache RUN a2enmod rewrite # Generate a self-signed SSL certificate (replace example.com with your domain) RUN openssl req -x509 -nodes -days 365 -newkey rsa:2048 \ -keyout /etc/ssl/private/apache-selfsigned.key \ -out /etc/ssl/certs/apache-selfsigned.crt \ -subj "/C=EU/ST=Berlin/L=Berlin/O=HFT/CN=www.moodle.loc" # Configure SSL virtual host RUN echo \ "\n" \ "ServerName www.moodle.loc\n" \ "ServerAlias www.moodle.loc\n" \ "DocumentRoot ${MOODLE_BASE_DIR}\n" \ "\n" \ " Options +FollowSymlinks\n" \ " AllowOverride All\n" \ " Require all granted\n" \ "\n" \ "SSLEngine on\n" \ "SSLCertificateFile /etc/ssl/certs/apache-selfsigned.crt\n" \ "SSLCertificateKeyFile /etc/ssl/private/apache-selfsigned.key\n" \ "ErrorLog /var/log/apache2/error.log\n" \ "CustomLog /var/log/apache2/access.log combined\n" \ "\n" \ > /etc/apache2/sites-enabled/default-ssl.conf # Opening 000-default.conf for edit RUN sed -i '/<\/VirtualHost>/i \ RewriteEngine On \n\ RewriteCond %{SERVER_PORT} 80 \n\ RewriteRule ^(.*)$ https://www.moodle.loc/$1 [R,L] \n\ ' /etc/apache2/sites-enabled/000-default.conf # Enable SSL module in Apache RUN a2enmod ssl # Adding entry to /etc/hosts #RUN echo "127.0.0.1 ${MOODLE_WWWROOT##https://}" >> /etc/hosts #Opening ports #EXPOSE 80 443 5000 EXPOSE 80 443 # Running supervisord CMD ["apache2ctl", "-D", "FOREGROUND"]