Fixing SO build
[so.git] / adapters / etsi-sol003-adapter / etsi-sol003-lcm / etsi-sol003-lcm-adapter / src / main / java / org / onap / so / adapters / vnfmadapter / oauth / AuthorizationServerConfig.java
1 /*-
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2019 Nordix Foundation.
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
21 package org.onap.so.adapters.vnfmadapter.oauth;
22
23 import org.onap.so.utils.CryptoUtils;
24 import org.springframework.beans.factory.annotation.Value;
25 import org.springframework.context.annotation.Configuration;
26 import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
27 import org.springframework.security.oauth2.config.annotation.configurers.ClientDetailsServiceConfigurer;
28 import org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerConfigurerAdapter;
29 import org.springframework.security.oauth2.config.annotation.web.configuration.EnableAuthorizationServer;
30
31 @Configuration
32 @EnableAuthorizationServer
33 /**
34  * Configures the authorization server for oauth token based authentication.
35  */
36 public class AuthorizationServerConfig extends AuthorizationServerConfigurerAdapter {
37
38     private static final int ONE_DAY = 60 * 60 * 24;
39
40     @Value("${vnfmadapter.auth:E39823AAB2739CC654C4E92B52C05BC34149342D0A46451B00CA508C8EDC62242CE4E9DA9445D3C01A3F13}")
41     private String vnfmAdapterAuth;
42
43     @Value("${mso.key}")
44     private String msoEncryptionKey;
45
46     @Override
47     public void configure(final ClientDetailsServiceConfigurer clients) throws Exception {
48         final String[] decrypedAuth = CryptoUtils.decrypt(vnfmAdapterAuth, msoEncryptionKey).split(":");
49         BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();
50         clients.inMemory().withClient(decrypedAuth[0]).secret(passwordEncoder.encode(decrypedAuth[1]))
51                 .authorizedGrantTypes("client_credentials").scopes("write").accessTokenValiditySeconds(ONE_DAY)
52                 .refreshTokenValiditySeconds(ONE_DAY);
53     }
54
55 }