blob: 039393cbc0d00484ae7572f051ee12f066975ce9 (
plain)
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
|
package com.blog.web.controllers;
import com.blog.web.dto.RegistrationDto;
import com.blog.web.dto.UserPublicDto;
import com.blog.web.models.UserEntity;
import com.blog.web.services.UserService;
import jakarta.validation.Valid;
import org.apache.commons.lang3.StringUtils;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.*;
@CrossOrigin(origins = "http://localhost:5173", allowCredentials = "true", allowedHeaders = "*")
@RestController
@RequestMapping("/api/v1")
public class AuthController {
private final UserService userService;
public AuthController(UserService userService) {
this.userService = userService;
}
//@PostMapping("/register/save")
@PostMapping("/register")
public RegistrationDto register(@Valid @ModelAttribute("user") RegistrationDto user, BindingResult result) {
UserEntity existingUserEmail = userService.findByEmail(user.getEmail()).orElse(null);
if (existingUserEmail != null && StringUtils.isBlank(existingUserEmail.getEmail())) {
result.rejectValue("email", "There is already a user with this email");
}
UserEntity existingUsername = userService.findByUsername(user.getUsername()).orElse(null);
if (existingUsername != null && StringUtils.isBlank(existingUsername.getUsername())) {
result.rejectValue("username", "There is already a user with this username");
}
if (!result.hasErrors()) {
userService.saveUser(user);
}
return user;
}
@GetMapping("/profile")
public UserPublicDto profile() {
final UserEntity user = userService.getLoggedInUser().orElse(new UserEntity());
return new UserPublicDto(user);
}
}
|