Ignore factory in json parsing bpgenerator
[dcaegen2/platform.git] / mod / bpgenerator / src / main / java / org / onap / blueprintgenerator / models / blueprint / Properties.java
index 25c4c53..d32d6f4 100644 (file)
@@ -1,13 +1,14 @@
-/**============LICENSE_START======================================================= 
- org.onap.dcae 
- ================================================================================ 
+/*============LICENSE_START=======================================================
+ org.onap.dcae
+ ================================================================================
  Copyright (c) 2019 AT&T Intellectual Property. All rights reserved.
- ================================================================================ 
+ Copyright (c) 2020 Nokia. All rights reserved.
+ ================================================================================
  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
+ 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,
  See the License for the specific language governing permissions and
  limitations under the License.
  ============LICENSE_END=========================================================
-
  */
 
 package org.onap.blueprintgenerator.models.blueprint;
 
+import static org.onap.blueprintgenerator.models.blueprint.tls.TlsConstants.USE_EXTERNAL_TLS_FIELD;
+
+import com.fasterxml.jackson.annotation.JsonIgnore;
+import com.fasterxml.jackson.annotation.JsonInclude;
+import com.fasterxml.jackson.annotation.JsonInclude.Include;
 import java.util.ArrayList;
 import java.util.LinkedHashMap;
+import java.util.Map;
 import java.util.TreeMap;
-
+import lombok.Getter;
+import lombok.Setter;
+import org.onap.blueprintgenerator.common.blueprint.BlueprintHelper;
+import org.onap.blueprintgenerator.models.blueprint.tls.ExternalCertificateParametersFactory;
+import org.onap.blueprintgenerator.models.blueprint.tls.ExternalTlsInfoFactory;
+import org.onap.blueprintgenerator.models.blueprint.tls.TlsInfo;
+import org.onap.blueprintgenerator.models.blueprint.tls.impl.ExternalTlsInfo;
 import org.onap.blueprintgenerator.models.componentspec.Auxilary;
 import org.onap.blueprintgenerator.models.componentspec.ComponentSpec;
-import org.onap.blueprintgenerator.models.componentspec.HealthCheck;
 import org.onap.blueprintgenerator.models.componentspec.Publishes;
 import org.onap.blueprintgenerator.models.componentspec.Subscribes;
-import org.onap.blueprintgenerator.models.componentspec.Volumes;
 import org.onap.blueprintgenerator.models.dmaapbp.DmaapStreams;
-import org.onap.blueprintgenerator.models.onapbp.LogDirectory;
 
-import com.fasterxml.jackson.annotation.JsonInclude;
-import com.fasterxml.jackson.annotation.JsonInclude.Include;
-
-import lombok.Getter; import lombok.Setter;
-
-@Getter @Setter
-@JsonInclude(value=Include.NON_NULL)
+@Getter
+@Setter
+@JsonInclude(value = Include.NON_NULL)
 public class Properties {
-       private Appconfig application_config;
-       private Auxilary docker_config;
-       private Object image;
-       private GetInput location_id;
-       private String service_component_type;
-       private TreeMap<String, Object> log_info;
-       private String dns_name;
-       private Object replicas;
-       private String name;
-       private GetInput topic_name;
-       private GetInput feed_name;
-       ArrayList<DmaapStreams> streams_publishes;
-       ArrayList<DmaapStreams> streams_subscribes;
-       private TreeMap<String, Object> tls_info;
-       private ResourceConfig resource_config;
-       //private boolean useExisting;
-
-       public TreeMap<String, LinkedHashMap<String, Object>> createOnapProperties(TreeMap<String, LinkedHashMap<String, Object>> inps, ComponentSpec cs, String override) {
-               TreeMap<String, LinkedHashMap<String, Object>> retInputs = new TreeMap<String, LinkedHashMap<String, Object>>();
-               retInputs = inps;
-
-               //set the image
-               GetInput image = new GetInput();
-               image.setGet_input("image");
-               this.setImage(image);
-               LinkedHashMap<String, Object> img = new LinkedHashMap<String, Object>();
-               img.put("type", "string");
-               img.put("default", cs.getArtifacts()[0].getUri());
-               retInputs.put("image", img);
-
-               //set the location id
-               GetInput location = new GetInput();
-               location.setGet_input("location_id");
-               this.setLocation_id(location);
-               LinkedHashMap<String, Object> locMap = new LinkedHashMap();
-               locMap.put("type", "string");
-               locMap.put("default", "central");
-
-               //set the log info
-               GetInput logD = new GetInput();
-               logD.setGet_input("log_directory");
-               TreeMap<String, Object> l = new TreeMap();
-               l.put("log_directory", logD);
-               this.setLog_info(l);
-               LinkedHashMap<String, Object> logMap = new LinkedHashMap();
-               logMap.put("type", "string");
-               logMap.put("default", "''");
-               retInputs.put("log_directory", logMap);
-
-               //set the replicas
-               GetInput replica = new GetInput();
-               replica.setGet_input("replicas");
-               this.setReplicas(replica);
-               LinkedHashMap<String, Object> rep = new LinkedHashMap<String, Object>();
-               rep.put("type", "integer");
-               rep.put("description", "number of instances");
-               rep.put("default", 1);
-               retInputs.put("replicas", rep);
-
-               //set the dns name
-               this.setDns_name(cs.getSelf().getName());
-
-               //set the name
-               this.setName(cs.getSelf().getName());
-
-               //set the docker config
-               Auxilary aux = cs.getAuxilary();
-               if(aux.getPorts() != null) {
-                       retInputs = aux.createPorts(retInputs);
-               }
-               this.setDocker_config(aux);
-
-               //set the app config
-               Appconfig app = new Appconfig();
-               retInputs = app.createAppconfig(retInputs, cs, override);
-               this.setApplication_config(app);
-
-               //set the tls info
-               GetInput tls = new GetInput();
-               tls.setGet_input("use_tls");
-               GetInput cert = new GetInput();
-               cert.setGet_input("cert_directory");
-               TreeMap<String, Object> tlsInfo = new TreeMap();
-               tlsInfo.put("cert_directory", cert);
-               tlsInfo.put("use_tls", tls);
-               this.setTls_info(tlsInfo);
-
-               LinkedHashMap<String, Object> certMap = new LinkedHashMap();
-               certMap.put("type", "string");
-               certMap.put("default", "''");
-               retInputs.put("cert_directory", certMap);
-
-               LinkedHashMap<String, Object> useMap = new LinkedHashMap();
-               useMap.put("type", "boolean");
-               useMap.put("default", false);
-               retInputs.put("use_tls", useMap);
-
-               //set the reource config
-               ResourceConfig resource = new ResourceConfig();
-               retInputs = resource.createResourceConfig(retInputs, cs.getSelf().getName());
-               this.setResource_config(resource);
-
-               return retInputs;
-       }
-
-       public TreeMap<String, LinkedHashMap<String, Object>> createDmaapProperties(TreeMap<String, LinkedHashMap<String, Object>> inps, ComponentSpec cs, String override) {
-               TreeMap<String, LinkedHashMap<String, Object>> retInputs = new TreeMap<String, LinkedHashMap<String, Object>>();
-               retInputs = inps;
-
-               //set the image
-               GetInput image = new GetInput();
-               image.setGet_input("tag_version");
-               this.setImage(image);
-               LinkedHashMap<String, Object> img = new LinkedHashMap<String, Object>();
-               img.put("type", "string");
-               img.put("default", cs.getArtifacts()[0].getUri());
-               retInputs.put("tag_version", img);
-
-               //set the log info
-               GetInput logD = new GetInput();
-               logD.setGet_input("log_directory");
-               TreeMap<String, Object> l = new TreeMap();
-               l.put("log_directory", logD);
-               this.setLog_info(l);
-               LinkedHashMap<String, Object> logMap = new LinkedHashMap();
-               logMap.put("type", "string");
-               logMap.put("default", "''");
-               retInputs.put("log_directory", logMap);
-
-               //set service component type
-               String sType = cs.getSelf().getName();
-               sType = sType.replace('.', '-');
-               this.setService_component_type(sType);
-
-               //set the tls info
-               GetInput tls = new GetInput();
-               tls.setGet_input("use_tls");
-               GetInput cert = new GetInput();
-               cert.setGet_input("cert_directory");
-               TreeMap<String, Object> tlsInfo = new TreeMap();
-               tlsInfo.put("cert_directory", cert);
-               tlsInfo.put("use_tls", tls);
-               this.setTls_info(tlsInfo);
-
-               LinkedHashMap<String, Object> certMap = new LinkedHashMap();
-               certMap.put("type", "string");
-               certMap.put("default", "''");
-               retInputs.put("cert_directory", certMap);
-
-               LinkedHashMap<String, Object> useMap = new LinkedHashMap();
-               useMap.put("type", "boolean");
-               useMap.put("default", false);
-               retInputs.put("use_tls", useMap);
-
-               //set the replicas
-               GetInput replica = new GetInput();
-               replica.setGet_input("replicas");
-               this.setReplicas(replica);
-               LinkedHashMap<String, Object> rep = new LinkedHashMap<String, Object>();
-               rep.put("type", "integer");
-               rep.put("description", "number of instances");
-               rep.put("default", 1);
-               retInputs.put("replicas", rep);
+
+    private Appconfig application_config;
+    private Auxilary docker_config;
+    private Object image;
+    private GetInput location_id;
+    private String service_component_type;
+    private TreeMap<String, Object> log_info;
+    private String dns_name;
+    private Object replicas;
+    private String name;
+    private GetInput topic_name;
+    private GetInput feed_name;
+    ArrayList<DmaapStreams> streams_publishes;
+    ArrayList<DmaapStreams> streams_subscribes;
+    private TlsInfo tls_info;
+    private ExternalTlsInfo external_cert;
+    private ResourceConfig resource_config;
+    private GetInput always_pull_image;
+    //private boolean useExisting;
+    @JsonIgnore
+    private ExternalTlsInfoFactory externalCertFactory;
+
+    public Properties() {
+        ExternalCertificateParametersFactory externalCertificateDataFactory = new ExternalCertificateParametersFactory();
+        externalCertFactory = new ExternalTlsInfoFactory(externalCertificateDataFactory);
+    }
+
+    public TreeMap<String, LinkedHashMap<String, Object>> createOnapProperties(
+        TreeMap<String, LinkedHashMap<String, Object>> inps, ComponentSpec cs, String override) {
+        TreeMap<String, LinkedHashMap<String, Object>> retInputs = inps;
+
+        //set the image
+        GetInput image = new GetInput();
+        image.setBpInputName("image");
+        this.setImage(image);
+        LinkedHashMap<String, Object> img = new LinkedHashMap<String, Object>();
+        img.put("type", "string");
+        img.put("default", cs.getArtifacts()[0].getUri());
+        retInputs.put("image", img);
+
+        //set the location id
+        GetInput location = new GetInput();
+        location.setBpInputName("location_id");
+        this.setLocation_id(location);
+        LinkedHashMap<String, Object> locMap = new LinkedHashMap();
+        locMap.put("type", "string");
+        locMap.put("default", "");
+        retInputs.put("location_id", locMap);
+
+        //set the log info
+        this.setLog_info(cs.getAuxilary().getLog_info());
+
+        //set the replicas
+        GetInput replica = new GetInput();
+        replica.setBpInputName("replicas");
+        this.setReplicas(replica);
+        LinkedHashMap<String, Object> rep = BlueprintHelper.createInputValue("integer", "number of instances", 1);
+        retInputs.put("replicas", rep);
+
+        //set the dns name
+        //this.setDns_name(cs.getSelf().getName());
+
+        //set the name
+        //this.setName(cs.getSelf().getName());
+
+        //set the docker config
+        Auxilary aux = cs.getAuxilary();
+//             if(aux.getPorts() != null) {
+//                     retInputs = aux.createPorts(retInputs);
+//             }
+        this.setDocker_config(aux);
+
+        //set the app config
+        Appconfig app = new Appconfig();
+        retInputs = app.createAppconfig(retInputs, cs, override, false);
+        this.setApplication_config(app);
+
+        // set always_pull_image
+        this.always_pull_image = new GetInput();
+        this.always_pull_image.setBpInputName("always_pull_image");
+        LinkedHashMap<String, Object> inputAlwaysPullImage = BlueprintHelper.createInputValue("boolean",
+            "Set to true if the image should always be pulled",
+            true);
+        retInputs.put("always_pull_image", inputAlwaysPullImage);
+
+        //set service component type
+        String sType = cs.getSelf().getName();
+        sType = sType.replace('.', '-');
+        this.setService_component_type(sType);
+
+        //set the tls info for internal and external communication
+        TreeMap<String, Object> tls_info = cs.getAuxilary().getTls_info();
+        if (tls_info != null) {
+            addTlsInfo(cs, retInputs);
+            if (tls_info.get(USE_EXTERNAL_TLS_FIELD) != null) {
+                retInputs.putAll(addExternalTlsInfo(cs));
+            }
+        }
+
+        //set the reource config
+        ResourceConfig resource = new ResourceConfig();
+        retInputs = resource.createResourceConfig(retInputs, cs.getSelf().getName());
+        this.setResource_config(resource);
+
+        return retInputs;
+    }
+
+    public TreeMap<String, LinkedHashMap<String, Object>> createDmaapProperties(
+        TreeMap<String, LinkedHashMap<String, Object>> inps, ComponentSpec cs, String override) {
+        TreeMap<String, LinkedHashMap<String, Object>> retInputs = new TreeMap<String, LinkedHashMap<String, Object>>();
+        retInputs = inps;
+
+        //set the image
+        GetInput image = new GetInput();
+        image.setBpInputName("tag_version");
+        this.setImage(image);
+        LinkedHashMap<String, Object> img = new LinkedHashMap<String, Object>();
+        img.put("type", "string");
+        img.put("default", cs.getArtifacts()[0].getUri());
+        retInputs.put("tag_version", img);
+
+        //set the location id
+        GetInput location = new GetInput();
+        location.setBpInputName("location_id");
+        this.setLocation_id(location);
+        LinkedHashMap<String, Object> locMap = new LinkedHashMap();
+        locMap.put("type", "string");
+        locMap.put("default", "");
+        retInputs.put("location_id", locMap);
+
+        //set the log info
+        this.setLog_info(cs.getAuxilary().getLog_info());
+
+        //set service component type
+        String sType = cs.getSelf().getName();
+        sType = sType.replace('.', '-');
+        this.setService_component_type(sType);
+
+        //set the tls info for internal and external communication
+        TreeMap<String, Object> tls_info = cs.getAuxilary().getTls_info();
+        if (tls_info != null) {
+            addTlsInfo(cs, retInputs);
+            if (tls_info.get(USE_EXTERNAL_TLS_FIELD) != null) {
+                retInputs.putAll(addExternalTlsInfo(cs));
+            }
+        }
+
+        //set the replicas
+        GetInput replica = new GetInput();
+        replica.setBpInputName("replicas");
+        this.setReplicas(replica);
+        LinkedHashMap<String, Object> rep = BlueprintHelper.createInputValue("integer", "number of instances", 1);
+        retInputs.put("replicas", rep);
 
 //             //set the dns name
 //             this.setDns_name(cs.getSelf().getName());
@@ -211,72 +206,89 @@ public class Properties {
 //             //set the name
 //             this.setName(cs.getSelf().getName());
 
-               //set the docker config
-               Auxilary aux = cs.getAuxilary();
-               if(aux.getPorts() != null) {
-                       retInputs = aux.createPorts(retInputs);
-               }
-               this.setDocker_config(aux);
-
-               //set the appconfig
-               Appconfig app = new Appconfig();
-               retInputs = app.createAppconfig(retInputs, cs, override);
-               this.setApplication_config(app);
-
-               //set the stream publishes
-               ArrayList<DmaapStreams> pubStreams = new ArrayList();
-               int counter = 0;
-               if(cs.getStreams().getPublishes() != null) {
-                       for(Publishes p: cs.getStreams().getPublishes()) {
-                               if(p.getType().equals("message_router") || p.getType().equals("message router")) {
-                                       String topic = "topic" + counter;
-                                       DmaapStreams mrStreams = new DmaapStreams();
-                                       retInputs = mrStreams.createStreams(inps, cs, topic, p.getType(), p.getConfig_key(), p.getRoute(), 'p');
-                                       pubStreams.add(mrStreams);
-                               }
-                               else if(p.getType().equals("data_router") || p.getType().equals("data router")){
-                                       String feed = "feed" + counter;
-                                       DmaapStreams drStreams = new DmaapStreams();
-                                       retInputs = drStreams.createStreams(inps, cs, feed, p.getType(), p.getConfig_key(), p.getRoute(), 'p');
-                                       pubStreams.add(drStreams);
-                               }
-                               counter++;
-                       }
-               }
-
-               //set the stream subscribes
-               ArrayList<DmaapStreams> subStreams = new ArrayList();
-               if(cs.getStreams().getSubscribes() != null) {
-                       for(Subscribes s: cs.getStreams().getSubscribes()) {
-                               if(s.getType().equals("message_router") || s.getType().equals("message router")) {
-                                       String topic = "topic" + counter;
-                                       DmaapStreams mrStreams = new DmaapStreams();
-                                       retInputs = mrStreams.createStreams(inps, cs, topic, s.getType(), s.getConfig_key(), s.getRoute(), 's');
-                                       subStreams.add(mrStreams);
-                               }
-                               else if(s.getType().equals("data_router") || s.getType().equals("data router")){
-                                       String feed = "feed" + counter;
-                                       DmaapStreams drStreams = new DmaapStreams();
-                                       retInputs = drStreams.createStreams(inps, cs, feed, s.getType(), s.getConfig_key(), s.getRoute(), 's');
-                                       subStreams.add(drStreams);
-                               }
-                               counter++;
-                       }
-               }
-
-               if(pubStreams.size() != 0) {
-                       this.setStreams_publishes(pubStreams);
-               }
-               if(subStreams.size() != 0) {
-                       this.setStreams_subscribes(subStreams);
-               }
-
-               //set the reource config
-               ResourceConfig resource = new ResourceConfig();
-               retInputs = resource.createResourceConfig(retInputs, cs.getSelf().getName());
-               this.setResource_config(resource);
-
-
-               return retInputs;
-       }
+        //set the docker config
+        Auxilary aux = cs.getAuxilary();
+//             if(aux.getPorts() != null) {
+//                     retInputs = aux.createPorts(retInputs);
+//             }
+        this.setDocker_config(aux);
+
+        //set the appconfig
+        Appconfig app = new Appconfig();
+        retInputs = app.createAppconfig(retInputs, cs, override, true);
+        this.setApplication_config(app);
+
+        //set the stream publishes
+        ArrayList<DmaapStreams> pubStreams = new ArrayList();
+        if (cs.getStreams().getPublishes() != null) {
+            for (Publishes p : cs.getStreams().getPublishes()) {
+                if (p.getType().equals("message_router") || p.getType().equals("message router")) {
+                    String topic = p.getConfig_key() + "_topic";
+                    DmaapStreams mrStreams = new DmaapStreams();
+                    retInputs = mrStreams
+                        .createStreams(inps, cs, topic, p.getType(), p.getConfig_key(), p.getRoute(), 'p');
+                    pubStreams.add(mrStreams);
+                } else if (p.getType().equals("data_router") || p.getType().equals("data router")) {
+                    String feed = p.getConfig_key() + "_feed";
+                    DmaapStreams drStreams = new DmaapStreams();
+                    retInputs = drStreams
+                        .createStreams(inps, cs, feed, p.getType(), p.getConfig_key(), p.getRoute(), 'p');
+                    pubStreams.add(drStreams);
+                }
+            }
+        }
+
+        //set the stream subscribes
+        ArrayList<DmaapStreams> subStreams = new ArrayList();
+        if (cs.getStreams().getSubscribes() != null) {
+            for (Subscribes s : cs.getStreams().getSubscribes()) {
+                if (s.getType().equals("message_router") || s.getType().equals("message router")) {
+                    String topic = s.getConfig_key() + "_topic";
+                    DmaapStreams mrStreams = new DmaapStreams();
+                    retInputs = mrStreams
+                        .createStreams(inps, cs, topic, s.getType(), s.getConfig_key(), s.getRoute(), 's');
+                    subStreams.add(mrStreams);
+                } else if (s.getType().equals("data_router") || s.getType().equals("data router")) {
+                    String feed = s.getConfig_key() + "_feed";
+                    DmaapStreams drStreams = new DmaapStreams();
+                    retInputs = drStreams
+                        .createStreams(inps, cs, feed, s.getType(), s.getConfig_key(), s.getRoute(), 's');
+                    subStreams.add(drStreams);
+                }
+            }
+        }
+
+        if (pubStreams.size() != 0) {
+            this.setStreams_publishes(pubStreams);
+        }
+        if (subStreams.size() != 0) {
+            this.setStreams_subscribes(subStreams);
+        }
+
+        //set the reource config
+        ResourceConfig resource = new ResourceConfig();
+        retInputs = resource.createResourceConfig(retInputs, cs.getSelf().getName());
+        this.setResource_config(resource);
+
+        return retInputs;
+    }
+
+    private void addTlsInfo(ComponentSpec cs, TreeMap<String, LinkedHashMap<String, Object>> retInputs) {
+        TlsInfo tlsInfo = new TlsInfo();
+        tlsInfo.setCertDirectory((String) cs.getAuxilary().getTls_info().get("cert_directory"));
+        GetInput useTLSFlag = new GetInput();
+        useTLSFlag.setBpInputName("use_tls");
+        tlsInfo.setUseTls(useTLSFlag);
+        this.setTls_info(tlsInfo);
+        LinkedHashMap<String, Object> useTlsFlagInput = BlueprintHelper.createInputValue("boolean",
+            "flag to indicate tls enable/disable",
+            cs.getAuxilary().getTls_info().get("use_tls"));
+        retInputs.put("use_tls", useTlsFlagInput);
+    }
+
+    private Map<String, LinkedHashMap<String, Object>> addExternalTlsInfo(ComponentSpec cs) {
+        this.setExternal_cert(externalCertFactory.createFromComponentSpec(cs));
+        return externalCertFactory.createInputListFromComponentSpec(cs);
+    }
+
 }