This repository has been archived by the owner on Dec 17, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Dockerfile
56 lines (43 loc) · 1.76 KB
/
Dockerfile
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
# Copyright © 2020 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
FROM registry.centos.org/centos:8 AS build
USER root
WORKDIR /work
# Speed up build by leveraging docker layer caching
COPY go.mod go.sum vendor/ ./
RUN mkdir -p bin
RUN dnf install -y --disableplugin=subscription-manager \
--enablerepo=powertools \
udica \
golang make libsemanage-devel
ADD . /work
RUN make
FROM registry.centos.org/centos:8
# TODO(jaosorior): Switch to UBI once we use static linking
#FROM registry.access.redhat.com/ubi8/ubi-minimal:latest
# TODO(jaosorior): See if we can run this without root
USER root
LABEL name="selinuxd" \
description="selinuxd is a daemon that listens for files in /etc/selinux.d/ and installs the relevant policies."
# TODO(jaosorior): Remove once we use static linking
RUN dnf install -y --disableplugin=subscription-manager \
--enablerepo=powertools \
policycoreutils
RUN mkdir -p /usr/share/selinuxd/templates
COPY --from=build /usr/share/udica/templates/* /usr/share/selinuxd/templates/
# For backwards compatibility with older SPO, we can remove later
RUN mkdir -p /usr/share/udica/
RUN ln -s /usr/share/selinuxd/templates /usr/share/udica/templates
COPY --from=build /work/bin/selinuxdctl /usr/bin/
ENTRYPOINT ["/usr/bin/selinuxdctl"]