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