Containers should not run as root by default
[aai/search-data-service.git] / search-data-service-app / src / main / docker / Dockerfile
1 FROM @aai.docker.namespace@/aai-common-@aai.base.image@:@aai.base.image.version@
2
3 ARG MICRO_HOME=/opt/app/search-data-service
4 ARG BIN_HOME=$MICRO_HOME/bin
5 ARG SD_LOGS=/var/log/onap/AAI-SDB
6
7 #AAI-2179 Additional optional steps for Ubuntu
8 RUN if  ((uname -v | grep -i "ubuntu") || ( cat /etc/*release|grep -i "ubuntu")      ) ; then \
9    #####################################
10    #if JAVA doesnt exist then install it:
11    ######################################
12    if type  java  2>/dev/null; then \
13      echo "skipping java installation"; \
14    else \
15      apt-get update && apt-get install -y software-properties-common; \
16      ## sudo -E is required to preserve the environment. If you remove that line, it will most like freeze at this step
17      sudo -E add-apt-repository ppa:openjdk-r/ppa && apt-get update && apt-get install -y openjdk-8-jdk ; \
18      ## Setup JAVA_HOME, this is useful for docker commandline
19      JAVA_HOME=usr/lib/jvm/java-8-openjdk-amd64; \
20      export JAVA_HOME ; \
21    fi; \
22 fi
23
24 # Build up the deployment folder structure
25 RUN mkdir -p $MICRO_HOME $USERS_HOME /logs $MICRO_HOME/bundleconfig/etc $BIN_HOME $SD_LOGS
26
27 RUN groupadd aaiadmin -g 1000
28 RUN adduser -u 1000 -h /opt/aaihome/aaiadmin -S -D -G aaiadmin -s /bin/bash aaiadmin
29
30 WORKDIR $MICRO_HOME
31
32 RUN chown -R aaiadmin:aaiadmin $MICRO_HOME $MICRO_HOME/logs $SD_LOGS
33
34 # copy everything from search-data-service-app/target/docker/nexus3.onap.org/10003/onap/search-data-service/latest/build/maven/search-data-service-app
35 COPY --chown=aaiadmin:aaiadmin /maven/search-data-service-app/ .
36
37 USER aaiadmin
38
39 RUN chmod -R 755 $BIN_HOME/* $MICRO_HOME/*
40 RUN ln -snf /logs $MICRO_HOME/logs
41
42 EXPOSE 9509 9509
43
44 CMD ["/opt/app/search-data-service/bin/start.sh"]