2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 - 2019 AT&T Intellectual Property. All rights reserved.
6 * Modifications Copyright (C) 2019 Nokia.
7 * ================================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ============LICENSE_END=========================================================
22 package org.onap.vid.controller;
24 import static org.onap.vid.utils.Logging.getMethodName;
26 import com.fasterxml.jackson.databind.ObjectMapper;
27 import java.io.IOException;
28 import java.util.List;
30 import java.util.UUID;
31 import java.util.stream.Collectors;
32 import javax.servlet.http.HttpServletRequest;
33 import javax.ws.rs.DefaultValue;
34 import javax.ws.rs.QueryParam;
35 import javax.ws.rs.WebApplicationException;
36 import javax.ws.rs.core.Response;
37 import org.apache.commons.lang3.tuple.ImmutablePair;
38 import org.apache.commons.lang3.tuple.Pair;
39 import org.onap.portalsdk.core.controller.RestrictedBaseController;
40 import org.onap.portalsdk.core.logging.logic.EELFLoggerDelegate;
41 import org.onap.portalsdk.core.util.SystemProperties;
42 import org.onap.vid.aai.AaiGetVnfResponse;
43 import org.onap.vid.aai.AaiResponse;
44 import org.onap.vid.aai.AaiResponseTranslator.PortMirroringConfigData;
45 import org.onap.vid.aai.ServiceInstancesSearchResults;
46 import org.onap.vid.aai.SubscriberFilteredResults;
47 import org.onap.vid.aai.model.AaiGetInstanceGroupsByCloudRegion;
48 import org.onap.vid.aai.model.AaiGetOperationalEnvironments.OperationalEnvironmentList;
49 import org.onap.vid.aai.model.AaiGetPnfs.Pnf;
50 import org.onap.vid.aai.model.AaiGetTenatns.GetTenantsResponse;
51 import org.onap.vid.aai.util.AAIRestInterface;
52 import org.onap.vid.model.VersionByInvariantIdsRequest;
53 import org.onap.vid.roles.Role;
54 import org.onap.vid.roles.RoleProvider;
55 import org.onap.vid.roles.RoleValidator;
56 import org.onap.vid.services.AaiService;
57 import org.onap.vid.utils.SystemPropertiesWrapper;
58 import org.onap.vid.utils.Unchecked;
59 import org.springframework.beans.factory.annotation.Autowired;
60 import org.springframework.http.HttpStatus;
61 import org.springframework.http.MediaType;
62 import org.springframework.http.ResponseEntity;
63 import org.springframework.web.bind.annotation.PathVariable;
64 import org.springframework.web.bind.annotation.RequestBody;
65 import org.springframework.web.bind.annotation.RequestMapping;
66 import org.springframework.web.bind.annotation.RequestMethod;
67 import org.springframework.web.bind.annotation.RequestParam;
68 import org.springframework.web.bind.annotation.RestController;
69 import org.springframework.web.servlet.HandlerMapping;
70 import org.springframework.web.servlet.ModelAndView;
74 public class AaiController extends RestrictedBaseController {
76 private static final EELFLoggerDelegate LOGGER = EELFLoggerDelegate.getLogger(AaiController.class);
77 private static final String FROM_APP_ID = "VidAaiController";
79 private AaiService aaiService;
80 private AAIRestInterface aaiRestInterface;
81 private RoleProvider roleProvider;
82 private SystemPropertiesWrapper systemPropertiesWrapper;
85 public AaiController(AaiService aaiService,
86 AAIRestInterface aaiRestInterface,
87 RoleProvider roleProvider,
88 SystemPropertiesWrapper systemPropertiesWrapper) {
90 this.aaiService = aaiService;
91 this.aaiRestInterface = aaiRestInterface;
92 this.roleProvider = roleProvider;
93 this.systemPropertiesWrapper = systemPropertiesWrapper;
96 @RequestMapping(value = {"/subscriberSearch"}, method = RequestMethod.GET)
97 public ModelAndView welcome() {
98 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== AaiController welcome start");
99 return new ModelAndView(getViewName());
102 @RequestMapping(value = {"/aai_get_aic_zones"}, method = RequestMethod.GET)
103 public ResponseEntity<String> getAicZones() throws IOException {
104 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== getAicZones controller start");
105 AaiResponse response = aaiService.getAaiZones();
106 return aaiResponseToResponseEntity(response);
109 @RequestMapping(value = {
110 "/aai_get_aic_zone_for_pnf/{globalCustomerId}/{serviceType}/{serviceId}"}, method = RequestMethod.GET)
111 public ResponseEntity<String> getAicZoneForPnf(@PathVariable("globalCustomerId") String globalCustomerId,
112 @PathVariable("serviceType") String serviceType, @PathVariable("serviceId") String serviceId) throws IOException {
113 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== getAicZoneForPnf controller start");
114 AaiResponse response = aaiService.getAicZoneForPnf(globalCustomerId, serviceType, serviceId);
115 return aaiResponseToResponseEntity(response);
118 @RequestMapping(value = {"/aai_get_instance_groups_by_vnf_instance_id/{vnfInstanceId}"}, method = RequestMethod.GET)
119 public ResponseEntity<String> getInstanceGroupsByVnfInstanceId(@PathVariable("vnfInstanceId") String vnfInstanceId) throws IOException {
120 AaiResponse response = aaiService.getInstanceGroupsByVnfInstanceId(vnfInstanceId);
121 return aaiResponseToResponseEntity(response);
124 @RequestMapping(value = {"/getuserID"}, method = RequestMethod.GET)
125 public ResponseEntity<String> getUserID(HttpServletRequest request) {
127 String userId = new ControllersUtils(systemPropertiesWrapper).extractUserId(request);
129 return new ResponseEntity<>(userId, HttpStatus.OK);
132 @RequestMapping(value = "/aai_get_services", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
133 public ResponseEntity<String> doGetServices(HttpServletRequest request) throws IOException {
134 RoleValidator roleValidator = RoleValidator.by(roleProvider.getUserRoles(request));
136 AaiResponse subscriberList = aaiService.getServices(roleValidator);
137 return aaiResponseToResponseEntity(subscriberList);
141 @RequestMapping(value = {"/aai_get_version_by_invariant_id"}, method = RequestMethod.POST)
142 public ResponseEntity<String> getVersionByInvariantId(@RequestBody VersionByInvariantIdsRequest versions) {
143 Response result = aaiService.getVersionByInvariantId(versions.versions);
145 return new ResponseEntity<>(result.readEntity(String.class), HttpStatus.OK);
149 private ResponseEntity<String> aaiResponseToResponseEntity(AaiResponse aaiResponseData)
151 ResponseEntity<String> responseEntity;
152 ObjectMapper objectMapper = new ObjectMapper();
153 if (aaiResponseData.getHttpCode() == 200) {
154 responseEntity = new ResponseEntity<>(objectMapper.writeValueAsString(aaiResponseData.getT()),
157 responseEntity = new ResponseEntity<>(aaiResponseData.getErrorMessage(),
158 HttpStatus.valueOf(aaiResponseData.getHttpCode()));
160 return responseEntity;
163 @RequestMapping(value = "/aai_get_service_instance/{service-instance-id}/{service-instance-type}", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
164 public ResponseEntity<String> doGetServiceInstance(@PathVariable("service-instance-id") String serviceInstanceId,
165 @PathVariable("service-instance-type") String serviceInstanceType) {
166 Response resp = null;
168 if (serviceInstanceType.equalsIgnoreCase("Service Instance Id")) {
170 "search/nodes-query?search-node-type=service-instance&filter=service-instance-id:EQUALS:"
171 + serviceInstanceId, false);
174 "search/nodes-query?search-node-type=service-instance&filter=service-instance-name:EQUALS:"
175 + serviceInstanceId, false);
177 return convertResponseToResponseEntity(resp);
180 @RequestMapping(value = "/aai_get_service_subscription/{global-customer-id}/{service-subscription-id}", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
181 public ResponseEntity<String> doGetServices(@PathVariable("global-customer-id") String globalCustomerId,
182 @PathVariable("service-subscription-id") String serviceSubscriptionId) {
183 Response resp = doAaiGet("business/customers/customer/" + globalCustomerId
184 + "/service-subscriptions/service-subscription/" + serviceSubscriptionId + "?depth=0", false);
185 return convertResponseToResponseEntity(resp);
188 @RequestMapping(value = "/aai_get_subscribers", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
189 public ResponseEntity<String> doGetSubscriberList(HttpServletRequest request,
190 @DefaultValue("n") @QueryParam("fullSet") String fullSet) throws IOException {
191 return getFullSubscriberList(request);
194 @RequestMapping(value = "/get_system_prop_vnf_prov_status", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
195 public ResponseEntity<String> getTargetProvStatus() {
196 String p = SystemProperties.getProperty("aai.vnf.provstatus");
197 return new ResponseEntity<>(p, HttpStatus.OK);
200 @RequestMapping(value = "/get_operational_environments", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
201 public AaiResponse<OperationalEnvironmentList> getOperationalEnvironments(
202 @RequestParam(value = "operationalEnvironmentType", required = false) String operationalEnvironmentType,
203 @RequestParam(value = "operationalEnvironmentStatus", required = false) String operationalEnvironmentStatus) {
204 LOGGER.debug(EELFLoggerDelegate.debugLogger, "start {}({}, {})", getMethodName(), operationalEnvironmentType,
205 operationalEnvironmentStatus);
206 AaiResponse<OperationalEnvironmentList> response = aaiService
207 .getOperationalEnvironments(operationalEnvironmentType, operationalEnvironmentStatus);
208 if (response.getHttpCode() != 200) {
209 String errorMessage = getAaiErrorMessage(response.getErrorMessage());
210 if (errorMessage != null) {
211 response = new AaiResponse<>(response.getT(), errorMessage, response.getHttpCode());
215 LOGGER.debug(EELFLoggerDelegate.debugLogger, "end {}() => {}", getMethodName(), response);
219 @RequestMapping(value = "/aai_get_full_subscribers", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
220 public ResponseEntity<String> getFullSubscriberList(HttpServletRequest request) throws IOException {
221 ObjectMapper objectMapper = new ObjectMapper();
222 ResponseEntity<String> responseEntity;
223 RoleValidator roleValidator = RoleValidator.by(roleProvider.getUserRoles(request));
224 SubscriberFilteredResults subscriberList = aaiService.getFullSubscriberList(roleValidator);
225 if (subscriberList.getHttpCode() == 200) {
226 responseEntity = new ResponseEntity<>(objectMapper.writeValueAsString(subscriberList.getSubscriberList()),
229 responseEntity = new ResponseEntity<>(subscriberList.getErrorMessage(),
230 HttpStatus.valueOf(subscriberList.getHttpCode()));
233 return responseEntity;
237 @RequestMapping(value = "/get_vnf_data_by_globalid_and_service_type/{globalCustomerId}/{serviceType}",
238 method = RequestMethod.GET,
239 produces = MediaType.APPLICATION_JSON_VALUE)
240 public ResponseEntity<String> getVnfDataByGlobalIdAndServiceType(
241 @PathVariable("globalCustomerId") String globalCustomerId,
242 @PathVariable("serviceType") String serviceType) throws IOException {
244 AaiResponse<AaiGetVnfResponse> resp = aaiService.getVNFData(globalCustomerId, serviceType);
245 return aaiResponseToResponseEntity(resp);
248 @RequestMapping(value = "/aai_refresh_subscribers", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
249 public ResponseEntity<String> doRefreshSubscriberList() {
250 return refreshSubscriberList();
253 @RequestMapping(value = "/aai_refresh_full_subscribers", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
254 public ResponseEntity<String> doRefreshFullSubscriberList() {
255 return refreshSubscriberList();
258 protected ResponseEntity<String> refreshSubscriberList() {
259 Response resp = getSubscribers();
260 return convertResponseToResponseEntity(resp);
263 @RequestMapping(value = "/aai_sub_details/{subscriberId}", method = RequestMethod.GET)
264 public ResponseEntity<String> GetSubscriberDetails(HttpServletRequest request,
265 @PathVariable("subscriberId") String subscriberId) throws IOException {
266 ObjectMapper objectMapper = new ObjectMapper();
267 ResponseEntity responseEntity;
268 List<Role> roles = roleProvider.getUserRoles(request);
269 RoleValidator roleValidator = RoleValidator.by(roles);
270 AaiResponse subscriberData = aaiService.getSubscriberData(subscriberId, roleValidator);
271 String httpMessage = subscriberData.getT() != null ?
272 objectMapper.writeValueAsString(subscriberData.getT()) :
273 subscriberData.getErrorMessage();
275 responseEntity = new ResponseEntity<>(httpMessage, HttpStatus.valueOf(subscriberData.getHttpCode()));
276 return responseEntity;
279 @RequestMapping(value = "/search_service_instances", method = RequestMethod.GET)
280 public ResponseEntity<String> SearchServiceInstances(HttpServletRequest request,
281 @RequestParam(value = "subscriberId", required = false) String subscriberId,
282 @RequestParam(value = "serviceInstanceIdentifier", required = false) String instanceIdentifier,
283 @RequestParam(value = "project", required = false) List<String> projects,
284 @RequestParam(value = "owningEntity", required = false) List<String> owningEntities) throws IOException {
285 ObjectMapper objectMapper = new ObjectMapper();
286 ResponseEntity responseEntity;
288 List<Role> roles = roleProvider.getUserRoles(request);
289 RoleValidator roleValidator = RoleValidator.by(roles);
291 AaiResponse<ServiceInstancesSearchResults> searchResult = aaiService
292 .getServiceInstanceSearchResults(subscriberId, instanceIdentifier, roleValidator, owningEntities, projects);
294 String httpMessage = searchResult.getT() != null ?
295 objectMapper.writeValueAsString(searchResult.getT()) :
296 searchResult.getErrorMessage();
298 if (searchResult.getT().serviceInstances.isEmpty()) {
299 responseEntity = new ResponseEntity<>(httpMessage, HttpStatus.NOT_FOUND);
302 responseEntity = new ResponseEntity<>(httpMessage, HttpStatus.valueOf(searchResult.getHttpCode()));
305 return responseEntity;
308 @RequestMapping(value = "/aai_sub_viewedit/{namedQueryId}/{globalCustomerId}/{serviceType}/{serviceInstance}", method = RequestMethod.GET)
309 public ResponseEntity<String> viewEditGetComponentList(
310 @PathVariable("namedQueryId") String namedQueryId,
311 @PathVariable("globalCustomerId") String globalCustomerId,
312 @PathVariable("serviceType") String serviceType,
313 @PathVariable("serviceInstance") String serviceInstance) {
315 String componentListPayload = getComponentListPutPayload(namedQueryId, globalCustomerId, serviceType,
318 Response resp = doAaiPost("search/named-query", componentListPayload, false);
319 return convertResponseToResponseEntity(resp);
322 @RequestMapping(value = "/aai_get_models_by_service_type/{namedQueryId}/{globalCustomerId}/{serviceType}", method = RequestMethod.GET)
323 public ResponseEntity<String> viewEditGetComponentList(
324 @PathVariable("namedQueryId") String namedQueryId,
325 @PathVariable("globalCustomerId") String globalCustomerId,
326 @PathVariable("serviceType") String serviceType) {
328 String componentListPayload = getModelsByServiceTypePayload(namedQueryId, globalCustomerId, serviceType);
330 Response resp = doAaiPost("search/named-query", componentListPayload, false);
331 return convertResponseToResponseEntity(resp);
334 @RequestMapping(value = "/aai_get_vnf_instances/{globalCustomerId}/{serviceType}/{modelVersionId}/{modelInvariantId}/{cloudRegion}", method = RequestMethod.GET)
335 public ResponseEntity<String> getNodeTemplateInstances(
336 @PathVariable("globalCustomerId") String globalCustomerId,
337 @PathVariable("serviceType") String serviceType,
338 @PathVariable("modelVersionId") String modelVersionId,
339 @PathVariable("modelInvariantId") String modelInvariantId,
340 @PathVariable("cloudRegion") String cloudRegion) {
342 AaiResponse<String> resp = aaiService
343 .getNodeTemplateInstances(globalCustomerId, serviceType, modelVersionId, modelInvariantId, cloudRegion);
344 return new ResponseEntity<>(resp.getT(), HttpStatus.valueOf(resp.getHttpCode()));
347 @RequestMapping(value = "/aai_get_network_collection_details/{serviceInstanceId}", method = RequestMethod.GET)
348 public ResponseEntity<String> getNetworkCollectionDetails(
349 @PathVariable("serviceInstanceId") String serviceInstanceId) throws IOException {
350 com.fasterxml.jackson.databind.ObjectMapper objectMapper = new com.fasterxml.jackson.databind.ObjectMapper();
351 AaiResponse<String> resp = aaiService.getNetworkCollectionDetails(serviceInstanceId);
353 String httpMessage = resp.getT() != null ?
354 objectMapper.writeValueAsString(resp.getT()) :
355 resp.getErrorMessage();
356 return new ResponseEntity<>(httpMessage, HttpStatus.valueOf(resp.getHttpCode()));
359 @RequestMapping(value = "/aai_get_instance_groups_by_cloudregion/{cloudOwner}/{cloudRegionId}/{networkFunction}", method = RequestMethod.GET)
360 public ResponseEntity<String> getInstanceGroupsByCloudRegion(@PathVariable("cloudOwner") String cloudOwner,
361 @PathVariable("cloudRegionId") String cloudRegionId,
362 @PathVariable("networkFunction") String networkFunction) throws IOException {
363 com.fasterxml.jackson.databind.ObjectMapper objectMapper = new com.fasterxml.jackson.databind.ObjectMapper();
364 AaiResponse<AaiGetInstanceGroupsByCloudRegion> resp = aaiService
365 .getInstanceGroupsByCloudRegion(cloudOwner, cloudRegionId, networkFunction);
367 String httpMessage = resp.getT() != null ?
368 objectMapper.writeValueAsString(resp.getT()) :
369 resp.getErrorMessage();
370 return new ResponseEntity<>(httpMessage, HttpStatus.valueOf(resp.getHttpCode()));
373 @RequestMapping(value = "/aai_get_by_uri/**", method = RequestMethod.GET)
374 public ResponseEntity<String> getByUri(HttpServletRequest request) {
376 String restOfTheUrl = (String) request.getAttribute(
377 HandlerMapping.PATH_WITHIN_HANDLER_MAPPING_ATTRIBUTE);
378 String formattedUri = restOfTheUrl.replaceFirst("/aai_get_by_uri/", "").replaceFirst("^aai/v[\\d]+/", "");
380 Response resp = doAaiGet(formattedUri, false);
382 return convertResponseToResponseEntity(resp);
385 @RequestMapping(value = "/aai_get_configuration/{configuration_id}", method = RequestMethod.GET)
386 public ResponseEntity<String> getSpecificConfiguration(@PathVariable("configuration_id") String configurationId) {
388 Response resp = doAaiGet("network/configurations/configuration/" + configurationId, false);
390 return convertResponseToResponseEntity(resp);
393 @RequestMapping(value = "/aai_get_service_instance_pnfs/{globalCustomerId}/{serviceType}/{serviceInstanceId}", method = RequestMethod.GET)
394 public List<String> getServiceInstanceAssociatedPnfs(
395 @PathVariable("globalCustomerId") String globalCustomerId,
396 @PathVariable("serviceType") String serviceType,
397 @PathVariable("serviceInstanceId") String serviceInstanceId) {
399 return aaiService.getServiceInstanceAssociatedPnfs(globalCustomerId, serviceType, serviceInstanceId);
402 @RequestMapping(value = "/aai_get_pnfs/pnf/{pnf_id}", method = RequestMethod.GET)
403 public ResponseEntity getSpecificPnf(@PathVariable("pnf_id") String pnfId) {
404 AaiResponse<Pnf> resp;
405 ResponseEntity<Pnf> re;
407 resp = aaiService.getSpecificPnf(pnfId);
408 re = new ResponseEntity<>(resp.getT(), HttpStatus.valueOf(resp.getHttpCode()));
409 } catch (Exception e) {
410 return new ResponseEntity<String>(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
415 @RequestMapping(value = "/aai_get_tenants/{global-customer-id}/{service-type}", method = RequestMethod.GET)
416 public ResponseEntity<String> viewEditGetTenantsFromServiceType(HttpServletRequest request,
417 @PathVariable("global-customer-id") String globalCustomerId, @PathVariable("service-type") String serviceType) {
419 ResponseEntity responseEntity;
421 ObjectMapper objectMapper = new ObjectMapper();
422 List<Role> roles = roleProvider.getUserRoles(request);
423 RoleValidator roleValidator = RoleValidator.by(roles);
424 AaiResponse<GetTenantsResponse[]> response = aaiService
425 .getTenants(globalCustomerId, serviceType, roleValidator);
426 if (response.getHttpCode() == 200) {
427 responseEntity = new ResponseEntity<>(objectMapper.writeValueAsString(response.getT()),
430 responseEntity = new ResponseEntity<>(response.getErrorMessage(),
431 HttpStatus.valueOf(response.getHttpCode()));
433 } catch (Exception e) {
434 responseEntity = new ResponseEntity<>("Unable to proccess getTenants reponse",
435 HttpStatus.INTERNAL_SERVER_ERROR);
437 return responseEntity;
440 @RequestMapping(value = "/aai_get_pnf_instances/{globalCustomerId}/{serviceType}/{modelVersionId}/{modelInvariantId}/{cloudRegion}/{equipVendor}/{equipModel}", method = RequestMethod.GET)
441 public ResponseEntity<String> getPnfInstances(
442 @PathVariable("globalCustomerId") String globalCustomerId,
443 @PathVariable("serviceType") String serviceType,
444 @PathVariable("modelVersionId") String modelVersionId,
445 @PathVariable("modelInvariantId") String modelInvariantId,
446 @PathVariable("cloudRegion") String cloudRegion,
447 @PathVariable("equipVendor") String equipVendor,
448 @PathVariable("equipModel") String equipModel) {
450 AaiResponse<String> resp = aaiService
451 .getPNFData(globalCustomerId, serviceType, modelVersionId, modelInvariantId, cloudRegion, equipVendor,
453 return new ResponseEntity<>(resp.getT(), HttpStatus.valueOf(resp.getHttpCode()));
456 @RequestMapping(value = "/aai_getPortMirroringConfigsData", method = RequestMethod.GET)
457 public Map<String, PortMirroringConfigData> getPortMirroringConfigsData(
458 @RequestParam("configurationIds") List<String> configurationIds) {
460 return configurationIds.stream()
461 .map(id -> ImmutablePair.of(id, aaiService.getPortMirroringConfigData(id)))
462 .collect(Collectors.toMap(Pair::getKey, Pair::getValue));
465 @RequestMapping(value = "/aai_getPortMirroringSourcePorts", method = RequestMethod.GET)
466 public Map<String, Object> getPortMirroringSourcePorts(
467 @RequestParam("configurationIds") List<String> configurationIds) {
469 return configurationIds.stream()
470 .map(id -> ImmutablePair.of(id, aaiService.getPortMirroringSourcePorts(id)))
471 .collect(Collectors.toMap(Pair::getKey, Pair::getValue));
474 private ResponseEntity<String> convertResponseToResponseEntity(Response resp) {
475 ResponseEntity<String> respEnt;
477 respEnt = new ResponseEntity<>("Failed to fetch data from A&AI, check server logs for details.",
478 HttpStatus.INTERNAL_SERVER_ERROR);
480 respEnt = new ResponseEntity<>(resp.readEntity(String.class), HttpStatus.valueOf(resp.getStatus()));
485 private Response getSubscribers() {
489 Response resp = doAaiGet("business/customers?subscriber-type=INFRA&depth=" + depth, false);
492 .debug(EELFLoggerDelegate.debugLogger, "<== getSubscribers() resp=" + resp.getStatusInfo().toString());
497 protected Response doAaiGet(String uri, boolean xml) {
498 String methodName = "getSubscriberList";
499 String transId = UUID.randomUUID().toString();
500 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== " + methodName + " start");
502 Response resp = null;
505 resp = aaiRestInterface.RestGet(FROM_APP_ID, transId, Unchecked.toURI(uri), xml).getResponse();
507 } catch (WebApplicationException e) {
508 final String message = e.getResponse().readEntity(String.class);
509 LOGGER.info(EELFLoggerDelegate.errorLogger, "<== " + "." + methodName + message);
510 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== " + "." + methodName + message);
511 } catch (Exception e) {
512 LOGGER.info(EELFLoggerDelegate.errorLogger, "<== " + "." + methodName + e.toString());
513 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== " + "." + methodName + e.toString());
519 protected Response doAaiPost(String uri, String payload, boolean xml) {
520 String methodName = "getSubscriberList";
521 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== " + methodName + " start");
523 Response resp = null;
526 resp = aaiRestInterface.RestPost(FROM_APP_ID, uri, payload, xml);
528 } catch (Exception e) {
529 LOGGER.info(EELFLoggerDelegate.errorLogger, "<== " + "." + methodName + e.toString());
530 LOGGER.debug(EELFLoggerDelegate.debugLogger, "<== " + "." + methodName + e.toString());
536 private String getComponentListPutPayload(String namedQueryId, String globalCustomerId, String serviceType,
537 String serviceInstance) {
540 " \"instance-filters\": {" +
541 " \"instance-filter\": [" +
544 " \"global-customer-id\": \"" + globalCustomerId + "\"" +
546 " \"service-instance\": {" +
547 " \"service-instance-id\": \"" + serviceInstance + "\"" +
549 " \"service-subscription\": {" +
550 " \"service-type\": \"" + serviceType + "\"" +
555 " \"query-parameters\": {" +
556 " \"named-query\": {" +
557 " \"named-query-uuid\": \"" + namedQueryId + "\"" +
564 private String getModelsByServiceTypePayload(String namedQueryId, String globalCustomerId, String serviceType) {
565 // TODO Auto-generated method stub
567 " \"instance-filters\": {" +
568 " \"instance-filter\": [" +
571 " \"global-customer-id\": \"" + globalCustomerId + "\"" +
573 " \"service-subscription\": {" +
574 " \"service-type\": \"" + serviceType + "\"" +
579 " \"query-parameters\": {" +
580 " \"named-query\": {" +
581 " \"named-query-uuid\": \"" + namedQueryId + "\"" +
588 private String getAaiErrorMessage(String message) {
590 org.json.JSONObject json = new org.json.JSONObject(message);
591 json = json.getJSONObject("requestError").getJSONObject("serviceException");
593 return json.getString("messageId") + ": " + json.getString("text");
595 } catch (Exception e) {