indentlabs/notebook

View on GitHub
Dockerfile

Summary

Maintainability
Test Coverage
# HEADS UP!
# This Dockerfile is for DEVELOPMENT use only;
# it's in no way optimized for production and is largely maintained by
# the open source community for convenience. Installing the full stack
# manually is the preferred setup for Notebook.ai instances.

# The image to build from.
FROM ruby:3.2.1

# Properties/labels for the image.
LABEL maintainer="Notebook.ai Contributors"

# Development ENV by default, but overridable with RAILS_ENV
ARG RAILS_ENV=development
ENV RAILS_ENV=${RAILS_ENV}

# Copy the current folder into the notebookai user's home directory.
COPY . /home/notebookai

# Set the notebookai user's home directory as the working directory.
WORKDIR /home/notebookai

# Create the notebookai user and group
RUN groupadd --system --gid 1000 notebookai && \
    useradd --system --home-dir /home/notebookai --gid notebookai --uid 1000 --shell /bin/bash notebookai

# Install system dependencies
RUN curl -sL https://deb.nodesource.com/setup_16.x | bash - && \
    apt-get update -qq && \
    apt-get install -y build-essential libpq-dev nodejs imagemagick libmagickwand-dev curl && \
    rm --recursive --force /var/lib/apt/lists/*

# Install yarn
RUN curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - && \
    echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list && \
    apt-get update && \
    apt-get install -y yarn

# Install app dependencies, compile assets, and set up the database
RUN bundle install && \
    yarn install && \
    if [ "$RAILS_ENV" = "development" ] ; then \
        echo "Starting webpack-dev-server..." && \
        bin/webpack-dev-server & \
    else \
        echo "Compiling webpack assets..." && \
        rails webpacker:compile ; \
    fi && \
    rails db:setup && \
    rake db:migrate && \
    rm -f tmp/pids/server.pid

# This image should expose the port 3000.
# This does not actually expose the port, you'll have to expose it yourself by
# using `-p 3000:3000/tcp` in Docker's CLI or `- "3000:3000"` in the in docker-compose.yml service's ports[].
# https://docs.docker.com/engine/reference/builder/#expose
#EXPOSE 3000/tcp

# This image should expose port 3000.
EXPOSE 3000/tcp

# Finally, start the server using Puma!
CMD bundle exec puma -C config/puma.rb -e ${RAILS_ENV} -b tcp://0.0.0.0:3000

# And run it with
# docker run --name nb-webserver -p 80:3000 -d notebookai