# See the License for the specific language governing permissions and
# limitations under the License.
-FROM ubuntu:16.04
+FROM ubuntu:18.04
# Set the working directory to /app
WORKDIR /app/LCM
-RUN apt-get update && apt-get install -y curl xz-utils \
+RUN apt-get update && apt-get install -y curl xz-utils gnupg2 \
&& apt-get update && apt-get install -y apt-transport-https \
&& curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | apt-key add - \
&& echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | tee -a /etc/apt/sources.list.d/kubernetes.list \
&& mv linux-amd64/helm /usr/local/bin/helm \
&& rm -r linux-amd64/
-RUN curl -L https://launchpad.net/juju/2.7/2.7.0/+download/juju-2.7.0-k8s.tar.xz --output juju-2.7.0-k8s.tar.xz \
- && tar -xvf juju-2.7.0-k8s.tar.xz \
+RUN curl -L https://launchpad.net/juju/2.7/2.7.6/+download/juju-2.7.6-k8s.tar.xz --output juju-2.7.6-k8s.tar.xz \
+ && tar -xvf juju-2.7.6-k8s.tar.xz \
&& mv juju /usr/local/bin/juju
RUN apt-get update && apt-get install -y git tox python3 \
- python3-pip python3-aiohttp python3-jinja2 \
+ python3-pip python3-jinja2 \
&& python3 -m pip install pip --upgrade \
- && python3 -m pip install -U 'PyYAML==3.*' 'aiohttp==0.20.2' flake8
+ && python3 -m pip install -U 'PyYAML' 'aiohttp>=2.3.10' flake8
RUN git -C /app clone https://osm.etsi.org/gerrit/osm/N2VC.git \
+ && git -C /app/N2VC checkout v8.0 \
&& python3 -m pip install -e /app/N2VC \
&& python3 -m pip install -U juju \
&& apt-get install -y libffi-dev libssl-dev openssh-client
# cd modules/libjuju; python3 setup.py develop
RUN git -C /app clone https://osm.etsi.org/gerrit/osm/common.git \
+ && git -C /app/common checkout v8.0 \
&& python3 -m pip install -e /app/common
# python3-pymongo python3-yaml pycrypto aiokafka
+RUN python3 -m pip install grpcio-tools grpclib
+
RUN mkdir -p /app/storage/kafka && mkdir -p /app/log
# VCA
ENV OSMLCM_VCA_HOST vca
-ENV OSMLCM_VCA_PORT: 17070
-ENV OSMLCM_VCA_USER: admin
-ENV OSMLCM_VCA_SECRET: secret
-# ENV OSMLCM_VCA_PUBKEY: pubkey
-# ENV OSMLCM_VCA_CACERT: cacert
+ENV OSMLCM_VCA_PORT 17070
+ENV OSMLCM_VCA_USER admin
+ENV OSMLCM_VCA_SECRET secret
+ENV OSMLCM_VCA_CLOUD: localhost
+# ENV OSMLCM_VCA_ENABLEOSUPGRADE false
+# ENV OSMLCM_VCA_APTMIRROR http://archive.ubuntu.com/ubuntu/
+# ENV OSMLCM_VCA_PUBKEY pubkey
+# ENV OSMLCM_VCA_CACERT cacert
+
+# VCA - k8s
+ENV OSMLCM_VCA_HELMPATH /usr/local/bin/helm
+ENV OSMLCM_VCA_KUBECTLPATH /usr/bin/kubectl
+ENV OSMLCM_VCA_JUJUPATH /usr/local/bin/juju
# database
ENV OSMLCM_DATABASE_DRIVER mongo
ENV OSMLCM_MESSAGE_HOST kafka
ENV OSMLCM_MESSAGE_PORT 9092
-# k8s
-ENV OSMLCM_VCA_HELMPATH /usr/local/bin/helm
-ENV OSMLCM_VCA_KUBECTLPATH /usr/bin/kubectl
-ENV OSMLCM_VCA_JUJUPATH /usr/local/bin/juju
# logs
# ENV OSMLCM_GLOBAL_LOGFILE /app/log/lcm.log
ENV OSMLCM_GLOBAL_LOGLEVEL DEBUG
+# timeouts
+# ENV OSMLCM_TIMEOUT_NS_DEPLOY 7200
+# ENV OSMLCM_TIMEOUT_NSI_DEPLOY 7200
+
# Copy the current directory contents into the container at /app/LCM
ADD . /app/LCM
# Run app.py when the container launches
CMD python3 -m osm_lcm.lcm
-# HEALTHCHECK --interval=120s --timeout=15s --retries=1 \
-# CMD python3 -m osm_lcm.lcm --health-check || exit 1
+# HEALTHCHECK --start-period=120s --interval=30s --timeout=30s --retries=1 \
+# CMD python3 -m osm_lcm.lcm_hc || exit 1
+