-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
81 lines (62 loc) · 1.9 KB
/
Dockerfile
File metadata and controls
81 lines (62 loc) · 1.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
FROM harbor.k8s.libraries.psu.edu/library/ruby-3.4.1-node-22:20260202 AS base
ARG UID=3000
USER root
RUN apt-get update && \
apt-get install --no-install-recommends -y \
libmariadb-dev \
mariadb-client && \
rm -rf /var/lib/apt/lists*
WORKDIR /app
RUN useradd -u $UID app -d /app
RUN mkdir /app/tmp
RUN mkdir /tmp/app/
RUN chown app:app /tmp/app && chmod 755 /tmp/app
COPY Gemfile Gemfile.lock /app/
COPY . .
RUN chown -R app:app /app
USER app
# in the event that bundler runs outside of docker, we get in sync with it's bundler version
RUN gem install bundler -v "$(grep -A 1 "BUNDLED WITH" Gemfile.lock | tail -n 1)"
RUN bundle config set path 'vendor/bundle'
RUN bundle install && \
rm -rf /app/.bundle/cache && \
rm -rf /app/vendor/bundle/ruby/*/cache
COPY package.json yarn.lock /app/
RUN yarn install --frozen-lockfile && \
rm -rf /app/.cache && \
rm -rf /app/tmp
COPY --chown=app . /app
RUN mkdir -p tmp/uploads && chown -R app:app tmp/uploads
FROM base AS dev-worker
ENTRYPOINT ["entrypoints/dev-worker.sh"]
FROM base AS dev-mock-remediation-tool
ENTRYPOINT ["entrypoints/dev-mock-remediation-tool.sh"]
FROM base AS dev
USER root
RUN apt-get update && apt-get install -y rsync \
wget
USER app
RUN bundle config set path 'vendor/bundle'
CMD ["bin/startup"]
# Final Target
FROM base AS production
# Clean up Bundle
RUN bundle install --without development test && \
bundle clean && \
rm -rf /app/.bundle/cache && \
rm -rf /app/vendor/bundle/ruby/*/cache
RUN RAILS_ENV=production \
NODE_ENV=production \
DEFAULT_URL_HOST=localhost \
SECRET_KEY_BASE=rails_bogus_key \
AWS_BUCKET=bucket \
AWS_ACCESS_KEY_ID=key \
AWS_SECRET_ACCESS_KEY=secret \
AWS_REGION=us-east-1 \
LLM_MODEL=default \
bundle exec rails assets:precompile && \
rm -rf /app/.cache/ && \
rm -rf /app/node_modules/.cache/ && \
rm -rf /app/tmp/ && \
mkdir /app/tmp && chown -R app:app /app/tmp
CMD ["bin/startup"]