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
 
   9  *      http://www.apache.org/licenses/LICENSE-2.0
 
  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.
 
  17  * SPDX-License-Identifier: Apache-2.0
 
  18  * ============LICENSE_END=========================================================
 
  20 package org.onap.so.adapters.etsi.sol003.adapter.packagemanagement.subscriptionmanagement;
 
  22 import static org.slf4j.LoggerFactory.getLogger;
 
  23 import org.onap.so.adapters.etsi.sol003.adapter.packagemanagement.model.SubscriptionsAuthentication;
 
  24 import org.onap.so.adapters.etsi.sol003.adapter.packagemanagement.model.SubscriptionsAuthentication.AuthTypeEnum;
 
  25 import org.onap.so.adapters.etsi.sol003.adapter.packagemanagement.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;
 
  34  * @author Waqas Ikram (waqas.ikram@est.tech)
 
  35  * @author Andrew Lamb (andrew.a.lamb@est.tech)
 
  39 public class OAuthNotificationServiceProvider extends AbstractNotificationServiceProvider
 
  40         implements NotificationServiceProvider {
 
  42     private static final Logger logger = getLogger(OAuthNotificationServiceProvider.class);
 
  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);
 
  51             logger.error("Failed to get access token");
 
  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.");
 
  64         logger.error("Failed to send notification.");
 
  69     public AuthTypeEnum getAuthType() {
 
  70         return AuthTypeEnum.OAUTH2_CLIENT_CREDENTIALS;
 
  73     private BasicHttpHeadersProvider getHttpHeadersProvider(final String token) {
 
  74         final String authHeader = "Bearer " + token;
 
  75         return new BasicHttpHeadersProvider(authHeader);
 
  78     private String getAccessToken(final SubscriptionsAuthentication subscriptionsAuthentication) {
 
  79         logger.info("Requesting Access Token.");
 
  81         final String tokenEndpoint = subscriptionsAuthentication.getParamsOauth2ClientCredentials().getTokenEndpoint();
 
  83         final HttpHeadersProvider httpHeadersProvider = getBasicHttpHeadersProviderWithBasicAuth(
 
  84                 subscriptionsAuthentication.getParamsOauth2ClientCredentials().getClientId(),
 
  85                 subscriptionsAuthentication.getParamsOauth2ClientCredentials().getClientPassword());
 
  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();
 
  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);