2017-08-08 10:01:06 +07:00
|
|
|
package io.spring.api;
|
|
|
|
|
2021-03-03 14:26:48 +07:00
|
|
|
import static org.springframework.web.bind.annotation.RequestMethod.POST;
|
|
|
|
|
2017-08-08 10:01:06 +07:00
|
|
|
import com.fasterxml.jackson.annotation.JsonRootName;
|
2021-03-03 14:26:48 +07:00
|
|
|
import io.spring.api.exception.InvalidAuthenticationException;
|
2017-08-18 16:08:27 +07:00
|
|
|
import io.spring.application.UserQueryService;
|
|
|
|
import io.spring.application.data.UserData;
|
2021-03-03 14:26:48 +07:00
|
|
|
import io.spring.application.data.UserWithToken;
|
2021-03-16 16:16:20 +07:00
|
|
|
import io.spring.application.user.RegisterParam;
|
|
|
|
import io.spring.application.user.UserService;
|
2017-08-18 16:08:27 +07:00
|
|
|
import io.spring.core.service.JwtService;
|
2017-08-14 10:09:11 +07:00
|
|
|
import io.spring.core.user.EncryptService;
|
2017-08-08 10:01:06 +07:00
|
|
|
import io.spring.core.user.User;
|
|
|
|
import io.spring.core.user.UserRepository;
|
2021-03-03 14:26:48 +07:00
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.Optional;
|
|
|
|
import javax.validation.Valid;
|
2018-05-10 13:50:44 +07:00
|
|
|
import javax.validation.constraints.Email;
|
|
|
|
import javax.validation.constraints.NotBlank;
|
2021-03-03 14:26:48 +07:00
|
|
|
import lombok.Getter;
|
|
|
|
import lombok.NoArgsConstructor;
|
2017-08-08 10:01:06 +07:00
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.http.ResponseEntity;
|
|
|
|
import org.springframework.web.bind.annotation.RequestBody;
|
|
|
|
import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
|
|
|
@RestController
|
|
|
|
public class UsersApi {
|
2021-03-03 14:26:48 +07:00
|
|
|
private UserRepository userRepository;
|
|
|
|
private UserQueryService userQueryService;
|
|
|
|
private EncryptService encryptService;
|
|
|
|
private JwtService jwtService;
|
2021-03-16 16:16:20 +07:00
|
|
|
private UserService userService;
|
2017-08-08 10:01:06 +07:00
|
|
|
|
2021-03-03 14:26:48 +07:00
|
|
|
@Autowired
|
|
|
|
public UsersApi(
|
|
|
|
UserRepository userRepository,
|
|
|
|
UserQueryService userQueryService,
|
|
|
|
EncryptService encryptService,
|
2021-03-16 16:16:20 +07:00
|
|
|
JwtService jwtService,
|
|
|
|
UserService userService) {
|
2021-03-03 14:26:48 +07:00
|
|
|
this.userRepository = userRepository;
|
|
|
|
this.userQueryService = userQueryService;
|
|
|
|
this.encryptService = encryptService;
|
|
|
|
this.jwtService = jwtService;
|
2021-03-16 16:16:20 +07:00
|
|
|
this.userService = userService;
|
2021-03-03 14:26:48 +07:00
|
|
|
}
|
2017-08-18 16:08:27 +07:00
|
|
|
|
2021-03-03 14:26:48 +07:00
|
|
|
@RequestMapping(path = "/users", method = POST)
|
|
|
|
public ResponseEntity createUser(@Valid @RequestBody RegisterParam registerParam) {
|
2021-03-16 16:16:20 +07:00
|
|
|
User user = userService.createUser(registerParam);
|
2021-03-03 14:26:48 +07:00
|
|
|
UserData userData = userQueryService.findById(user.getId()).get();
|
|
|
|
return ResponseEntity.status(201)
|
|
|
|
.body(userResponse(new UserWithToken(userData, jwtService.toToken(user))));
|
|
|
|
}
|
2017-08-18 16:08:27 +07:00
|
|
|
|
2021-03-03 14:26:48 +07:00
|
|
|
@RequestMapping(path = "/users/login", method = POST)
|
|
|
|
public ResponseEntity userLogin(@Valid @RequestBody LoginParam loginParam) {
|
|
|
|
Optional<User> optional = userRepository.findByEmail(loginParam.getEmail());
|
|
|
|
if (optional.isPresent()
|
|
|
|
&& encryptService.check(loginParam.getPassword(), optional.get().getPassword())) {
|
|
|
|
UserData userData = userQueryService.findById(optional.get().getId()).get();
|
|
|
|
return ResponseEntity.ok(
|
|
|
|
userResponse(new UserWithToken(userData, jwtService.toToken(optional.get()))));
|
|
|
|
} else {
|
|
|
|
throw new InvalidAuthenticationException();
|
2017-08-14 10:09:11 +07:00
|
|
|
}
|
2021-03-03 14:26:48 +07:00
|
|
|
}
|
2017-08-14 10:09:11 +07:00
|
|
|
|
2021-03-03 14:26:48 +07:00
|
|
|
private Map<String, Object> userResponse(UserWithToken userWithToken) {
|
|
|
|
return new HashMap<String, Object>() {
|
|
|
|
{
|
|
|
|
put("user", userWithToken);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
2017-08-15 16:52:23 +07:00
|
|
|
|
2017-08-14 10:09:11 +07:00
|
|
|
@Getter
|
|
|
|
@JsonRootName("user")
|
|
|
|
@NoArgsConstructor
|
|
|
|
class LoginParam {
|
2021-03-03 14:26:48 +07:00
|
|
|
@NotBlank(message = "can't be empty")
|
|
|
|
@Email(message = "should be an email")
|
|
|
|
private String email;
|
|
|
|
|
|
|
|
@NotBlank(message = "can't be empty")
|
|
|
|
private String password;
|
2017-08-14 10:09:11 +07:00
|
|
|
}
|