You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
97 lines
3.7 KiB
97 lines
3.7 KiB
FROM ruby:2.6-stretch AS pgloader
|
|
RUN apt-get update -qq && apt-get install -y libsqlite3-dev make curl gawk freetds-dev libzip-dev
|
|
COPY docker/mysql-to-postgres/bin/build /tmp/build-pgloader
|
|
RUN /tmp/build-pgloader && rm /tmp/build-pgloader
|
|
|
|
FROM ruby:2.6-stretch
|
|
MAINTAINER operations@openproject.com
|
|
|
|
ENV NODE_VERSION "10.15.0"
|
|
ENV BUNDLER_VERSION "2.0.2"
|
|
ENV BUNDLE_PATH__SYSTEM=false
|
|
ENV APP_USER app
|
|
ENV APP_PATH /app
|
|
ENV APP_DATA_PATH /var/openproject/assets
|
|
ENV APP_DATA_PATH_LEGACY /var/db/openproject
|
|
ENV PGDATA /var/openproject/pgdata
|
|
ENV PGDATA_LEGACY /var/lib/postgresql/9.6/main
|
|
|
|
ENV DATABASE_URL postgres://openproject:openproject@127.0.0.1/openproject
|
|
ENV RAILS_ENV production
|
|
ENV HEROKU true
|
|
ENV RAILS_CACHE_STORE memcache
|
|
ENV OPENPROJECT_INSTALLATION__TYPE docker
|
|
ENV NEW_RELIC_AGENT_ENABLED false
|
|
ENV ATTACHMENTS_STORAGE_PATH $APP_DATA_PATH/files
|
|
# Set a default key base, ensure to provide a secure value in production environments!
|
|
ENV SECRET_KEY_BASE OVERWRITE_ME
|
|
|
|
COPY --from=pgloader /usr/local/bin/pgloader-ccl /usr/local/bin/
|
|
|
|
# install node + npm
|
|
RUN curl https://nodejs.org/dist/v${NODE_VERSION}/node-v${NODE_VERSION}-linux-x64.tar.gz | tar xzf - -C /usr/local --strip-components=1
|
|
|
|
RUN apt-get update -qq && \
|
|
DEBIAN_FRONTEND=noninteractive apt-get install -y \
|
|
postgresql-client \
|
|
poppler-utils \
|
|
unrtf \
|
|
tesseract-ocr \
|
|
catdoc \
|
|
memcached \
|
|
postfix \
|
|
postgresql \
|
|
apache2 \
|
|
supervisor && \
|
|
apt-get clean && rm -rf /var/lib/apt/lists/*
|
|
|
|
# Set up pg defaults
|
|
RUN echo "host all all 0.0.0.0/0 md5" >> /etc/postgresql/9.6/main/pg_hba.conf
|
|
RUN echo "listen_addresses='*'" >> /etc/postgresql/9.6/main/postgresql.conf
|
|
RUN echo "data_directory='$PGDATA'" >> /etc/postgresql/9.6/main/postgresql.conf
|
|
RUN rm -rf "$PGDATA_LEGACY" && rm -rf "$PGDATA" && mkdir -p "$PGDATA" && chown -R postgres:postgres "$PGDATA"
|
|
RUN a2enmod proxy proxy_http && rm -f /etc/apache2/sites-enabled/000-default.conf
|
|
|
|
# using /home/app since npm cache and other stuff will be put there when running npm install
|
|
# we don't want to pollute any locally-mounted directory
|
|
RUN useradd -d /home/$APP_USER -m $APP_USER
|
|
|
|
WORKDIR $APP_PATH
|
|
RUN gem install bundler --version "${bundler_version}" --no-document
|
|
|
|
COPY Gemfile ./Gemfile
|
|
COPY Gemfile.* ./
|
|
COPY modules ./modules
|
|
# OpenProject::Version is required by module versions in gemspecs
|
|
RUN mkdir -p lib/open_project
|
|
COPY lib/open_project/version.rb ./lib/open_project/
|
|
RUN bundle install --deployment --path vendor/bundle --no-cache \
|
|
--with="docker opf_plugins" --without="test development" --jobs=8 --retry=3 && \
|
|
rm -rf vendor/bundle/ruby/*/cache && rm -rf vendor/bundle/ruby/*/gems/*/spec && rm -rf vendor/bundle/ruby/*/gems/*/test
|
|
|
|
# Finally, copy over the whole thing
|
|
COPY . .
|
|
|
|
# Re-use packager database.yml
|
|
RUN cp ./packaging/conf/database.yml ./config/database.yml
|
|
# Add MySQL-to-Postgres migration script to path (used in entrypoint.sh)
|
|
RUN cp ./docker/mysql-to-postgres/bin/migrate-mysql-to-postgres /usr/local/bin/
|
|
# Ensure OpenProject starts with the docker group of gems
|
|
RUN sed -i "s|Rails.groups(:opf_plugins)|Rails.groups(:opf_plugins, :docker)|" config/application.rb
|
|
# Ensure we can write in /tmp/op_uploaded_files (cf. #29112)
|
|
RUN mkdir -p /tmp/op_uploaded_files/ && chown -R $APP_USER:$APP_USER /tmp/op_uploaded_files/
|
|
|
|
# Handle the assets precompilation
|
|
RUN bash docker/precompile-assets.sh
|
|
|
|
# Expose ports for apache and postgres
|
|
EXPOSE 80 5432
|
|
|
|
# Expose the postgres data directory and OpenProject data directory as volumes
|
|
VOLUME ["$PGDATA", "$APP_DATA_PATH"]
|
|
|
|
# Set a custom entrypoint to allow for privilege dropping and one-off commands
|
|
ENTRYPOINT ["./docker/entrypoint.sh"]
|
|
|
|
# Set default command to launch the all-in-one configuration supervised by supervisord
|
|
CMD ["./docker/supervisord"]
|
|
|