Merge "Add ability to deploy mso 1.1 in K8s"
diff --git a/cloudify/scripts/onap/patch_definitions.py b/cloudify/scripts/onap/patch_definitions.py
new file mode 100644
index 0000000..d43e921
--- /dev/null
+++ b/cloudify/scripts/onap/patch_definitions.py
@@ -0,0 +1 @@
+from cloudify import ctx
diff --git a/cloudify/scripts/onap/provision_definitions.py b/cloudify/scripts/onap/provision_definitions.py
new file mode 100644
index 0000000..d43e921
--- /dev/null
+++ b/cloudify/scripts/onap/provision_definitions.py
@@ -0,0 +1 @@
+from cloudify import ctx
diff --git a/cloudify/scripts/onap/read_definitions.py b/cloudify/scripts/onap/read_definitions.py
new file mode 100644
index 0000000..d43e921
--- /dev/null
+++ b/cloudify/scripts/onap/read_definitions.py
@@ -0,0 +1 @@
+from cloudify import ctx
diff --git a/cloudify/types/onap.yaml b/cloudify/types/onap.yaml
new file mode 100644
index 0000000..20ef33f
--- /dev/null
+++ b/cloudify/types/onap.yaml
@@ -0,0 +1,34 @@
+node_types:
+  cloudify.onap.kubernetes.App:
+    derived_from: cloudify.nodes.Root
+    properties:
+      name:
+        type: string
+        description: >
+          Name of ONAP app
+      resources:
+        description: >
+          List of paths (relative, blueprint prespective)
+          to all kubernetes resources YAML files definition
+        default: []
+      services:
+        type: string
+        description: >
+          Path (relative, blueprint prespective)
+          to kubernetes app services YAML file definition
+        default: []
+      inputs:
+        description: >
+          Parameters required to create kubernetes resources for each app
+        default: {}
+    interfaces:
+      cloudify.interfaces.lifecycle:
+        create:
+          implementation: cloudify/scripts/onap/read_definitions.py
+          executor: central_deployment_agent
+        configure:
+          implementation: cloudify/scripts/onap/patch_definitions.py
+          executor: central_deployment_agent
+        start:
+          implementation: cloudify/scripts/onap/provision_definitions.py
+          executor: central_deployment_agent
diff --git a/kubernetes/msb/Chart.yaml b/kubernetes/msb/Chart.yaml
new file mode 100644
index 0000000..7e2ba04
--- /dev/null
+++ b/kubernetes/msb/Chart.yaml
@@ -0,0 +1,4 @@
+apiVersion: v1
+description: A Helm chart for Kubernetes
+name: msb
+version: 0.1.0
diff --git a/kubernetes/msb/templates/all-services.yaml b/kubernetes/msb/templates/all-services.yaml
new file mode 100644
index 0000000..b67808d
--- /dev/null
+++ b/kubernetes/msb/templates/all-services.yaml
@@ -0,0 +1,59 @@
+apiVersion: v1
+kind: Service
+metadata:
+  name: msb-consul
+  labels:
+    app: msb-consul
+spec:
+  clusterIP: "{{ .Values.consulClusterIP }}"
+  ports:
+    - port: {{ .Values.consulPort }}
+      nodePort: {{ .Values.consulNodePort }}
+  selector:
+    app: msb-consul
+  type: NodePort
+---
+apiVersion: v1
+kind: Service
+metadata:
+  name: msb-discovery
+  labels:
+    app: msb-discovery
+spec:
+  clusterIP: "{{ .Values.discoveryClusterIP }}"
+  ports:
+    - port: {{ .Values.discoveryPort }}
+      nodePort: {{ .Values.discoveryNodePort }}
+  selector:
+    app: msb-discovery
+  type: NodePort
+---
+apiVersion: v1
+kind: Service
+metadata:
+  name: msb-iag
+  labels:
+    app: msb-iag
+spec:
+  clusterIP: "{{ .Values.iagClusterIP }}"
+  ports:
+    - port: {{ .Values.iagPort }}
+      nodePort: {{ .Values.iagNodePort }}
+  selector:
+    app: msb-iag
+  type: NodePort
+---
+apiVersion: v1
+kind: Service
+metadata:
+  name: msb-eag
+  labels:
+    app: msb-eag
+spec:
+  clusterIP: "{{ .Values.eagClusterIP }}"
+  ports:
+    - port: {{ .Values.eagPort }}
+      nodePort: {{ .Values.eagNodePort }}
+  selector:
+    app: msb-eag
+  type: NodePort
\ No newline at end of file
diff --git a/kubernetes/msb/templates/msb-consul-deployment.yaml b/kubernetes/msb/templates/msb-consul-deployment.yaml
new file mode 100644
index 0000000..1dbbe8f
--- /dev/null
+++ b/kubernetes/msb/templates/msb-consul-deployment.yaml
@@ -0,0 +1,29 @@
+apiVersion: extensions/v1beta1
+kind: Deployment
+metadata:
+  name: msb-consul
+spec:
+  replicas: 1
+  selector:
+    matchLabels:
+      app: msb-consul
+  template:
+    metadata:
+      labels:
+        app: msb-consul
+      name: msb-consul
+    spec:
+      hostname: msb-consul
+      containers:
+      - args:
+        image: consul
+        name: "msb-consul"
+        ports:
+        - containerPort: {{ .Values.consulPort }}
+          name: msb-consul
+        readinessProbe:
+          tcpSocket:
+            port: {{ .Values.consulPort }}
+          initialDelaySeconds: 5
+          periodSeconds: 10
+        imagePullPolicy: "{{ .Values.pullPolicy }}"
\ No newline at end of file
diff --git a/kubernetes/msb/templates/msb-discovery-deployment.yaml b/kubernetes/msb/templates/msb-discovery-deployment.yaml
new file mode 100644
index 0000000..0fcd2f9
--- /dev/null
+++ b/kubernetes/msb/templates/msb-discovery-deployment.yaml
@@ -0,0 +1,34 @@
+apiVersion: extensions/v1beta1
+kind: Deployment
+metadata:
+  name: msb-discovery
+spec:
+  replicas: {{ .Values.discoveryReplicas }}
+  selector:
+    matchLabels:
+      app: msb-discovery
+  template:
+    metadata:
+      labels:
+        app: msb-discovery
+      name: msb-discovery
+    spec:
+      hostname: msb-discovery
+      containers:
+      - args:
+        image:  nexus3.onap.org:10001/onap/msb/msb_discovery
+        name: "msb-discovery"
+        env:
+        - name: CONSUL_IP
+          value: "{{ .Values.consulClusterIP }}"
+        ports:
+        - containerPort: {{ .Values.discoveryPort }}
+          name: msb-discovery
+        readinessProbe:
+          tcpSocket:
+            port: {{ .Values.discoveryPort }}
+          initialDelaySeconds: 5
+          periodSeconds: 10
+        imagePullPolicy: "{{ .Values.pullPolicy }}"
+
+
diff --git a/kubernetes/msb/templates/msb-eag-deployment.yaml b/kubernetes/msb/templates/msb-eag-deployment.yaml
new file mode 100644
index 0000000..eb75cd9
--- /dev/null
+++ b/kubernetes/msb/templates/msb-eag-deployment.yaml
@@ -0,0 +1,38 @@
+apiVersion: extensions/v1beta1
+kind: Deployment
+metadata:
+  name: msb-eag
+spec:
+  replicas: {{ .Values.eagReplicas }}
+  selector:
+    matchLabels:
+      app: msb-eag
+  template:
+    metadata:
+      labels:
+        app: msb-eag
+      name: msb-eag
+    spec:
+      hostname: msb-eag
+      containers:
+      - args:
+        image:  nexus3.onap.org:10001/onap/msb/msb_apigateway
+        name: "msb-eag"
+        env:
+        - name: CONSUL_IP
+          value: "{{ .Values.consulClusterIP}}"
+        - name: SDCLIENT_IP
+          value: "{{ .Values.discoveryClusterIP}}"
+        - name: ROUTE_LABELS
+          value: "visualRange:0"
+        ports:
+        - containerPort: {{ .Values.eagPort }}
+          name: msb-eag
+        readinessProbe:
+          tcpSocket:
+            port: {{ .Values.eagPort }}
+          initialDelaySeconds: 5
+          periodSeconds: 10
+        imagePullPolicy: "{{ .Values.pullPolicy}}"
+
+
diff --git a/kubernetes/msb/templates/msb-iag-deployment.yaml b/kubernetes/msb/templates/msb-iag-deployment.yaml
new file mode 100644
index 0000000..d83951a
--- /dev/null
+++ b/kubernetes/msb/templates/msb-iag-deployment.yaml
@@ -0,0 +1,38 @@
+apiVersion: extensions/v1beta1
+kind: Deployment
+metadata:
+  name: msb-iag
+spec:
+  replicas: {{ .Values.iagReplicas }}
+  selector:
+    matchLabels:
+      app: msb-iag
+  template:
+    metadata:
+      labels:
+        app: msb-iag
+      name: msb-iag
+    spec:
+      hostname: msb-iag
+      containers:
+      - args:
+        image:  nexus3.onap.org:10001/onap/msb/msb_apigateway
+        name: "msb-iag"
+        env:
+        - name: CONSUL_IP
+          value: "{{ .Values.consulClusterIP}}"
+        - name: SDCLIENT_IP
+          value: "{{ .Values.discoveryClusterIP}}"
+        - name: ROUTE_LABELS
+          value: "visualRange:1"
+        ports:
+        - containerPort: {{ .Values.iagPort }}
+          name: msb-iag
+        readinessProbe:
+          tcpSocket:
+            port: {{ .Values.iagPort }}
+          initialDelaySeconds: 5
+          periodSeconds: 10
+        imagePullPolicy: "{{ .Values.pullPolicy}}"
+
+
diff --git a/kubernetes/msb/values.yaml b/kubernetes/msb/values.yaml
new file mode 100644
index 0000000..38059e1
--- /dev/null
+++ b/kubernetes/msb/values.yaml
@@ -0,0 +1,20 @@
+consulClusterIP: 10.43.6.204
+consulPort: 8500
+consulNodePort: 30500
+
+discoveryClusterIP: 10.43.6.205
+discoveryPort: 10081
+discoveryNodePort: 30081
+discoveryReplicas: 1
+
+iagClusterIP: 10.43.6.206
+iagPort: 80
+iagNodePort: 30080
+iagReplicas: 1
+
+eagClusterIP: 10.43.6.207
+eagPort: 80
+eagNodePort: 30082
+eagReplicas: 1
+
+pullPolicy: IfNotPresent
\ No newline at end of file
diff --git a/onap-blueprint.yaml b/onap-blueprint.yaml
new file mode 100644
index 0000000..50ac29b
--- /dev/null
+++ b/onap-blueprint.yaml
@@ -0,0 +1,240 @@
+tosca_definitions_version: cloudify_dsl_1_3
+
+description: >
+  Blueprint deploys all ONAP kubernetes resources defined in YAML files on existing kubernetes cluster
+  The following pre-setup steps are assumed, but not required:
+  - Create Cloudify Example Environment: https://github.com/cloudify-examples/cloudify-environment-setup.
+  - Create Kubernetes Cluster: https://github.com/cloudify-examples/simple-kubernetes-blueprint.
+
+imports:
+  - https://raw.githubusercontent.com/cloudify-cosmo/cloudify-manager/4.1/resources/rest-service/cloudify/types/types.yaml
+  # Plugin required: https://github.com/cloudify-incubator/cloudify-kubernetes-plugin/releases/download/1.2.0/cloudify_kubernetes_plugin-1.2.0-py27-none-linux_x86_64-centos-Core.wgn
+  - https://raw.githubusercontent.com/cloudify-incubator/cloudify-kubernetes-plugin/1.2.0/plugin.yaml
+  - cloudify/types/onap.yaml
+
+inputs:
+  kubernetes_configuration_file_content:
+    description: >
+      File content of kubernetes master YAML configuration
+
+  apps:
+    description: >
+      List of ONAP apps names to be deployed.
+      Default empty array (deploy all available apps).
+    default: []
+
+  namespace_prefix:
+    type: string
+    description: >
+      Kubernetes namespace name prefix which will be uese for all ONAP apps
+    default: onap
+
+  docker_registry:
+    type: string
+    default: regsecret
+
+  docker_server:
+    type: string
+    default: nexus3.onap.org:10001
+
+  docker_username:
+    type: string
+    default: docker
+
+  docker_password:
+    type: string
+    default: docker
+
+  docker_email:
+    type: string
+    default: email@email.com
+
+dsl_definitions:
+  inputs: &app_inputs
+    namespace_prefix: { get_input: namespace_prefix }
+    docker_registry: { get_input: docker_registry }
+    docker_server: { get_input: docker_server }
+    docker_username: { get_input: docker_username }
+    docker_password: { get_input: docker_password }
+    docker_email: { get_input: docker_email }
+
+node_templates:
+  kubernetes_master:
+    type: cloudify.kubernetes.nodes.Master
+    properties:
+      configuration:
+        file_content: { get_input: kubernetes_configuration_file_content }
+
+  init_pod:
+    type: cloudify.kubernetes.resources.Pod
+    properties:
+      definition:
+        file:
+          resource_path: kubernetes/config/pod-config-init.yaml
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+
+  mso_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: mso
+      resources:
+          - kubernetes/mso/templates/mso-deployment.yaml
+          - kubernetes/mso/templates/db-deployment.yaml
+      services: kubernetes/mso/templates/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  message_router_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: message-router
+      resources:
+          - kubernetes/message-router/templates/message-router-zookeeper.yaml
+          - kubernetes/message-router/templates/message-router-dmaap.yaml
+          - kubernetes/message-router/templates/message-router-kafka.yaml
+      services: kubernetes/message-router/templates/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  sdc_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: sdc
+      resources:
+        - kubernetes/sdc/sdc-es.yaml
+        - kubernetes/sdc/sdc-fe.yaml
+        - kubernetes/sdc/sdc-kb.yaml
+        - kubernetes/sdc/sdc-cs.yaml
+        - kubernetes/sdc/sdc-be.yaml
+      services: kubernetes/sdc/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  aai_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: aai
+      resources:
+        - kubernetes/aai/aai-deployment.yaml
+        - kubernetes/aai/modelloader-deployment.yaml
+        - kubernetes/aai/hbase-deployment.yaml
+      services: kubernetes/aai/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  robot_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: robot
+      resources:
+        - kubernetes/robot/robot-deployment.yaml
+      services: kubernetes/robot/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  vid_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: vid
+      resources:
+        - kubernetes/vid/vid-mariadb-deployment.yaml
+        - kubernetes/vid/vid-server-deployment.yaml
+      services: kubernetes/vid/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  sdnc_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: sdnc
+      resources:
+        - kubernetes/sdnc/web-deployment.yaml
+        - kubernetes/sdnc/sdnc-deployment.yaml
+        - kubernetes/sdnc/dgbuilder-deployment.yaml
+        - kubernetes/sdnc/db-deployment.yaml
+      services: kubernetes/sdnc/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  portal_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: portal
+      resources:
+        - kubernetes/portal/portal-widgets-deployment.yaml
+        - kubernetes/portal/portal-apps-deployment.yaml
+        - kubernetes/portal/portal-mariadb-deployment.yaml
+        - kubernetes/portal/portal-vnc-dep.yaml
+      services: kubernetes/portal/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  policy_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: policy
+      resources:
+        - kubernetes/policy/dep-drools.yaml
+        - kubernetes/policy/dep-nexus.yaml
+        - kubernetes/policy/dep-brmsgw.yaml
+        - kubernetes/policy/dep-pdp.yaml
+        - kubernetes/policy/dep-pap.yaml
+        - kubernetes/policy/dep-maria.yaml
+        - kubernetes/policy/dep-pypdp.yaml
+      services: kubernetes/policy/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod
+
+  appc_app:
+    type: cloudify.onap.kubernetes.App
+    properties:
+      name: appc
+      resources:
+        - kubernetes/appc/appc-deployment.yaml
+        - kubernetes/appc/dgbuilder-deployment.yaml
+        - kubernetes/appc/db-deployment.yaml
+      services: kubernetes/appc/all-services.yaml
+      inputs: *app_inputs
+    relationships:
+      - type: cloudify.kubernetes.relationships.managed_by_master
+        target: kubernetes_master
+      - type: cloudify.relationships.depends_on
+        target: init_pod