summaryrefslogtreecommitdiff
path: root/src/main/java/com/mavlushechka/studentdatabase/config/WebSecurityConfig.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/com/mavlushechka/studentdatabase/config/WebSecurityConfig.java')
-rwxr-xr-xsrc/main/java/com/mavlushechka/studentdatabase/config/WebSecurityConfig.java62
1 files changed, 62 insertions, 0 deletions
diff --git a/src/main/java/com/mavlushechka/studentdatabase/config/WebSecurityConfig.java b/src/main/java/com/mavlushechka/studentdatabase/config/WebSecurityConfig.java
new file mode 100755
index 0000000..99733d6
--- /dev/null
+++ b/src/main/java/com/mavlushechka/studentdatabase/config/WebSecurityConfig.java
@@ -0,0 +1,62 @@
+package com.mavlushechka.studentdatabase.config;
+
+import com.mavlushechka.studentdatabase.service.CustomUserDetailsService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
+import org.springframework.security.config.annotation.web.builders.HttpSecurity;
+import org.springframework.security.config.annotation.web.builders.WebSecurity;
+import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
+import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
+import org.springframework.security.core.userdetails.UserDetailsService;
+import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
+
+@Configuration
+@EnableWebSecurity
+public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
+ @Autowired
+ private BCryptPasswordEncoder bCryptPasswordEncoder;
+ @Autowired
+ CustomAuthenticationSuccessHandler customAuthenticationSuccessHandler;
+
+ @Bean
+ public UserDetailsService mongoUserDetails() {
+ return new CustomUserDetailsService();
+ }
+
+ @Override
+ protected void configure(AuthenticationManagerBuilder auth) throws Exception {
+ UserDetailsService userDetailsService = mongoUserDetails();
+ auth
+ .userDetailsService(userDetailsService)
+ .passwordEncoder(bCryptPasswordEncoder);
+ }
+
+ @Override
+ protected void configure(HttpSecurity http) throws Exception {
+ http
+ .authorizeRequests()
+ .antMatchers("/admin-panel/**").hasAuthority("ADMIN")
+ .anyRequest().authenticated()
+ .and()
+ .csrf()
+ .disable()
+ .formLogin()
+ .loginPage("/authentication/login")
+ .permitAll()
+ .and()
+ .logout()
+ .logoutSuccessUrl("/")
+ .permitAll()
+ .and()
+ .exceptionHandling();
+ }
+
+ @Override
+ public void configure(WebSecurity web) {
+ web
+ .ignoring()
+ .antMatchers("/js/**", "/css/**", "/img/**", "/fonts/**");
+ }
+} \ No newline at end of file