aboutsummaryrefslogtreecommitdiff
blob: 71dd07afe8670ad7e2e7b58f361029d11b371cbe (plain)
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
## Create Dockerfile that builds container suitable for systemd build
## This container runs as non-root user by deafult

FROM fedora:27

# Demand the specification of non-root username
ARG DOCKER_USER
ARG DOCKER_USER_UID
ARG DOCKER_USER_GID

# Copy the requirements into the container at /tmp
COPY requirements.txt /tmp/

# Install the requirements
# RUN dnf -y update FIXME
RUN dnf -y install $(cat '/tmp/requirements.txt')
# clean step to prevent cache and metadata corruption
RUN dnf clean all
RUN dnf -y builddep systemd

# Add non-root user and chown the project dir
RUN groupadd -g $DOCKER_USER_GID $DOCKER_USER
RUN useradd --create-home --shell /bin/bash -u $DOCKER_USER_UID -g $DOCKER_USER_GID -G wheel $DOCKER_USER
ENV HOME /home/$DOCKER_USER
ENV PROJECTDIR $HOME/systemd

# Copy content to the project directory
COPY . $PROJECTDIR

# Greant user all permissions to the project dir
RUN chown -R $DOCKER_USER $PROJECTDIR

# Switch to noroot user by default
USER $DOCKER_USER

# Update workdir to user home dir
WORKDIR $PROJECTDIR