Refactor SOL003 Adapter to organize its modules
[so.git] / adapters / etsi-sol003-adapter / etsi-sol003-package-management / etsi-sol003-package-management-adapter / src / main / java / org / onap / so / adapters / etsisol003adapter / pkgm / subscriptionmanagement / OAuthNotificationServiceProvider.java
1 /*-
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2020 Ericsson. All rights reserved.
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  * 
17  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20 package org.onap.so.adapters.etsisol003adapter.pkgm.subscriptionmanagement;
21
22 import static org.slf4j.LoggerFactory.getLogger;
23 import org.onap.so.adapters.etsisol003adapter.pkgm.model.SubscriptionsAuthentication;
24 import org.onap.so.adapters.etsisol003adapter.pkgm.model.SubscriptionsAuthentication.AuthTypeEnum;
25 import org.onap.so.adapters.etsisol003adapter.pkgm.rest.exceptions.InternalServerErrorException;
26 import org.onap.so.configuration.rest.BasicHttpHeadersProvider;
27 import org.onap.so.configuration.rest.HttpHeadersProvider;
28 import org.onap.so.rest.service.HttpRestServiceProvider;
29 import org.slf4j.Logger;
30 import org.springframework.http.ResponseEntity;
31 import org.springframework.stereotype.Service;
32
33 /**
34  * @author Waqas Ikram (waqas.ikram@est.tech)
35  * @author Andrew Lamb (andrew.a.lamb@est.tech)
36  *
37  */
38 @Service
39 public class OAuthNotificationServiceProvider extends AbstractNotificationServiceProvider
40         implements NotificationServiceProvider {
41
42     private static final Logger logger = getLogger(OAuthNotificationServiceProvider.class);
43
44     @Override
45     public boolean send(final Object notification, final SubscriptionsAuthentication subscriptionsAuthentication,
46             final String callbackUri) {
47         logger.info("Sending notification to uri: {}", callbackUri);
48         logger.info("Object: {}", notification);
49         final String token = getAccessToken(subscriptionsAuthentication);
50
51         if (token == null) {
52             logger.error("Failed to get access token");
53             return false;
54         }
55
56         final HttpHeadersProvider httpHeadersProvider = getHttpHeadersProvider(token);
57         final HttpRestServiceProvider httpRestServiceProvider = getHttpRestServiceProvider();
58         final ResponseEntity<Void> responseEntity = httpRestServiceProvider.postHttpRequest(notification, callbackUri,
59                 httpHeadersProvider.getHttpHeaders(), Void.class);
60         if (responseEntity.getStatusCode().is2xxSuccessful()) {
61             logger.info("Notification sent successfully.");
62             return true;
63         }
64
65         logger.error("Failed to send notification.");
66         return false;
67     }
68
69     @Override
70     public AuthTypeEnum getAuthType() {
71         return AuthTypeEnum.OAUTH2_CLIENT_CREDENTIALS;
72     }
73
74     private BasicHttpHeadersProvider getHttpHeadersProvider(final String token) {
75         final String authHeader = "Bearer " + token;
76         return new BasicHttpHeadersProvider(authHeader);
77     }
78
79     private String getAccessToken(final SubscriptionsAuthentication subscriptionsAuthentication) {
80         logger.info("Requesting Access Token.");
81
82         final String tokenEndpoint = subscriptionsAuthentication.getParamsOauth2ClientCredentials().getTokenEndpoint();
83
84         final HttpHeadersProvider httpHeadersProvider = getBasicHttpHeadersProviderWithBasicAuth(
85                 subscriptionsAuthentication.getParamsOauth2ClientCredentials().getClientId(),
86                 subscriptionsAuthentication.getParamsOauth2ClientCredentials().getClientPassword());
87
88         final HttpRestServiceProvider httpRestServiceProvider = getHttpRestServiceProvider();
89         final ResponseEntity<OAuthTokenResponse> responseEntity = httpRestServiceProvider.postHttpRequest(null,
90                 tokenEndpoint, httpHeadersProvider.getHttpHeaders(), OAuthTokenResponse.class);
91         if (responseEntity.getStatusCode().is2xxSuccessful()) {
92             if (responseEntity.getBody() != null) {
93                 logger.info("Returning Access Token.");
94                 return responseEntity.getBody().getAccessToken();
95             }
96         }
97
98         final String errorMessage = "An error occurred.  Unable to retrieve OAuth Token from VNFM for notification.";
99         logger.error(errorMessage);
100         throw new InternalServerErrorException(errorMessage);
101     }
102
103
104 }