package com.wediscussmovies.project.configuration; import com.wediscussmovies.project.service.UserService; import org.springframework.security.authentication.AuthenticationProvider; import org.springframework.security.authentication.BadCredentialsException; import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; import org.springframework.security.core.Authentication; import org.springframework.security.core.userdetails.UserDetails; import org.springframework.security.crypto.password.PasswordEncoder; import org.springframework.stereotype.Component; import javax.naming.AuthenticationException; @Component public class CustomUsernamePasswordAuthenticationProvider implements AuthenticationProvider { private final UserService userService; private final PasswordEncoder passwordEncoder; public CustomUsernamePasswordAuthenticationProvider(UserService userService, PasswordEncoder passwordEncoder) { this.userService = userService; this.passwordEncoder = passwordEncoder; } @Override public Authentication authenticate(Authentication authentication){ String username = authentication.getName(); String password = authentication.getCredentials().toString(); if ("".equals(username) || "".equals(password)) { throw new BadCredentialsException("Invalid Credentials"); } UserDetails userDetails = this.userService.loadUserByUsername(username); if (!passwordEncoder.matches(password, userDetails.getPassword())) { throw new BadCredentialsException("Password is incorrect!"); } return new UsernamePasswordAuthenticationToken(userDetails, userDetails.getPassword(), userDetails.getAuthorities()); } @Override public boolean supports(Class aClass) { return aClass.equals(UsernamePasswordAuthenticationToken.class); } }