2 * Copyright 2016-2017 ZTE Corporation.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
16 package org.onap.aai.esr.resource;
18 import com.codahale.metrics.annotation.Timed;
19 import io.swagger.annotations.Api;
20 import io.swagger.annotations.ApiOperation;
21 import io.swagger.annotations.ApiResponse;
22 import io.swagger.annotations.ApiResponses;
23 import org.eclipse.jetty.http.HttpStatus;
24 import org.onap.aai.esr.entity.rest.VimRegisterInfo;
25 import org.onap.aai.esr.util.ExtsysUtil;
26 import org.onap.aai.esr.wrapper.VimManagerWrapper;
27 import org.slf4j.Logger;
28 import org.slf4j.LoggerFactory;
30 import javax.ws.rs.Consumes;
31 import javax.ws.rs.DELETE;
32 import javax.ws.rs.GET;
33 import javax.ws.rs.POST;
34 import javax.ws.rs.PUT;
35 import javax.ws.rs.Path;
36 import javax.ws.rs.PathParam;
37 import javax.ws.rs.Produces;
38 import javax.ws.rs.core.MediaType;
39 import javax.ws.rs.core.Response;
42 @Api(tags = {" vim Management "})
43 public class VimManager {
45 private static final Logger LOGGER = LoggerFactory.getLogger(VimManager.class);
47 private static ExtsysUtil extsysUtil = new ExtsysUtil();
53 @ApiOperation(value = "get all vim ")
54 @Produces(MediaType.APPLICATION_JSON)
55 @ApiResponses(value = {
56 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
57 response = String.class),
58 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
59 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
60 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
61 response = String.class)})
63 public Response queryVimList() {
64 return VimManagerWrapper.getInstance().queryVimListDetails();
70 @Path("/{cloudOwner}/{cloudRegionId}")
72 @ApiOperation(value = "get vim by id")
73 @Produces(MediaType.APPLICATION_JSON)
74 @ApiResponses(value = {
75 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
76 response = String.class),
77 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
78 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
79 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
80 response = String.class)})
82 public Response queryVimById(@PathParam("cloudOwner") String cloudOwner, @PathParam("cloudRegionId") String cloudRegionId) {
83 LOGGER.info("start query vim by cloud owner and cloud region id." + cloudOwner +"," + cloudRegionId);
84 return VimManagerWrapper.getInstance().queryVimById(cloudOwner, cloudRegionId);
90 @Path("/{cloudOwner}/{cloudRegionId}")
92 @ApiOperation(value = "delete a vim")
93 @ApiResponses(value = {
94 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
95 response = String.class),
96 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
97 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
98 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
99 response = String.class)})
101 public Response delvim(@PathParam("cloudOwner") String cloudOwner,@PathParam("cloudRegionId") String cloudRegionId) {
102 LOGGER.info("start delete cloud-owner :" + cloudOwner +", cloud-region-id: " + cloudRegionId);
103 return VimManagerWrapper.getInstance().delVim(cloudOwner, cloudRegionId);
110 @Path("/{cloudOwner}/{cloudRegionId}")
111 @Consumes(MediaType.APPLICATION_JSON)
112 @Produces(MediaType.APPLICATION_JSON)
113 @ApiOperation(value = "update a vim")
114 @ApiResponses(value = {
115 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
116 response = String.class),
117 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
118 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
119 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
120 response = String.class)})
122 public Response updatevims(@PathParam("cloudOwner") String cloudOwner, @PathParam("cloudRegionId") String cloudRegionId, VimRegisterInfo vim) {
123 LOGGER.info("start update vim info:" + extsysUtil.objectToString(vim));
124 return VimManagerWrapper.getInstance().updateVim(cloudOwner, cloudRegionId, vim);
131 @Consumes(MediaType.APPLICATION_JSON)
132 @Produces({MediaType.TEXT_PLAIN, MediaType.APPLICATION_JSON})
133 @ApiOperation(value = "create a vim")
134 @ApiResponses(value = {
135 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
136 response = String.class),
137 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
138 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
139 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
140 response = String.class)})
142 public Response registerVims(VimRegisterInfo vim) {
143 LOGGER.info("start add vim" + " info:" + extsysUtil.objectToString(vim));
144 return VimManagerWrapper.getInstance().registerVim(vim);