X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=docker%2FNBI%2FDockerfile;h=04a9acd94b7555aacdf44ea04b813f1423836772;hb=aa4905206a547169672d45300102afd5709992ae;hp=44b24b2404b68d7c587bbb3099ebb6dcef536e4c;hpb=182bd73468eb7e3a69254bed25f12a91b18393d0;p=osm%2Fdevops.git diff --git a/docker/NBI/Dockerfile b/docker/NBI/Dockerfile index 44b24b24..04a9acd9 100644 --- a/docker/NBI/Dockerfile +++ b/docker/NBI/Dockerfile @@ -4,6 +4,12 @@ FROM ubuntu:16.04 RUN apt-get update && apt-get -y install curl software-properties-common +RUN apt-get update && apt-get install -y git python3 python3-jsonschema \ + python3-pymongo python3-yaml python3-pip python3-keystoneclient \ + && pip3 install pip==9.0.3 \ + && pip3 install aiokafka cherrypy==18.0.0 pyangbind keystoneauth1 \ + && mkdir -p /app/storage/kafka && mkdir -p /app/log + ARG REPOSITORY_BASE=http://osm-download.etsi.org/repository/osm/debian ARG RELEASE=ReleaseFOUR-daily ARG REPOSITORY_KEY=OSM%20ETSI%20Release%20Key.gpg @@ -12,19 +18,21 @@ ARG REPOSITORY=testing RUN curl ${REPOSITORY_BASE}/${RELEASE}/${REPOSITORY_KEY} | apt-key add - RUN add-apt-repository -y "deb ${REPOSITORY_BASE}/${RELEASE} ${REPOSITORY} NBI IM common" && apt update -RUN apt-get -y install python3-osm-nbi python3-osm-common python3-osm-im +ARG NBI_VERSION +ARG COMMON_VERSION +ARG IM_VERSION + +RUN apt-get update && apt-get -y install python3-osm-nbi${NBI_VERSION} python3-osm-common${COMMON_VERSION} python3-osm-im${IM_VERSION} # Set the working directory to /app WORKDIR /app/osm_nbi -RUN apt-get update && apt-get install -y git python3 python3-jsonschema \ - python3-pymongo python3-yaml python3-pip \ - && pip3 install pip==9.0.3 \ - && pip3 install aiokafka cherrypy pyangbind \ - && mkdir -p /app/storage/kafka && mkdir -p /app/log - EXPOSE 9999 +RUN cp -R /usr/lib/python3/dist-packages/osm_nbi/html_public /app/osm_nbi/html_public +RUN cp /usr/lib/python3/dist-packages/osm_nbi/nbi.cfg /app/osm_nbi/ +RUN cp -R /usr/lib/python3/dist-packages/osm_nbi/http /app/osm_nbi/ + LABEL Maintainer="alfonso.tiernosepulveda@telefonica.com" \ Description="This implements a north bound interface for OSM" \ Version="1.0" \ @@ -43,10 +51,12 @@ ENV OSMNBI_SOCKET_PORT 9999 ENV OSMNBI_STORAGE_PATH /app/storage # database ENV OSMNBI_DATABASE_DRIVER mongo -ENV OSMNBI_DATABASE_HOST mongo -ENV OSMNBI_DATABASE_PORT 27017 +ENV OSMNBI_DATABASE_URI mongodb://mongo:27017 +#ENV OSMNBI_DATABASE_HOST mongo +#ENV OSMNBI_DATABASE_PORT 27017 + # web -ENV OSMNBI_STATIC_DIR /usr/lib/python3/dist-packages/osm_nbi/html_public +ENV OSMNBI_STATIC_DIR /app/osm_nbi/html_public # logs ENV OSMNBI_LOG_FILE /app/log ENV OSMNBI_LOG_LEVEL DEBUG @@ -57,6 +67,19 @@ ENV OSMNBI_MESSAGE_PORT 9092 # logs ENV OSMNBI_LOG_FILE /app/log/nbi.log ENV OSMNBI_LOG_LEVEL DEBUG +# authentication +ENV OSMNBI_AUTHENTICATION_BACKEND internal +#ENV OSMNBI_AUTHENTICATION_BACKEND keystone +#ENV OSMNBI_AUTHENTICATION_AUTH_URL keystone +#ENV OSMNBI_AUTHENTICATION_AUTH_PORT 5000 +#ENV OSMNBI_AUTHENTICATION_USER_DOMAIN_NAME default +#ENV OSMNBI_AUTHENTICATION_PROJECT_DOMAIN_NAME default +#ENV OSMNBI_AUTHENTICATION_SERVICE_USERNAME nbi +#ENV OSMNBI_AUTHENTICATION_SERVICE_PASSWORD nbi +#ENV OSMNBI_AUTHENTICATION_SERVICE_PROJECT service + +HEALTHCHECK --interval=5s --timeout=2s --retries=12 \ + CMD curl -k https://localhost:9999/osm/ | grep Welcome || exit 1 # Run app.py when the container launches CMD ["python3", "/usr/lib/python3/dist-packages/osm_nbi/nbi.py"]