feat(security): creado SecurityConfig para controlar autorización según roles y autenticación

parent 87efc5f6
package com.example.apprecetas.user.infrastructure.config; package com.example.apprecetas.security.config;
import com.example.apprecetas.security.jwt.JwtAuthFilter;
import lombok.RequiredArgsConstructor;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpMethod;
import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.config.annotation.authentication.configuration.AuthenticationConfiguration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configurers.AbstractHttpConfigurer; import org.springframework.security.config.annotation.web.configurers.AbstractHttpConfigurer;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; import org.springframework.security.config.http.SessionCreationPolicy;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.web.SecurityFilterChain; import org.springframework.security.web.SecurityFilterChain;
import org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter;
@EnableWebSecurity
@Configuration @Configuration
@RequiredArgsConstructor
public class SecurityConfig { public class SecurityConfig {
@Bean private final JwtAuthFilter jwtAuthFilter;
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder(); private final CustomAuthenticationEntryPoint authenticationEntryPoint;
}
@Bean @Bean
public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
return http return http
.csrf(AbstractHttpConfigurer::disable) .csrf(AbstractHttpConfigurer::disable)
.headers(AbstractHttpConfigurer::disable) // necesario para h2-console .headers(AbstractHttpConfigurer::disable) // necesario para h2-console
.sessionManagement(AbstractHttpConfigurer::disable)
.httpBasic(AbstractHttpConfigurer::disable) .httpBasic(AbstractHttpConfigurer::disable)
.authorizeHttpRequests(request -> request .authorizeHttpRequests(request -> request
.anyRequest().permitAll() // permite TODO sin autenticación .requestMatchers("/auth/**").permitAll()
.requestMatchers(HttpMethod.GET, "/user").hasRole("ADMIN")
.anyRequest().authenticated()
) )
.sessionManagement(session -> session.sessionCreationPolicy(SessionCreationPolicy.STATELESS))
.addFilterBefore(jwtAuthFilter, UsernamePasswordAuthenticationFilter.class)
.exceptionHandling(ex -> ex.authenticationEntryPoint(authenticationEntryPoint))
.build(); .build();
} }
@Bean
public AuthenticationManager authenticationManager(AuthenticationConfiguration authConfig) throws Exception {
return authConfig.getAuthenticationManager();
}
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment