Add HTTPS support between SOL003 Adapter and ETSI
[so.git] / adapters / mso-vnfm-adapter / mso-vnfm-etsi-adapter / src / main / java / org / onap / so / adapters / vnfmadapter / packagemanagement / 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.vnfmadapter.packagemanagement.subscriptionmanagement;
21
22 import static org.slf4j.LoggerFactory.getLogger;
23 import org.onap.so.adapters.vnfmadapter.extclients.vnfm.packagemanagement.model.SubscriptionsAuthentication;
24 import org.onap.so.adapters.vnfmadapter.extclients.vnfm.packagemanagement.model.SubscriptionsAuthentication.AuthTypeEnum;
25 import org.onap.so.adapters.vnfmadapter.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         final String token = getAccessToken(subscriptionsAuthentication);
49
50         if (token == null) {
51             logger.error("Failed to get access token");
52             return false;
53         }
54
55         final HttpHeadersProvider httpHeadersProvider = getHttpHeadersProvider(token);
56         final HttpRestServiceProvider httpRestServiceProvider = getHttpRestServiceProvider();
57         final ResponseEntity<Void> responseEntity = httpRestServiceProvider.postHttpRequest(notification, callbackUri,
58                 httpHeadersProvider.getHttpHeaders(), Void.class);
59         if (responseEntity.getStatusCode().is2xxSuccessful()) {
60             logger.info("Notification sent successfully.");
61             return true;
62         }
63
64         logger.error("Failed to send notification.");
65         return false;
66     }
67
68     @Override
69     public AuthTypeEnum getAuthType() {
70         return AuthTypeEnum.OAUTH2_CLIENT_CREDENTIALS;
71     }
72
73     private BasicHttpHeadersProvider getHttpHeadersProvider(final String token) {
74         final String authHeader = "Bearer " + token;
75         return new BasicHttpHeadersProvider(authHeader);
76     }
77
78     private String getAccessToken(final SubscriptionsAuthentication subscriptionsAuthentication) {
79         logger.info("Requesting Access Token.");
80
81         final String tokenEndpoint = subscriptionsAuthentication.getParamsOauth2ClientCredentials().getTokenEndpoint();
82
83         final HttpHeadersProvider httpHeadersProvider = getBasicHttpHeadersProviderWithBasicAuth(
84                 subscriptionsAuthentication.getParamsOauth2ClientCredentials().getClientId(),
85                 subscriptionsAuthentication.getParamsOauth2ClientCredentials().getClientPassword());
86
87         final HttpRestServiceProvider httpRestServiceProvider = getHttpRestServiceProvider();
88         final ResponseEntity<OAuthTokenResponse> responseEntity = httpRestServiceProvider.postHttpRequest(null,
89                 tokenEndpoint, httpHeadersProvider.getHttpHeaders(), OAuthTokenResponse.class);
90         if (responseEntity.getStatusCode().is2xxSuccessful()) {
91             if (responseEntity.getBody() != null) {
92                 logger.info("Returning Access Token.");
93                 return responseEntity.getBody().getAccessToken();
94             }
95         }
96
97         final String errorMessage = "An error occurred.  Unable to retrieve OAuth Token from VNFM for notification.";
98         logger.error(errorMessage);
99         throw new InternalServerErrorException(errorMessage);
100     }
101
102
103 }