# ----------------------------------------------------------------------------- # docker-pinry # # Builds a basic docker image that can run Pinry (http://getpinry.com) and serve # all of it's assets, there are more optimal ways to do this but this is the # most friendly and has everything contained in a single instance. # # Authors: Isaac Bythewood # Updated: Mar 29th, 2016 # Require: Docker (http://www.docker.io/) # ----------------------------------------------------------------------------- # Base system is the LTS version of Ubuntu. FROM python:3.7-stretch RUN groupadd -g 2300 tmpgroup \ && usermod -g tmpgroup www-data \ && groupdel www-data \ && groupadd -g 1000 www-data \ && usermod -g www-data www-data \ && usermod -u 1000 www-data \ && groupdel tmpgroup RUN mkdir /data RUN chown -R www-data:www-data /data RUN apt-get update \ && apt-get -y install nginx nginx-extras pwgen \ && rm -rf /var/lib/apt/lists/* \ && apt-get autoclean # required for other database options RUN pip --no-cache-dir install pipenv gunicorn mysqlclient psycopg2 cx-Oracle # COPY and start installation COPY . /pinry RUN cd /pinry \ && pipenv install --three --system --clear # config nodejs RUN curl -L https://raw.githubusercontent.com/tj/n/master/bin/n -o n || exit RUN bash n 10 RUN npm -g install yarn # build frontend RUN cd /pinry/pinry-spa/ && yarn install && yarn build # Load in all of our config files. ADD docker/nginx/nginx.conf /etc/nginx/nginx.conf ADD docker/nginx/sites-enabled/default /etc/nginx/sites-enabled/default # 80 is for nginx web, /data contains static files and database /start runs it. EXPOSE 80 VOLUME ["/data"] CMD ["/pinry/docker/scripts/start.sh"]