2 * Copyright 2016 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.ApiParam;
22 import io.swagger.annotations.ApiResponse;
23 import io.swagger.annotations.ApiResponses;
25 import org.eclipse.jetty.http.HttpStatus;
26 import org.onap.aai.esr.entity.db.EmsData;
27 import org.onap.aai.esr.entity.rest.EmsRestData;
28 import org.onap.aai.esr.exception.ExtsysException;
29 import org.onap.aai.esr.handle.EmsHandler;
30 import org.onap.aai.esr.util.ExtsysDbUtil;
31 import org.onap.aai.esr.util.RestResponseUtil;
32 import org.slf4j.Logger;
33 import org.slf4j.LoggerFactory;
35 import java.util.ArrayList;
36 import java.util.List;
37 import javax.ws.rs.Consumes;
38 import javax.ws.rs.DELETE;
39 import javax.ws.rs.GET;
40 import javax.ws.rs.POST;
41 import javax.ws.rs.PUT;
42 import javax.ws.rs.Path;
43 import javax.ws.rs.PathParam;
44 import javax.ws.rs.Produces;
45 import javax.ws.rs.core.MediaType;
46 import javax.ws.rs.core.Response;
49 @Api(tags = {" ems Management "})
50 public class EmsManager {
52 EmsHandler handler = new EmsHandler();
53 private static final Logger LOGGER = LoggerFactory.getLogger(EmsManager.class);
60 @ApiOperation(value = "get all ems ")
61 @Produces(MediaType.APPLICATION_JSON)
62 @ApiResponses(value = {
63 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
64 response = String.class),
65 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
66 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
67 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
68 response = String.class)})
70 public Response queryEmsList() {
71 LOGGER.info("start query all ems!");
74 list = handler.getAll();
75 } catch (ExtsysException error) {
76 LOGGER.error("query all ems failed.errorMsg:" + error.getErrorMsg());
77 return RestResponseUtil.getErrorResponse(error);
79 if (list == null || list.size() <= 0) {
80 LOGGER.info("query all ems end.no match condition record");
81 return RestResponseUtil.getSuccessResponse(new ArrayList<EmsRestData>());
83 LOGGER.info("query all ems end.size:" + list.size());
84 ArrayList<EmsRestData> restList = new ArrayList<EmsRestData>();
85 for (int i = 0; i < list.size(); i++) {
86 restList.add(new EmsRestData(list.get(i)));
88 return RestResponseUtil.getSuccessResponse(restList);
94 * query ems info by id.
98 @ApiOperation(value = "get ems by id")
99 @Produces(MediaType.APPLICATION_JSON)
100 @ApiResponses(value = {
101 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
102 response = String.class),
103 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
104 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
105 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
106 response = String.class)})
108 public Response queryemsById(@ApiParam(value = "ems id") @PathParam("emsId") String emsId) {
109 LOGGER.info("start query ems by id." + emsId);
112 list = handler.getEmsById(emsId);
113 } catch (ExtsysException error) {
114 LOGGER.error("query ems failed.errorMsg:" + error.getErrorMsg());
115 return RestResponseUtil.getErrorResponse(error);
117 if (list == null || list.size() <= 0) {
118 LOGGER.info("query ems end.no match condition record");
119 return RestResponseUtil.getSuccessResponse(null);
121 LOGGER.info("query ems end.info:" + ExtsysDbUtil.objectToString(list));
122 return RestResponseUtil.getSuccessResponse(new EmsRestData(list.get(0)));
131 @ApiOperation(value = "delete a ems")
132 @ApiResponses(value = {
133 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
134 response = String.class),
135 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
136 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
137 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
138 response = String.class)})
140 public Response delems(@ApiParam(value = "ems id") @PathParam("emsId") String emsId) {
141 LOGGER.info("start delete ems .id:" + emsId);
143 handler.delete(emsId);
144 } catch (ExtsysException error) {
145 LOGGER.error("delete ems failed.errorMsg:" + error.getErrorMsg());
146 return RestResponseUtil.getErrorResponse(error);
148 LOGGER.info(" delete ems end !");
149 return Response.noContent().build();
157 @Consumes(MediaType.APPLICATION_JSON)
158 @Produces({MediaType.TEXT_PLAIN, MediaType.APPLICATION_JSON})
159 @ApiOperation(value = "update a ems")
160 @ApiResponses(value = {
161 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
162 response = String.class),
163 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
164 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
165 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
166 response = String.class)})
168 public Response updateemss(@ApiParam(value = "ems", required = true) EmsData ems,
169 @ApiParam(value = "ems id", required = true) @PathParam("emsId") String emsId) {
170 LOGGER.info("start update ems .id:" + emsId + " info:" + ExtsysDbUtil.objectToString(ems));
173 newData = handler.update(ems, emsId);
174 } catch (ExtsysException error) {
175 LOGGER.error("update ems failed.errorMsg:" + error.getErrorMsg());
176 return RestResponseUtil.getErrorResponse(error);
178 LOGGER.info(" update ems end !");
179 return RestResponseUtil.getSuccessResponse(new EmsRestData(newData));
187 @Consumes(MediaType.APPLICATION_JSON)
188 @Produces({MediaType.TEXT_PLAIN, MediaType.APPLICATION_JSON})
189 @ApiOperation(value = "create a ems")
190 @ApiResponses(value = {
191 @ApiResponse(code = HttpStatus.NOT_FOUND_404, message = "microservice not found",
192 response = String.class),
193 @ApiResponse(code = HttpStatus.UNSUPPORTED_MEDIA_TYPE_415,
194 message = "Unprocessable MicroServiceInfo Entity ", response = String.class),
195 @ApiResponse(code = HttpStatus.INTERNAL_SERVER_ERROR_500, message = "internal server error",
196 response = String.class)})
198 public Response addemss(@ApiParam(value = "ems", required = true) EmsData ems) {
199 LOGGER.info("start add ems" + " info:" + ExtsysDbUtil.objectToString(ems));
202 emsData = handler.add(ems);
203 } catch (ExtsysException error) {
204 LOGGER.error("add ems failed.errorMsg:" + error.getErrorMsg());
205 return RestResponseUtil.getErrorResponse(error);
207 LOGGER.info(" add ems end !");
208 return RestResponseUtil.getCreateSussceeResponse(new EmsRestData(emsData));