-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUserService.java
More file actions
58 lines (50 loc) · 2.23 KB
/
UserService.java
File metadata and controls
58 lines (50 loc) · 2.23 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package com.example.domain.user.service;
import com.example.domain.post.repository.PostRepository;
import com.example.domain.user.dto.CreateUserDto;
import com.example.domain.user.dto.UserDto;
import com.example.domain.user.entity.User;
import com.example.domain.user.repository.UserRepository;
import com.example.global.util.UserUtil;
import lombok.RequiredArgsConstructor;
import org.springframework.http.HttpStatus;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.stereotype.Service;
import org.springframework.web.server.ResponseStatusException;
import java.util.List;
import java.util.Optional;
@Service
@RequiredArgsConstructor
public class UserService {
private final UserRepository userRepository;
private final PostRepository postRepository;
private final PasswordEncoder passwordEncoder;
private final UserUtil userUtil;
public List<UserDto> getUsers() {
return userRepository.findAll().stream()
.map(UserDto::of)
.toList();
}
public void createUser(CreateUserDto createUserDto) {
if(isUserExist(createUserDto.getUsername())) throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Username already exists");
User user = User.builder()
.name(Optional.ofNullable(createUserDto.getUsername()).orElseThrow(
() -> new ResponseStatusException(HttpStatus.BAD_REQUEST, "Username is required"
)))
.password(
passwordEncoder.encode(Optional.ofNullable(createUserDto.getPassword()).orElseThrow(
() -> new ResponseStatusException(HttpStatus.BAD_REQUEST, "Password is required"
)))
)
.build();
userRepository.save(user);
}
public void deleteUser() {
User user = userUtil.getCurrentUser();
if(user == null) throw new ResponseStatusException(HttpStatus.UNAUTHORIZED, "you are not logged in");
postRepository.deleteAllByAuthorId(user.getId());
userRepository.deleteById(user.getId());
}
private boolean isUserExist(String username) {
return userRepository.findUserByName(username).isPresent();
}
}