summaryrefslogtreecommitdiffstats
path: root/Dockerfile
blob: 8824c3b51b44fcca3f240ae648dd645db2652b5b (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
38
39
40
41
42
43
44
45
46
#
#     Copyright (c) 2018 Orange
#
#     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 openjdk:8-jre-alpine

ARG SERVER_PORT
ARG PKG_FILENAME=nbi-rest-services-4.0.1-SNAPSHOT.jar
ADD target/$PKG_FILENAME app.jar

RUN addgroup -S appgroup
RUN adduser -S appuser -G appgroup
RUN mkdir temptoscafile
RUN chown appuser:appgroup temptoscafile/

COPY src/main/resources/certificate /certs
ARG CERT_PASS=changeit
RUN for cert in $(ls -d /certs/*); do \
        echo "adding $cert to java keystore..."; \
        keytool -import \
                -file "$cert" \
                -storepass "${CERT_PASS}" \
                -keystore $JAVA_HOME/lib/security/cacerts \
                -alias "$(basename $cert)" \
                --noprompt; \
    done

USER appuser:appgroup

ENV SERVER_PORT=${SERVER_PORT:-8080}
ENV JAVA_OPTS="-Djava.security.egd=file:/dev/./urandom"

EXPOSE $SERVER_PORT
ENTRYPOINT java -XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap $JAVA_OPTS -jar /app.jar