import javax.ws.rs.core.Response;
-import org.onap.aai.esr.entity.rest.RegisterResponse;
+import org.onap.aai.esr.entity.aai.CloudRegion;
import org.onap.aai.esr.entity.rest.VimRegisterInfo;
-//import org.slf4j.Logger;
-//import org.slf4j.LoggerFactory;
+import org.onap.aai.esr.entity.rest.VimRegisterResponse;
+import org.onap.aai.esr.externalservice.aai.CloudRegionProxy;
+import org.onap.aai.esr.util.ExtsysUtil;
+import org.onap.aai.esr.util.VimManagerUtil;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import com.google.gson.Gson;
+
public class VimManagerWrapper {
private static VimManagerWrapper vimManagerWrapper;
-// private static final Logger LOG = LoggerFactory.getLogger(VimManagerWrapper.class);
+ private static final Logger LOG = LoggerFactory.getLogger(VimManagerWrapper.class);
/**
* get VimManagerWrapper instance.
vimManagerWrapper = new VimManagerWrapper();
}
return vimManagerWrapper;
+
}
- public Response registerVim(VimRegisterInfo vim) {
- //TODO
- RegisterResponse result = null;
- return Response.ok(result).build();
+ public Response registerVim(VimRegisterInfo vimRegisterInfo) {
+ LOG.info("Start register VIM, input VIM info is: " + ExtsysUtil.objectToString(vimRegisterInfo));
+ CloudRegion cloudRegion = new CloudRegion();
+ VimRegisterResponse result = new VimRegisterResponse();
+ cloudRegion = VimManagerUtil.vimRegisterInfo2CloudRegion(vimRegisterInfo);
+ String cloud_owner = vimRegisterInfo.getCloudOwner();
+ String cloud_region_id = vimRegisterInfo.getCloudRegionId();
+
+ try {
+ CloudRegionProxy.registerVim(cloud_owner, cloud_region_id, cloudRegion);
+ result.setCloudOwner(cloud_owner);
+ result.setCloudRegionId(cloud_region_id);
+ return Response.ok(result).build();
+ } catch (Exception e) {
+ e.printStackTrace();
+ return Response.serverError().build();
+ }
}
public Response updateVim(VimRegisterInfo vim) {
return Response.ok(vimList).build();
}
- public Response queryVimById(String vimId) {
+ public Response queryVimById(String cloudOwner, String cloudRegionId) {
VimRegisterInfo vim = new VimRegisterInfo();
- //TODO
- return Response.ok(vim).build();
+ CloudRegion cloudRegion = new CloudRegion();
+ try {
+ String cloudRegionstr = CloudRegionProxy.queryVimDetail(cloudOwner, cloudRegionId);
+ LOG.info("Response from AAI by query VIM: " + cloudRegionstr);
+ cloudRegion = new Gson().fromJson(cloudRegionstr, CloudRegion.class);
+ vim = VimManagerUtil.cloudRegion2VimRegisterInfo(cloudRegion);
+ return Response.ok(vim).build();
+ } catch (Exception e) {
+ e.printStackTrace();
+ return Response.serverError().build();
+ }
+
}
public Response delVim(String vimId) {