Realize the VNFM register API, Add Serializable annotation for AAI entity.
Change-Id: I74d1026b8f6dab06e4a1b36dd342635631c284a9
Issue-ID: AAI-310
Signed-off-by: lizi00164331 <li.zi30@zte.com.cn>
  */
 package org.onap.aai.esr.entity.aai;
 
+import java.io.Serializable;
 
-public class EsrEmsDetail {
+import com.google.gson.annotations.SerializedName;
 
+public class EsrEmsDetail implements Serializable {
+
+  public static final long serialVersionUID = 1L;
+  
+  @SerializedName("ems-id")
   private String emsId;
   
-  private String resouceVersion;
+  @SerializedName("resource-version")
+  private String resourceVersion;
   
+  @SerializedName("esr-system-info-list")
   private EsrSystemInfoList esrSystemInfoList;
 
   public String getEmsId() {
     this.esrSystemInfoList = esrSystemInfoList;
   }
 
-  public String getResouceVersion() {
-    return resouceVersion;
+  public String getResourceVersion() {
+    return resourceVersion;
   }
 
-  public void setResouceVersion(String resouceVersion) {
-    this.resouceVersion = resouceVersion;
+  public void setResourceVersion(String resourceVersion) {
+    this.resourceVersion = resourceVersion;
   }
 }
 
  */
 package org.onap.aai.esr.entity.aai;
 
-public class EsrThirdpartySdncDetail {
+import java.io.Serializable;
 
+import com.google.gson.annotations.SerializedName;
+
+public class EsrThirdpartySdncDetail implements Serializable {
+
+  public static final long serialVersionUID = 1L;
+  
+  @SerializedName("thirdparty-sdnc-id")
   private String thirdpartySdncId;
   
+  @SerializedName("location")
   private String location;
   
+  @SerializedName("product-name")
   private String productName;
   
+  @SerializedName("resouce-version")
   private String resouceVersion;
   
+  @SerializedName("esr-system-info-list")
   private EsrSystemInfoList esrSystemInfoList;
 
   public String getThirdpartySdncId() {
 
  */
 package org.onap.aai.esr.entity.aai;
 
-public class EsrVnfmDetail {
+import java.io.Serializable;
+
+import com.google.gson.annotations.SerializedName;
+
+public class EsrVnfmDetail implements Serializable {
+  
+  public static final long serialVersionUID = 1L;
   
+  @SerializedName("vnfm-id")
   private String vnfmId;
   
+  @SerializedName("vim-id")
   private String vimId;
   
+  @SerializedName("certificate-id")
   private String certificateUrl;
   
+  @SerializedName("resouce-version")
   private String resouceVersion;
   
+  @SerializedName("esr-system-info-list")
   private EsrSystemInfoList esrSystemInfoList;
 
   public String getVnfmId() {
 
         config, ICloudRegion.class);
   }
 
-
   public static void registerVim(String cloudOwner, String cloudRegionId, CloudRegionDetail cloudRegion)
       throws Exception {
     ClientConfig config = new ClientConfig(new RegisterVimProvider());
 
--- /dev/null
+/**
+ * Copyright 2017 ZTE Corporation.
+ *
+ * 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.
+ */
+package org.onap.aai.esr.externalservice.aai;
+
+import org.glassfish.jersey.client.ClientConfig;
+import org.onap.aai.esr.entity.aai.EsrVnfmDetail;
+
+import com.eclipsesource.jaxrs.consumer.ConsumerFactory;
+
+public class ExternalSystemProxy {
+
+  private static IExternalSystem adapterServiceproxy;
+
+  private static String transactionId = "9999";
+  private static String fromAppId = "esr-server";
+  private static String authorization = AaiCommon.getAuthenticationCredentials();
+  static {
+    ClientConfig config = new ClientConfig();
+    adapterServiceproxy = ConsumerFactory.createConsumer(AaiAdapterConfig.getExternalSystemAddr(),
+        config, IExternalSystem.class);
+  }
+
+  public static void registerVnfm(String vnfmId, EsrVnfmDetail esrVnfmDetail) throws Exception {
+    ClientConfig config = new ClientConfig(new RegisterVnfmProvider());
+    IExternalSystem registerVnfmServiceproxy = ConsumerFactory
+        .createConsumer(AaiAdapterConfig.getExternalSystemAddr(), config, IExternalSystem.class);
+    registerVnfmServiceproxy.registerVNFM(transactionId, fromAppId, authorization, vnfmId,
+        esrVnfmDetail);
+  }
+  
+  
+}
 
 import org.onap.aai.esr.entity.aai.EsrThirdpartySdncDetail;
 import org.onap.aai.esr.entity.aai.EsrVnfmDetail;
 
+@Path("/")
 public interface IExternalSystem {
 
   @PUT
 
 
 import com.google.gson.Gson;
 
-public class RegisterVimProvider  implements MessageBodyWriter<CloudRegionDetail>{
+public class RegisterVimProvider implements MessageBodyWriter<CloudRegionDetail>{
   private static final Logger logger = LoggerFactory.getLogger(RegisterVimProvider.class);
 
   @Override
       Annotation[] annotations, MediaType mediaType, MultivaluedMap<String, Object> httpHeaders,
       OutputStream entityStream) throws IOException, WebApplicationException {
     String json = new Gson().toJson(t, CloudRegionDetail.class);
-    logger.info("the param to createNetworkByAdapter input is:" + json);
+    logger.info("the param to register VIM input is:" + json);
     entityStream.write(json.getBytes("UTF-8"));
   }
 }
 
--- /dev/null
+/**
+ * Copyright 2017 ZTE Corporation.
+ *
+ * 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.
+ */
+package org.onap.aai.esr.externalservice.aai;
+
+import java.io.IOException;
+import java.io.OutputStream;
+import java.lang.annotation.Annotation;
+import java.lang.reflect.Type;
+
+import javax.ws.rs.WebApplicationException;
+import javax.ws.rs.core.MediaType;
+import javax.ws.rs.core.MultivaluedMap;
+import javax.ws.rs.ext.MessageBodyWriter;
+
+import org.onap.aai.esr.entity.aai.EsrVnfmDetail;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import com.google.gson.Gson;
+
+public class RegisterVnfmProvider  implements MessageBodyWriter<EsrVnfmDetail>{
+
+  private static final Logger logger = LoggerFactory.getLogger(RegisterVnfmProvider.class);
+
+  @Override
+  public boolean isWriteable(Class<?> type, Type genericType, Annotation[] annotations,
+      MediaType mediaType) {
+    return EsrVnfmDetail.class.isAssignableFrom(type);
+  }
+
+  @Override
+  public long getSize(EsrVnfmDetail t, Class<?> type, Type genericType,
+      Annotation[] annotations, MediaType mediaType) {
+    return -1;
+  }
+
+  @Override
+  public void writeTo(EsrVnfmDetail t, Class<?> type, Type genericType,
+      Annotation[] annotations, MediaType mediaType, MultivaluedMap<String, Object> httpHeaders,
+      OutputStream entityStream) throws IOException, WebApplicationException {
+    String json = new Gson().toJson(t, EsrVnfmDetail.class);
+    logger.info("the param to register VNFM input is:" + json);
+    entityStream.write(json.getBytes("UTF-8"));
+  }
+}
 
 
 public class VnfmManagerUtil {
   
-  public EsrVnfmDetail vnfmRegisterInfo2EsrVnfm(VnfmRegisterInfo vnfmRegisterInfo) {
+  public static EsrVnfmDetail vnfmRegisterInfo2EsrVnfm(VnfmRegisterInfo vnfmRegisterInfo) {
     EsrVnfmDetail esrVnfm = new EsrVnfmDetail();
     EsrSystemInfoList esrSystemInfo = new EsrSystemInfoList();
     EsrSystemInfo authInfo = new EsrSystemInfo();
    * @param vnfmRegisterInfo vnfm register informantion from portal
    * @return
    */
-  private EsrSystemInfo getAuthInfoFromVnfmRegisterInfo(VnfmRegisterInfo vnfmRegisterInfo) {
+  private static EsrSystemInfo getAuthInfoFromVnfmRegisterInfo(VnfmRegisterInfo vnfmRegisterInfo) {
     EsrSystemInfo authInfo = new EsrSystemInfo();
     authInfo.setEsrSystemInfoId(ExtsysUtil.generateId());
     authInfo.setSystemName(vnfmRegisterInfo.getName());
     return authInfo;
   }
   
-  public VnfmRegisterInfo esrVnfm2VnfmRegisterInfo(EsrVnfmDetail esrVnfm) {
+  public static VnfmRegisterInfo esrVnfm2VnfmRegisterInfo(EsrVnfmDetail esrVnfm) {
     VnfmRegisterInfo vnfmRegisterInfo = new VnfmRegisterInfo();
     EsrSystemInfo authInfo = new EsrSystemInfo();
     vnfmRegisterInfo.setVnfmId(esrVnfm.getVnfmId());
 
       result.setCloudRegionId(cloudRegionId);
       return Response.ok(result).build();
     } catch (Exception e) {
-      e.printStackTrace();
+      LOG.error("Register VIM failed !" + e.getMessage());
       return Response.serverError().build();
     }
   }
+  
   public Response updateVim(VimRegisterInfo vimRegisterInfo) {
     LOG.info("Start update VIM, input VIM info is: " + ExtsysUtil.objectToString(vimRegisterInfo));
     String cloudOwner = vimRegisterInfo.getCloudOwner();
       return Response.ok(result).build();
     } catch (Exception e) {
       e.printStackTrace();
+      LOG.error("Update VIM failed !" + e.getMessage());
       return Response.serverError().build();
     }
   }
 
 
 import javax.ws.rs.core.Response;
 
+import org.onap.aai.esr.entity.aai.EsrVnfmDetail;
 import org.onap.aai.esr.entity.rest.CommonRegisterResponse;
 import org.onap.aai.esr.entity.rest.VnfmRegisterInfo;
-//import org.slf4j.Logger;
-//import org.slf4j.LoggerFactory;
+import org.onap.aai.esr.externalservice.aai.ExternalSystemProxy;
+import org.onap.aai.esr.util.VnfmManagerUtil;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 
 public class VnfmManagerWrapper {
   private static VnfmManagerWrapper vnfmManagerWrapper;
-//  private static final Logger LOG = LoggerFactory.getLogger(VnfmManagerWrapper.class);
+  private static final Logger LOG = LoggerFactory.getLogger(VnfmManagerWrapper.class);
 
   /**
    * get VnfmManagerWrapper instance.
   }
 
   public Response registerVnfm(VnfmRegisterInfo vnfm) {
-    //TODO
-    CommonRegisterResponse result = null;
-    return Response.ok(result).build();
+    CommonRegisterResponse result = new CommonRegisterResponse();
+    EsrVnfmDetail esrVnfmDetail = new EsrVnfmDetail();
+    esrVnfmDetail = VnfmManagerUtil.vnfmRegisterInfo2EsrVnfm(vnfm);
+    String vnfmId = esrVnfmDetail.getVnfmId();
+    try {
+      ExternalSystemProxy.registerVnfm(vnfmId, esrVnfmDetail);
+      result.setId(vnfmId);
+      return Response.ok(result).build();
+    } catch (Exception e) {
+      LOG.error("Register VNFM failed !" + e.getMessage());
+      return Response.serverError().build();
+    }
   }
   
   public Response updateVnfm(VnfmRegisterInfo vnfm, String vnfmId) {