mirror of
https://github.com/snipe/snipe-it.git
synced 2024-11-13 17:14:10 -08:00
6783dc1312
Fixes #12299, where currently there is no recursive permissions set on /var/www/html/storage/ during build time. As a result this requires users to run an exec into the container and change the permissions before they are able to initiate the setup. Without this a 500 error is thrown and little is evident in the docker logs as to what the issue is.
145 lines
4.3 KiB
Docker
145 lines
4.3 KiB
Docker
FROM ubuntu:22.04
|
|
LABEL maintainer="Brady Wetherington <bwetherington@grokability.com>"
|
|
|
|
# No need to add `apt-get clean` here, reference:
|
|
# - https://github.com/snipe/snipe-it/pull/9201
|
|
# - https://docs.docker.com/develop/develop-images/dockerfile_best-practices/#apt-get
|
|
|
|
RUN export DEBIAN_FRONTEND=noninteractive; \
|
|
export DEBCONF_NONINTERACTIVE_SEEN=true; \
|
|
echo 'tzdata tzdata/Areas select Etc' | debconf-set-selections; \
|
|
echo 'tzdata tzdata/Zones/Etc select UTC' | debconf-set-selections; \
|
|
apt-get update -qqy \
|
|
&& apt-get install -qqy --no-install-recommends \
|
|
apt-utils \
|
|
apache2 \
|
|
apache2-bin \
|
|
libapache2-mod-php8.1 \
|
|
php8.1-curl \
|
|
php8.1-ldap \
|
|
php8.1-mysql \
|
|
php8.1-gd \
|
|
php8.1-xml \
|
|
php8.1-mbstring \
|
|
php8.1-zip \
|
|
php8.1-bcmath \
|
|
php8.1-redis \
|
|
php-memcached \
|
|
patch \
|
|
curl \
|
|
wget \
|
|
vim \
|
|
git \
|
|
cron \
|
|
mysql-client \
|
|
supervisor \
|
|
cron \
|
|
gcc \
|
|
make \
|
|
autoconf \
|
|
libc-dev \
|
|
libldap-common \
|
|
pkg-config \
|
|
libmcrypt-dev \
|
|
php8.1-dev \
|
|
ca-certificates \
|
|
unzip \
|
|
dnsutils \
|
|
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
|
|
|
|
|
RUN curl -L -O https://github.com/pear/pearweb_phars/raw/master/go-pear.phar
|
|
RUN php go-pear.phar
|
|
|
|
RUN pecl install mcrypt
|
|
|
|
RUN bash -c "echo extension=/usr/lib/php/20210902/mcrypt.so > /etc/php/8.1/mods-available/mcrypt.ini"
|
|
|
|
RUN phpenmod mcrypt
|
|
RUN phpenmod gd
|
|
RUN phpenmod bcmath
|
|
|
|
RUN sed -i 's/variables_order = .*/variables_order = "EGPCS"/' /etc/php/8.1/apache2/php.ini
|
|
RUN sed -i 's/variables_order = .*/variables_order = "EGPCS"/' /etc/php/8.1/cli/php.ini
|
|
|
|
RUN useradd -m --uid 1000 --gid 50 docker
|
|
|
|
RUN echo export APACHE_RUN_USER=docker >> /etc/apache2/envvars
|
|
RUN echo export APACHE_RUN_GROUP=staff >> /etc/apache2/envvars
|
|
|
|
COPY docker/000-default.conf /etc/apache2/sites-enabled/000-default.conf
|
|
|
|
#SSL
|
|
RUN mkdir -p /var/lib/snipeit/ssl
|
|
#COPY docker/001-default-ssl.conf /etc/apache2/sites-enabled/001-default-ssl.conf
|
|
COPY docker/001-default-ssl.conf /etc/apache2/sites-available/001-default-ssl.conf
|
|
|
|
RUN a2enmod ssl
|
|
RUN a2ensite 001-default-ssl.conf
|
|
|
|
COPY . /var/www/html
|
|
|
|
RUN a2enmod rewrite
|
|
|
|
COPY docker/column-statistics.cnf /etc/mysql/conf.d/column-statistics.cnf
|
|
|
|
############ INITIAL APPLICATION SETUP #####################
|
|
|
|
WORKDIR /var/www/html
|
|
|
|
#Append to bootstrap file (less brittle than 'patch')
|
|
# RUN sed -i 's/return $app;/$env="production";\nreturn $app;/' bootstrap/start.php
|
|
|
|
#copy all configuration files
|
|
# COPY docker/*.php /var/www/html/app/config/production/
|
|
COPY docker/docker.env /var/www/html/.env
|
|
|
|
RUN chown -R docker /var/www/html
|
|
|
|
RUN \
|
|
rm -r "/var/www/html/storage/private_uploads" && ln -fs "/var/lib/snipeit/data/private_uploads" "/var/www/html/storage/private_uploads" \
|
|
&& rm -rf "/var/www/html/public/uploads" && ln -fs "/var/lib/snipeit/data/uploads" "/var/www/html/public/uploads" \
|
|
&& rm -r "/var/www/html/storage/app/backups" && ln -fs "/var/lib/snipeit/dumps" "/var/www/html/storage/app/backups" \
|
|
&& mkdir -p "/var/lib/snipeit/keys" && ln -fs "/var/lib/snipeit/keys/oauth-private.key" "/var/www/html/storage/oauth-private.key" \
|
|
&& ln -fs "/var/lib/snipeit/keys/oauth-public.key" "/var/www/html/storage/oauth-public.key" \
|
|
&& ln -fs "/var/lib/snipeit/keys/ldap_client_tls.cert" "/var/www/html/storage/ldap_client_tls.cert" \
|
|
&& ln -fs "/var/lib/snipeit/keys/ldap_client_tls.key" "/var/www/html/storage/ldap_client_tls.key" \
|
|
&& chown docker "/var/lib/snipeit/keys/" \
|
|
&& chown -Rh docker "/var/www/html/storage/" \
|
|
&& chmod +x /var/www/html/artisan \
|
|
&& echo "Finished setting up application in /var/www/html"
|
|
|
|
############## DEPENDENCIES via COMPOSER ###################
|
|
|
|
#global install of composer
|
|
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
|
|
|
|
# Get dependencies
|
|
USER docker
|
|
RUN composer install --no-dev --working-dir=/var/www/html
|
|
USER root
|
|
|
|
############### APPLICATION INSTALL/INIT #################
|
|
|
|
#RUN php artisan app:install
|
|
# too interactive! Try something else
|
|
|
|
#COPY docker/app_install.exp /tmp/app_install.exp
|
|
#RUN chmod +x /tmp/app_install.exp
|
|
#RUN /tmp/app_install.exp
|
|
|
|
############### DATA VOLUME #################
|
|
|
|
VOLUME ["/var/lib/snipeit"]
|
|
|
|
##### START SERVER
|
|
|
|
COPY docker/startup.sh docker/supervisord.conf /
|
|
COPY docker/supervisor-exit-event-listener /usr/bin/supervisor-exit-event-listener
|
|
RUN chmod +x /startup.sh /usr/bin/supervisor-exit-event-listener
|
|
|
|
CMD ["/startup.sh"]
|
|
|
|
EXPOSE 80
|
|
EXPOSE 443
|