private ApiKey apiKey() {
return new ApiKey("JWT", "Authorization", "header");
}
private SecurityContext securityContext() {
return SecurityContext.builder().securityReferences(defaultAuth()).build();
}
private List<SecurityReference> defaultAuth() {
AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything");
AuthorizationScope[] authorizationScopes = new AuthorizationScope[1];
authorizationScopes[0] = authorizationScope;
return Arrays.asList(new SecurityReference("JWT", authorizationScopes));
}
@Bean
protected SecurityFilterChain configureAuthorization (HttpSecurity http) throws Exception{
return http.cors(cors -> corsFilter()).csrf(csrf -> csrf.disable())
.authorizeHttpRequests(auth -> auth
.requestMatchers(AUTH_WHITE_LIST).permitAll()
.requestMatchers("/api/auth/**", "/api/verify", "/api/users/createReader").permitAll()
.anyRequest().authenticated())
.sessionManagement(session -> session.sessionCreationPolicy(SessionCreationPolicy.STATELESS))
.exceptionHandling(exception -> exception.authenticationEntryPoint((request, response, ex) -> {
response.sendError(HttpServletResponse.SC_UNAUTHORIZED, ex.getMessage());
}))
.addFilterBefore(jwtFilter, UsernamePasswordAuthenticationFilter.class)
.build();
}
public void configure(WebSecurity web) throws Exception {
web.ignoring().requestMatchers(AUTH_WHITE_LIST);
}
private ApiKey apiKey() {
return new ApiKey("JWT", "Authorization", "header");
}
private SecurityContext securityContext() {
return SecurityContext.builder().securityReferences(defaultAuth()).build();
}
private List<SecurityReference> defaultAuth() {
AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything");
AuthorizationScope[] authorizationScopes = new AuthorizationScope[1];
authorizationScopes[0] = authorizationScope;
return Arrays.asList(new SecurityReference("JWT", authorizationScopes));
}
@Bean
protected SecurityFilterChain configureAuthorization (HttpSecurity http) throws Exception{
return http.cors(cors -> corsFilter()).csrf(csrf -> csrf.disable())
.authorizeHttpRequests(auth -> auth
.requestMatchers(AUTH_WHITE_LIST).permitAll()
.requestMatchers("/api/auth/**", "/api/verify", "/api/users/createReader").permitAll()
.anyRequest().authenticated())
.sessionManagement(session -> session.sessionCreationPolicy(SessionCreationPolicy.STATELESS))
.exceptionHandling(exception -> exception.authenticationEntryPoint((request, response, ex) -> {
response.sendError(HttpServletResponse.SC_UNAUTHORIZED, ex.getMessage());
}))
.addFilterBefore(jwtFilter, UsernamePasswordAuthenticationFilter.class)
.build();
}
public void configure(WebSecurity web) throws Exception {
web.ignoring().requestMatchers(AUTH_WHITE_LIST);
}