| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package org.apache.servicecomb.authentication; |
| |
| import java.util.Arrays; |
| |
| import org.apache.servicecomb.authentication.token.AbstractOpenIDTokenStore; |
| import org.apache.servicecomb.authentication.token.InMemoryOpenIDTokenStore; |
| import org.apache.servicecomb.authentication.util.Constants; |
| import org.springframework.beans.factory.annotation.Autowired; |
| import org.springframework.beans.factory.annotation.Qualifier; |
| import org.springframework.context.annotation.Bean; |
| import org.springframework.context.annotation.Configuration; |
| import org.springframework.security.core.authority.SimpleGrantedAuthority; |
| import org.springframework.security.core.userdetails.User; |
| import org.springframework.security.core.userdetails.UserDetails; |
| import org.springframework.security.core.userdetails.UserDetailsService; |
| import org.springframework.security.crypto.password.PasswordEncoder; |
| import org.springframework.security.crypto.password.Pbkdf2PasswordEncoder; |
| import org.springframework.security.jwt.crypto.sign.MacSigner; |
| import org.springframework.security.jwt.crypto.sign.SignerVerifier; |
| import org.springframework.security.provisioning.InMemoryUserDetailsManager; |
| |
| @Configuration |
| public class AuthenticationConfiguration { |
| @Bean(name = Constants.BEAN_AUTH_PASSWORD_ENCODER) |
| public PasswordEncoder authPasswordEncoder() { |
| return new Pbkdf2PasswordEncoder(); |
| } |
| |
| @Bean(name = {Constants.BEAN_AUTH_SIGNER, Constants.BEAN_AUTH_SIGNATURE_VERIFIER}) |
| public SignerVerifier authSignerVerifier() { |
| // If using RSA, need to configure authSigner and authSignatureVerifier separately. |
| // If using MacSigner, need to protect the shared key by properly encryption. |
| return new MacSigner("Please change this key."); |
| } |
| |
| @Bean(name = Constants.BEAN_AUTH_OPEN_ID_TOKEN_STORE) |
| public AbstractOpenIDTokenStore openIDTokenStore() { |
| // TODO: Use in memory store for testing. Need to implement JDBC or Redis SessionIDTokenStore in product. |
| return new InMemoryOpenIDTokenStore(); |
| } |
| |
| @Bean(name = Constants.BEAN_AUTH_USER_DETAILS_SERVICE) |
| public UserDetailsService authUserDetailsService( |
| @Autowired @Qualifier(Constants.BEAN_AUTH_PASSWORD_ENCODER) PasswordEncoder passwordEncoder) { |
| // TODO: Use in memory UserDetails, need to implement JDBC or others in product |
| InMemoryUserDetailsManager manager = new InMemoryUserDetailsManager(); |
| UserDetails uAdmin = new User("admin", passwordEncoder.encode("changeMyPassword"), |
| Arrays.asList(new SimpleGrantedAuthority("ADMIN"))); |
| UserDetails uGuest = new User("guest", passwordEncoder.encode("changeMyPassword"), |
| Arrays.asList(new SimpleGrantedAuthority("GUEST"))); |
| manager.createUser(uAdmin); |
| manager.createUser(uGuest); |
| return manager; |
| } |
| } |