Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
package com.example.secureapplication.service;

import com.example.secureapplication.user.AccountRecord;
import com.example.secureapplication.user.Role;
import java.util.LinkedHashSet;
import java.util.Set;
import javax.annotation.processing.Generated;
import org.springframework.stereotype.Component;

@Generated(
value = "org.mapstruct.ap.MappingProcessor",
date = "2023-10-15T09:59:06-0400",
comments = "version: 1.5.5.Final, compiler: IncrementalProcessingEnvironment from gradle-language-java-8.2.1.jar, environment: Java 17.0.8.1 (Amazon.com Inc.)"
)
@Component
public class AccountMapperImpl implements AccountMapper {

@Override
public AccountServiceLayerRecord toService(AccountRecord user) {
if ( user == null ) {
return null;
}

AccountServiceLayerRecord.AccountServiceLayerRecordBuilder accountServiceLayerRecord = AccountServiceLayerRecord.builder();

accountServiceLayerRecord.id( user.getId() );
accountServiceLayerRecord.username( user.getUsername() );
accountServiceLayerRecord.password( user.getPassword() );
accountServiceLayerRecord.email( user.getEmail() );
accountServiceLayerRecord.enabled( user.isEnabled() );

return accountServiceLayerRecord.build();
}

@Override
public AccountRecord toRepo(AccountServiceLayerRecord user) {
if ( user == null ) {
return null;
}

AccountRecord accountRecord = new AccountRecord();

accountRecord.setId( user.getId() );
accountRecord.setUsername( user.getUsername() );
accountRecord.setPassword( user.getPassword() );
accountRecord.setEmail( user.getEmail() );
Set<Role> set = user.getRoles();
if ( set != null ) {
accountRecord.setRoles( new LinkedHashSet<Role>( set ) );
}
accountRecord.setEnabled( user.isEnabled() );

return accountRecord;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
package com.example.secureapplication.config;

import org.mapstruct.MapperConfig;
import org.springframework.context.annotation.Configuration;

@Configuration
@MapperConfig(componentModel = "spring")
public class MappingConfig {}
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,10 @@
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.core.userdetails.User;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.provisioning.InMemoryUserDetailsManager;
import org.springframework.security.web.SecurityFilterChain;
import org.springframework.security.web.servlet.util.matcher.MvcRequestMatcher;
import org.springframework.web.servlet.handler.HandlerMappingIntrospector;

import static org.springframework.security.config.Customizer.withDefaults;
import static org.springframework.security.web.util.matcher.AntPathRequestMatcher.antMatcher;

//TODO:Remove the logger
Expand All @@ -23,7 +17,7 @@
@Slf4j
@Configuration
@EnableWebSecurity
public class SecSecurityConfig {
public class SecurityConfig {

/* @Bean
public InMemoryUserDetailsManager userDetailsService() {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
package com.example.secureapplication.repo;

import com.example.secureapplication.user.User;
import com.example.secureapplication.user.AccountRecord;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.stereotype.Repository;


@Repository
public interface UserRepository extends JpaRepository<User, Long>, JpaSpecificationExecutor<User> {
User findByUsername(String username);
public interface AccountDB extends JpaRepository<AccountRecord, Long>, JpaSpecificationExecutor<AccountRecord> {
AccountRecord findByUsername(String username);
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
import com.example.secureapplication.user.Role;
import org.springframework.data.jpa.repository.JpaRepository;

public interface RoleRepository extends JpaRepository<Role, Long> {
public interface RoleDB extends JpaRepository<Role, Long> {
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@

import com.example.secureapplication.data.AboutApp;
import com.example.secureapplication.data.AppInfo;
import com.example.secureapplication.service.UserDetailsServiceImpl;
import com.example.secureapplication.user.User;
import com.example.secureapplication.service.AccountDetails;
import com.example.secureapplication.service.AccountServiceLayerRecord;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
Expand All @@ -21,9 +21,9 @@ public class AppController {
private final AppInfo appInfo;
private final AboutApp aboutApp;

private final UserDetailsServiceImpl userDetailsService;
private final AccountDetails userDetailsService;

public AppController(AppInfo appInfo, AboutApp aboutApp, UserDetailsServiceImpl userDetailsService) {
public AppController(AppInfo appInfo, AboutApp aboutApp, AccountDetails userDetailsService) {

this.appInfo = appInfo;
this.aboutApp = aboutApp;
Expand All @@ -47,7 +47,7 @@ public void getUserInfo(){
}

@PostMapping("/user")
public void createUser(@RequestBody User user) {
userDetailsService.createUser(user);
public void createUser(@RequestBody AccountServiceLayerRecord accountRecord) {
userDetailsService.createUser(accountRecord);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
package com.example.secureapplication.service;

import com.example.secureapplication.repo.AccountDB;
import com.example.secureapplication.user.AccountRecord;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service;

@Service
public class AccountDetails implements UserDetailsService {
private final AccountDB accountDB;
private final AccountMapper mapper;

public AccountDetails(AccountDB accountDB, AccountMapper mapper) {
this.accountDB = accountDB;
this.mapper = mapper;
}

@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
AccountRecord accountRecord = accountDB.findByUsername(username);
if (accountRecord == null) {
throw new UsernameNotFoundException("User not found");
}
return new com.example.secureapplication.user.AccountDetails(accountRecord);
}

public UserDetails createUser(AccountServiceLayerRecord user) {
AccountRecord newAccountRecord = accountDB.save(mapper.toRepo(user));
return new com.example.secureapplication.user.AccountDetails(newAccountRecord);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package com.example.secureapplication.service;


import com.example.secureapplication.config.MappingConfig;
import com.example.secureapplication.user.AccountRecord;
import org.mapstruct.Mapper;
import org.springframework.stereotype.Component;

@Mapper(config = MappingConfig.class)
@Component
public interface AccountMapper {
AccountServiceLayerRecord toService(AccountRecord user);
AccountRecord toRepo(AccountServiceLayerRecord user);

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package com.example.secureapplication.service;


import com.example.secureapplication.user.Role;
import lombok.Builder;
import lombok.EqualsAndHashCode;
import lombok.Value;

import java.util.HashSet;
import java.util.Set;

@Value
@Builder
@EqualsAndHashCode
public class AccountServiceLayerRecord {

@EqualsAndHashCode.Include
Long id;
String username;
String password;
String email;
Set<Role> roles = new HashSet<>();
boolean enabled;
}

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,11 @@

@AllArgsConstructor
@NoArgsConstructor
public class UserDetailsImpl implements UserDetails {
private User user ;
public class AccountDetails implements UserDetails {
private AccountRecord accountRecord;
@Override
public Collection<? extends GrantedAuthority> getAuthorities() {
Set<Role> roles = user.getRoles();
Set<Role> roles = accountRecord.getRoles();
List<SimpleGrantedAuthority> authorities = new ArrayList<>();

for (Role role : roles) {
Expand All @@ -29,12 +29,12 @@ public Collection<? extends GrantedAuthority> getAuthorities() {

@Override
public String getPassword() {
return user.getPassword();
return accountRecord.getPassword();
}

@Override
public String getUsername() {
return user.getUsername();
return accountRecord.getUsername();
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,7 @@
@Data
@Entity
@Table(name = "users")
/*@AllArgsConstructor
@NoArgsConstructor
@Getter
@Setter*/
public class User implements Serializable {
public class AccountRecord implements Serializable {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
Expand Down