a84b30c15aab0649f2a6fc3d6139fd9dbb5e829a
[nonrtric/plt/a1policymanagementservice.git] / Dockerfile
1 #
2 # ============LICENSE_START=======================================================
3 #  Copyright (C) 2019-2023 Nordix Foundation.
4 #  Copyright (C) 2024: OpenInfra Foundation Europe. All rights reserved.
5 # ================================================================================
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 #      http://www.apache.org/licenses/LICENSE-2.0
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 #
18 # SPDX-License-Identifier: Apache-2.0
19 # ============LICENSE_END=========================================================
20 #
21 FROM openjdk:17-jdk as jre-build
22
23 RUN $JAVA_HOME/bin/jlink \
24 --verbose \
25 --add-modules ALL-MODULE-PATH \
26 --strip-debug \
27 --no-man-pages \
28 --no-header-files \
29 --compress=2 \
30 --output /customjre
31
32 # Use debian base image (same as openjdk uses)
33 FROM debian:11-slim
34
35 ENV JAVA_HOME=/jre
36 ENV PATH="${JAVA_HOME}/bin:${PATH}"
37
38 # Copy JRE from the base image
39 COPY --from=jre-build /customjre $JAVA_HOME
40
41 ARG JAR
42
43 EXPOSE 8081 8433
44
45
46 WORKDIR /opt/app/policy-agent
47 RUN mkdir -p /var/log/policy-agent
48 RUN mkdir -p /opt/app/policy-agent/etc/cert/
49 RUN mkdir -p /var/policy-management-service
50 EXPOSE 8081 8433
51
52 ADD /config/application.yaml /opt/app/policy-agent/config/application.yaml
53 ADD /config/application_configuration.json /opt/app/policy-agent/data/application_configuration.json_example
54 ADD /config/keystore.jks /opt/app/policy-agent/etc/cert/keystore.jks
55 ADD /config/truststore.jks /opt/app/policy-agent/etc/cert/truststore.jks
56
57 ARG user=nonrtric
58 ARG group=nonrtric
59
60 RUN groupadd $user && \
61     useradd -r -g $group $user
62 RUN chown -R $user:$group /opt/app/policy-agent
63 RUN chown -R $user:$group /var/log/policy-agent
64 RUN chown -R $user:$group /var/policy-management-service
65
66 USER ${user}
67
68 ADD target/${JAR} /opt/app/policy-agent/policy-agent.jar
69 CMD ["/jre/bin/java", "-jar", "/opt/app/policy-agent/policy-agent.jar"]