X-Git-Url: https://osm.etsi.org/gitweb/?p=osm%2FNBI.git;a=blobdiff_plain;f=Dockerfile.local;h=e72aefac89d1237f4f6ea2a624d194ff09088b4b;hp=372e6a9c26711ed9c23b42144ccadccaa43f58b8;hb=refs%2Fchanges%2F54%2F8054%2F6;hpb=cd65be33d44114e73936813eaf790e6a12b0df63 diff --git a/Dockerfile.local b/Dockerfile.local index 372e6a9..e72aefa 100644 --- a/Dockerfile.local +++ b/Dockerfile.local @@ -1,22 +1,32 @@ +# 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. + # This creates osm/NBI docker from local NBI source code FROM ubuntu:16.04 # Set the working directory to /app -WORKDIR /app/NBI/osm_nbi - -# Copy the current directory contents into the container at /app -#ADD . /app +WORKDIR /app/NBI 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 keystoneauth1 \ + && pip3 install aiokafka aiohttp cherrypy==18.1.2 keystoneauth1 requests \ && mkdir -p /app/storage/kafka && mkdir -p /app/log # OSM_COMMON -RUN git clone https://osm.etsi.org/gerrit/osm/common.git \ - && pip3 install -e common +RUN git -C /app clone https://osm.etsi.org/gerrit/osm/common.git \ + && pip3 install -e /app/common # && cd common && python3 setup.py develop && cd .. # && pip3 install -U -r requirements.txt \ # && cd .. @@ -30,6 +40,7 @@ RUN pip3 install pyang && mkdir -p /app && cd /app \ && mkdir /app/IM/osm_im \ && pyang --plugindir /app/pyangbind/pyangbind/plugin -f pybind -o /app/IM/osm_im/vnfd.py vnfd.yang \ && pyang --plugindir /app/pyangbind/pyangbind/plugin -f pybind -o /app/IM/osm_im/nsd.py nsd.yang \ + && pyang --plugindir /app/pyangbind/pyangbind/plugin -f pybind -o /app/IM/osm_im/nst.py nst.yang \ && pip3 install -e /app/IM EXPOSE 9999 @@ -48,6 +59,8 @@ VOLUME /app/log # server ENV OSMNBI_SOCKET_HOST 0.0.0.0 ENV OSMNBI_SOCKET_PORT 9999 +ENV OSMNBI_SERVER_SSL_CERTIFICATE /app/NBI/osm_nbi/http/cert.pem +ENV OSMNBI_SERVER_SSL_PRIVATE_KEY /app/NBI/osm_nbi/http/privkey.pem # storage ENV OSMNBI_STORAGE_PATH /app/storage # database @@ -58,17 +71,14 @@ ENV OSMNBI_DATABASE_PORT 27017 # ENV OSMNBI_DATABASE_PASSWORD xxx # ENV OSMNBI_DATABASE_COMMONKEY xxx # web -ENV OSMNBI_STATIC_DIR /app/osm_nbi/html_public +ENV OSMNBI_STATIC_DIR /app/NBI/osm_nbi/html_public # logs -ENV OSMNBI_LOG_FILE /app/log +# ENV OSMNBI_LOG_FILE /app/log/nbi.log ENV OSMNBI_LOG_LEVEL DEBUG # message ENV OSMNBI_MESSAGE_DRIVER kafka ENV OSMNBI_MESSAGE_HOST kafka 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 @@ -79,9 +89,16 @@ ENV OSMNBI_AUTHENTICATION_BACKEND internal #ENV OSMNBI_AUTHENTICATION_SERVICE_USERNAME nbi #ENV OSMNBI_AUTHENTICATION_SERVICE_PASSWORD nbi #ENV OSMNBI_AUTHENTICATION_SERVICE_PROJECT service +# RBAC +ENV OSMNBI_RBAC_RESOURCES_TO_OPERATIONS /app/NBI/osm_nbi/resources_to_operations.yml +ENV OSMNBI_RBAC_ROLES_TO_OPERATIONS /app/NBI/osm_nbi/roles_to_operations.yml +# prometheus +ENV OSMNBI_PROMETHEUS_HOST prometheus +ENV OSMNBI_PROMETHEUS_PORT 9090 +# Copy the current directory contents into the container at /app ADD . /app/NBI # Run app.py when the container launches -CMD ["python3", "nbi.py"] +CMD python3 -m osm_nbi.nbi