56685ad5ed636a059236e1ee5736f780780e9ec4
[sdnc/apps.git] /
1 /*
2  * ============LICENSE_START===================================================
3  * Copyright (c) 2018 Amdocs
4  * ============================================================================
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  *        http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  * ============LICENSE_END=====================================================
17  */
18 package org.onap.sdnc.apps.pomba.servicedecomposition.service;
19
20 import org.json.JSONObject;
21 import org.onap.aai.restclient.client.RestClient;
22 import org.onap.logging.ref.slf4j.ONAPLogAdapter;
23 import org.onap.sdnc.apps.pomba.servicedecomposition.exception.DiscoveryException;
24 import org.onap.sdnc.apps.pomba.servicedecomposition.util.RestUtil;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
27 import org.springframework.beans.factory.annotation.Autowired;
28 import static org.onap.sdnc.apps.pomba.servicedecomposition.exception.DiscoveryException.Error.*;
29
30
31 @org.springframework.stereotype.Service
32 public class SpringServiceImpl implements SpringService {
33     private static Logger log = LoggerFactory.getLogger(SpringService.class);
34     public static final String APP_NAME = "ServiceDiscovery";
35
36     @Autowired
37     private RestClient aaiClient;
38
39     @Autowired
40     private String aaiBaseUrl;
41
42     @Autowired
43     private String aaiBasicAuthorization;
44
45     @Autowired
46     private String aaiServiceInstancePath;
47
48     @Autowired
49     private String aaiResourceList;
50
51     @Override
52     public String decomposeService(String fromAppId,
53                                    String transactionId,
54                                    String serviceInstanceId,
55                                    ONAPLogAdapter adapter) throws DiscoveryException {
56
57
58         log.info("Querying A&AI for service instance " + serviceInstanceId);
59         JSONObject serviceInstance = null;
60
61         try {
62             serviceInstance = RestUtil.retrieveAAIModelData(aaiClient, aaiBaseUrl, aaiBasicAuthorization, aaiServiceInstancePath, aaiResourceList,
63                     transactionId, serviceInstanceId, adapter);
64         } catch (DiscoveryException de) {
65             throw de;
66         } catch (Exception e) {
67             throw  new DiscoveryException(GENERAL_FAILURE, e , e.getLocalizedMessage());
68         }
69         return serviceInstance.toString();
70     }
71
72
73 }