forked from cyberark/conjur
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile.ubi
89 lines (74 loc) · 2.58 KB
/
Dockerfile.ubi
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
82
83
84
85
86
87
88
89
# Conjur Base Image (UBI)
FROM cyberark/ubi-ruby-fips:latest
EXPOSE 8080
ARG VERSION
ENV PORT=8080 \
LOG_DIR=/opt/conjur-server/log \
TMP_DIR=/opt/conjur-server/tmp \
SSL_CERT_DIRECTORY=/opt/conjur/etc/ssl \
RAILS_ENV=production
LABEL name="conjur-ubi" \
vendor="CyberArk" \
version="$VERSION" \
release="$VERSION" \
summary="Conjur UBI-based image" \
description="Conjur provides secrets management and machine identity for modern infrastructure."
# Create conjur user with one that has known gid / uid.
RUN groupadd -r conjur \
-g 777 && \
useradd -c "conjur runner account" \
-g conjur \
-d "$HOME" \
-r \
-m \
-s /bin/bash \
-u 777 conjur
WORKDIR /opt/conjur-server
# Ensure few required GID0-owned folders to run as a random UID (OpenShift requirement)
RUN mkdir -p "$TMP_DIR" \
"$LOG_DIR" \
"$SSL_CERT_DIRECTORY/ca" \
"$SSL_CERT_DIRECTORY/cert" \
/run/authn-local && \
# Use GID of 0 since that is what OpenShift will want to be able to read things
chown conjur:0 "$LOG_DIR" \
"$TMP_DIR" \
"$SSL_CERT_DIRECTORY" \
/run/authn-local && \
# We need open group permissions in these directories since OpenShift won't
# match our UID when we try to write files to them
chmod 770 "$LOG_DIR" \
"$TMP_DIR" \
"$SSL_CERT_DIRECTORY" \
/run/authn-local
COPY Gemfile \
Gemfile.lock ./
COPY gems/ gems/
# Install package dependencies for Conjur
RUN INSTALL_PKGS="openldap-clients \
tzdata" && \
yum install -y --setopt=tsflags=nodocs $INSTALL_PKGS && \
rpm -V $INSTALL_PKGS && \
yum -y clean all --enablerepo='*'
# Install Gems (and build native gems) for Conjur
RUN INSTALL_PKGS="gcc \
gcc-c++ \
git \
glibc-devel \
libxml2-devel \
libxslt-devel \
make" && \
yum install -y --setopt=tsflags=nodocs $INSTALL_PKGS && \
rpm -V $INSTALL_PKGS && \
# Install the gems dependencies
bundle --without test development && \
# Remove the build packages
yum remove -y $INSTALL_PKGS && \
yum -y clean all --enablerepo='*'
COPY . .
# removing CA bundle of httpclient gem
RUN find / -name httpclient -type d -exec find {} -name *.pem -type f -delete \;
RUN ln -sf /opt/conjur-server/bin/conjurctl /usr/local/bin/
COPY LICENSE.md /licenses/
USER conjur
ENTRYPOINT ["conjurctl"]