summaryrefslogtreecommitdiffhomepage
path: root/backend/src/main/java/com/blog/web/controllers/AuthController.java
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);
    }
}