structure update
This commit is contained in:
parent
ce6a56e1db
commit
b97bf72311
@ -6,6 +6,7 @@ import com.fasterxml.jackson.databind.SerializerProvider;
|
|||||||
import com.fasterxml.jackson.databind.module.SimpleModule;
|
import com.fasterxml.jackson.databind.module.SimpleModule;
|
||||||
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
|
import org.joda.time.format.ISODateTimeFormat;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
|
||||||
@ -36,7 +37,7 @@ public class JacksonCustomizations {
|
|||||||
if (value == null) {
|
if (value == null) {
|
||||||
gen.writeNull();
|
gen.writeNull();
|
||||||
} else {
|
} else {
|
||||||
gen.writeString(value.toString());
|
gen.writeString(ISODateTimeFormat.dateTime().withZoneUTC().print(value));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,9 +3,9 @@ package io.spring.api;
|
|||||||
import com.fasterxml.jackson.annotation.JsonRootName;
|
import com.fasterxml.jackson.annotation.JsonRootName;
|
||||||
import io.spring.api.exception.NoAuthorizationException;
|
import io.spring.api.exception.NoAuthorizationException;
|
||||||
import io.spring.api.exception.ResourceNotFoundException;
|
import io.spring.api.exception.ResourceNotFoundException;
|
||||||
import io.spring.application.AuthorizationService;
|
import io.spring.core.service.AuthorizationService;
|
||||||
import io.spring.application.article.ArticleData;
|
import io.spring.application.data.ArticleData;
|
||||||
import io.spring.application.article.ArticleQueryService;
|
import io.spring.application.ArticleQueryService;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.spring.api.exception.ResourceNotFoundException;
|
import io.spring.api.exception.ResourceNotFoundException;
|
||||||
import io.spring.application.article.ArticleData;
|
import io.spring.application.data.ArticleData;
|
||||||
import io.spring.application.article.ArticleQueryService;
|
import io.spring.application.ArticleQueryService;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.favorite.ArticleFavorite;
|
import io.spring.core.favorite.ArticleFavorite;
|
||||||
|
@ -3,7 +3,7 @@ package io.spring.api;
|
|||||||
import com.fasterxml.jackson.annotation.JsonRootName;
|
import com.fasterxml.jackson.annotation.JsonRootName;
|
||||||
import io.spring.api.exception.InvalidRequestException;
|
import io.spring.api.exception.InvalidRequestException;
|
||||||
import io.spring.application.Page;
|
import io.spring.application.Page;
|
||||||
import io.spring.application.article.ArticleQueryService;
|
import io.spring.application.ArticleQueryService;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
|
@ -4,9 +4,9 @@ import com.fasterxml.jackson.annotation.JsonRootName;
|
|||||||
import io.spring.api.exception.InvalidRequestException;
|
import io.spring.api.exception.InvalidRequestException;
|
||||||
import io.spring.api.exception.NoAuthorizationException;
|
import io.spring.api.exception.NoAuthorizationException;
|
||||||
import io.spring.api.exception.ResourceNotFoundException;
|
import io.spring.api.exception.ResourceNotFoundException;
|
||||||
import io.spring.application.AuthorizationService;
|
import io.spring.core.service.AuthorizationService;
|
||||||
import io.spring.application.comment.CommentData;
|
import io.spring.application.data.CommentData;
|
||||||
import io.spring.application.comment.CommentQueryService;
|
import io.spring.application.CommentQueryService;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.comment.Comment;
|
import io.spring.core.comment.Comment;
|
||||||
|
@ -2,8 +2,9 @@ package io.spring.api;
|
|||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonRootName;
|
import com.fasterxml.jackson.annotation.JsonRootName;
|
||||||
import io.spring.api.exception.InvalidRequestException;
|
import io.spring.api.exception.InvalidRequestException;
|
||||||
import io.spring.application.user.UserQueryService;
|
import io.spring.application.UserQueryService;
|
||||||
import io.spring.application.user.UserWithToken;
|
import io.spring.application.UserWithToken;
|
||||||
|
import io.spring.application.data.UserData;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
@ -40,11 +41,15 @@ public class CurrentUserApi {
|
|||||||
@GetMapping
|
@GetMapping
|
||||||
public ResponseEntity currentUser(@AuthenticationPrincipal User currentUser,
|
public ResponseEntity currentUser(@AuthenticationPrincipal User currentUser,
|
||||||
@RequestHeader(value = "Authorization") String authorization) {
|
@RequestHeader(value = "Authorization") String authorization) {
|
||||||
return ResponseEntity.ok(userResponse(userQueryService.fetchCurrentUser(currentUser.getUsername(), authorization.split(" ")[1])));
|
UserData userData = userQueryService.findById(currentUser.getId()).get();
|
||||||
|
return ResponseEntity.ok(userResponse(
|
||||||
|
new UserWithToken(userData, authorization.split(" ")[1])
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
@PutMapping
|
@PutMapping
|
||||||
public ResponseEntity updateProfile(@AuthenticationPrincipal User currentUser,
|
public ResponseEntity updateProfile(@AuthenticationPrincipal User currentUser,
|
||||||
|
@RequestHeader("Authorization") String token,
|
||||||
@Valid @RequestBody UpdateUserParam updateUserParam,
|
@Valid @RequestBody UpdateUserParam updateUserParam,
|
||||||
BindingResult bindingResult) {
|
BindingResult bindingResult) {
|
||||||
if (bindingResult.hasErrors()) {
|
if (bindingResult.hasErrors()) {
|
||||||
@ -59,7 +64,10 @@ public class CurrentUserApi {
|
|||||||
updateUserParam.getBio(),
|
updateUserParam.getBio(),
|
||||||
updateUserParam.getImage());
|
updateUserParam.getImage());
|
||||||
userRepository.save(currentUser);
|
userRepository.save(currentUser);
|
||||||
return ResponseEntity.ok(userResponse(userQueryService.fetchNewAuthenticatedUser(currentUser.getUsername())));
|
UserData userData = userQueryService.findById(currentUser.getId()).get();
|
||||||
|
return ResponseEntity.ok(userResponse(
|
||||||
|
new UserWithToken(userData, token.split(" ")[1])
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkUniquenessOfUsernameAndEmail(User currentUser, UpdateUserParam updateUserParam, BindingResult bindingResult) {
|
private void checkUniquenessOfUsernameAndEmail(User currentUser, UpdateUserParam updateUserParam, BindingResult bindingResult) {
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.spring.api.exception.ResourceNotFoundException;
|
import io.spring.api.exception.ResourceNotFoundException;
|
||||||
import io.spring.application.profile.ProfileData;
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.application.profile.ProfileQueryService;
|
import io.spring.application.ProfileQueryService;
|
||||||
import io.spring.core.user.FollowRelation;
|
import io.spring.core.user.FollowRelation;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.spring.application.tag.TagsQueryService;
|
import io.spring.application.TagsQueryService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
import org.springframework.web.bind.annotation.GetMapping;
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
@ -2,8 +2,10 @@ package io.spring.api;
|
|||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonRootName;
|
import com.fasterxml.jackson.annotation.JsonRootName;
|
||||||
import io.spring.api.exception.InvalidRequestException;
|
import io.spring.api.exception.InvalidRequestException;
|
||||||
import io.spring.application.user.UserQueryService;
|
import io.spring.application.UserQueryService;
|
||||||
import io.spring.application.user.UserWithToken;
|
import io.spring.application.UserWithToken;
|
||||||
|
import io.spring.application.data.UserData;
|
||||||
|
import io.spring.core.service.JwtService;
|
||||||
import io.spring.core.user.EncryptService;
|
import io.spring.core.user.EncryptService;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
@ -32,32 +34,25 @@ public class UsersApi {
|
|||||||
private UserQueryService userQueryService;
|
private UserQueryService userQueryService;
|
||||||
private String defaultImage;
|
private String defaultImage;
|
||||||
private EncryptService encryptService;
|
private EncryptService encryptService;
|
||||||
|
private JwtService jwtService;
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
public UsersApi(UserRepository userRepository,
|
public UsersApi(UserRepository userRepository,
|
||||||
UserQueryService userQueryService,
|
UserQueryService userQueryService,
|
||||||
EncryptService encryptService,
|
EncryptService encryptService,
|
||||||
@Value("${image.default}") String defaultImage) {
|
@Value("${image.default}") String defaultImage,
|
||||||
|
JwtService jwtService) {
|
||||||
this.userRepository = userRepository;
|
this.userRepository = userRepository;
|
||||||
this.userQueryService = userQueryService;
|
this.userQueryService = userQueryService;
|
||||||
this.encryptService = encryptService;
|
this.encryptService = encryptService;
|
||||||
this.defaultImage = defaultImage;
|
this.defaultImage = defaultImage;
|
||||||
|
this.jwtService = jwtService;
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping(path = "/users", method = POST)
|
@RequestMapping(path = "/users", method = POST)
|
||||||
public ResponseEntity createUser(@Valid @RequestBody RegisterParam registerParam, BindingResult bindingResult) {
|
public ResponseEntity createUser(@Valid @RequestBody RegisterParam registerParam, BindingResult bindingResult) {
|
||||||
if (bindingResult.hasErrors()) {
|
checkInput(registerParam, bindingResult);
|
||||||
throw new InvalidRequestException(bindingResult);
|
|
||||||
}
|
|
||||||
if (userRepository.findByUsername(registerParam.getUsername()).isPresent()) {
|
|
||||||
bindingResult.rejectValue("username", "DUPLICATED", "duplicated username");
|
|
||||||
throw new InvalidRequestException(bindingResult);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (userRepository.findByEmail(registerParam.getEmail()).isPresent()) {
|
|
||||||
bindingResult.rejectValue("email", "DUPLICATED", "duplicated email");
|
|
||||||
throw new InvalidRequestException(bindingResult);
|
|
||||||
}
|
|
||||||
User user = new User(
|
User user = new User(
|
||||||
registerParam.getEmail(),
|
registerParam.getEmail(),
|
||||||
registerParam.getUsername(),
|
registerParam.getUsername(),
|
||||||
@ -65,14 +60,33 @@ public class UsersApi {
|
|||||||
"",
|
"",
|
||||||
defaultImage);
|
defaultImage);
|
||||||
userRepository.save(user);
|
userRepository.save(user);
|
||||||
return ResponseEntity.status(201).body(userResponse(userQueryService.fetchNewAuthenticatedUser(user.getUsername())));
|
UserData userData = userQueryService.findById(user.getId()).get();
|
||||||
|
return ResponseEntity.status(201).body(userResponse(new UserWithToken(userData, jwtService.toToken(user))));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkInput(@Valid @RequestBody RegisterParam registerParam, BindingResult bindingResult) {
|
||||||
|
if (bindingResult.hasErrors()) {
|
||||||
|
throw new InvalidRequestException(bindingResult);
|
||||||
|
}
|
||||||
|
if (userRepository.findByUsername(registerParam.getUsername()).isPresent()) {
|
||||||
|
bindingResult.rejectValue("username", "DUPLICATED", "duplicated username");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (userRepository.findByEmail(registerParam.getEmail()).isPresent()) {
|
||||||
|
bindingResult.rejectValue("email", "DUPLICATED", "duplicated email");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (bindingResult.hasErrors()) {
|
||||||
|
throw new InvalidRequestException(bindingResult);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping(path = "/users/login", method = POST)
|
@RequestMapping(path = "/users/login", method = POST)
|
||||||
public ResponseEntity userLogin(@Valid @RequestBody LoginParam loginParam, BindingResult bindingResult) {
|
public ResponseEntity userLogin(@Valid @RequestBody LoginParam loginParam, BindingResult bindingResult) {
|
||||||
Optional<User> optional = userRepository.findByEmail(loginParam.getEmail());
|
Optional<User> optional = userRepository.findByEmail(loginParam.getEmail());
|
||||||
if (optional.isPresent() && encryptService.check(loginParam.getPassword(), optional.get().getPassword())) {
|
if (optional.isPresent() && encryptService.check(loginParam.getPassword(), optional.get().getPassword())) {
|
||||||
return ResponseEntity.ok(userResponse(userQueryService.fetchNewAuthenticatedUser(optional.get().getUsername())));
|
UserData userData = userQueryService.findById(optional.get().getId()).get();
|
||||||
|
return ResponseEntity.ok(userResponse(new UserWithToken(userData, jwtService.toToken(optional.get()))));
|
||||||
} else {
|
} else {
|
||||||
bindingResult.rejectValue("password", "INVALID", "invalid email or password");
|
bindingResult.rejectValue("password", "INVALID", "invalid email or password");
|
||||||
throw new InvalidRequestException(bindingResult);
|
throw new InvalidRequestException(bindingResult);
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
package io.spring.api.security;
|
package io.spring.api.security;
|
||||||
|
|
||||||
import io.spring.application.JwtService;
|
import io.spring.core.service.JwtService;
|
||||||
import io.spring.core.user.User;
|
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
|
import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.application.article;
|
package io.spring.application;
|
||||||
|
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
@ -1,8 +1,10 @@
|
|||||||
package io.spring.application.article;
|
package io.spring.application;
|
||||||
|
|
||||||
import io.spring.application.Page;
|
import io.spring.application.data.ArticleData;
|
||||||
import io.spring.application.profile.UserRelationshipQueryService;
|
import io.spring.application.data.ArticleDataList;
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.UserRelationshipQueryService;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.ArticleReadService;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
@ -1,7 +1,9 @@
|
|||||||
package io.spring.application.comment;
|
package io.spring.application;
|
||||||
|
|
||||||
import io.spring.application.profile.UserRelationshipQueryService;
|
import io.spring.application.data.CommentData;
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.UserRelationshipQueryService;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.CommentReadService;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
@ -1,8 +1,10 @@
|
|||||||
package io.spring.application.profile;
|
package io.spring.application;
|
||||||
|
|
||||||
import io.spring.application.user.UserData;
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.application.user.UserReadService;
|
import io.spring.application.data.UserData;
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.UserReadService;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.UserRelationshipQueryService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
@ -1,5 +1,6 @@
|
|||||||
package io.spring.application.tag;
|
package io.spring.application;
|
||||||
|
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.TagReadService;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
24
src/main/java/io/spring/application/UserQueryService.java
Normal file
24
src/main/java/io/spring/application/UserQueryService.java
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
package io.spring.application;
|
||||||
|
|
||||||
|
import io.spring.application.data.UserData;
|
||||||
|
import io.spring.core.service.JwtService;
|
||||||
|
import io.spring.infrastructure.mybatis.readservice.UserReadService;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
@Service
|
||||||
|
public class UserQueryService {
|
||||||
|
private UserReadService userReadService;
|
||||||
|
private JwtService jwtService;
|
||||||
|
|
||||||
|
public UserQueryService(UserReadService userReadService, JwtService jwtService) {
|
||||||
|
this.userReadService = userReadService;
|
||||||
|
this.jwtService = jwtService;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<UserData> findById(String id) {
|
||||||
|
return Optional.ofNullable(userReadService.findById(id));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,5 +1,6 @@
|
|||||||
package io.spring.application.user;
|
package io.spring.application;
|
||||||
|
|
||||||
|
import io.spring.application.data.UserData;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
|
|
||||||
@Getter
|
@Getter
|
@ -1,7 +1,6 @@
|
|||||||
package io.spring.application.article;
|
package io.spring.application.data;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import io.spring.application.profile.ProfileData;
|
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.application.article;
|
package io.spring.application.data;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
@ -1,8 +1,7 @@
|
|||||||
package io.spring.application.comment;
|
package io.spring.application.data;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty;
|
import com.fasterxml.jackson.annotation.JsonProperty;
|
||||||
import io.spring.application.profile.ProfileData;
|
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.application.profile;
|
package io.spring.application.data;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnore;
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.application.user;
|
package io.spring.application.data;
|
||||||
|
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
@ -1,25 +0,0 @@
|
|||||||
package io.spring.application.user;
|
|
||||||
|
|
||||||
import io.spring.application.JwtService;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class UserQueryService {
|
|
||||||
private UserReadService userReadService;
|
|
||||||
private JwtService jwtService;
|
|
||||||
|
|
||||||
public UserQueryService(UserReadService userReadService, JwtService jwtService) {
|
|
||||||
this.userReadService = userReadService;
|
|
||||||
this.jwtService = jwtService;
|
|
||||||
}
|
|
||||||
|
|
||||||
public UserWithToken fetchNewAuthenticatedUser(String username) {
|
|
||||||
UserData userData = userReadService.findByUsername(username);
|
|
||||||
return new UserWithToken(userData, jwtService.toToken(userData));
|
|
||||||
}
|
|
||||||
|
|
||||||
public UserWithToken fetchCurrentUser(String username, String token) {
|
|
||||||
return new UserWithToken(userReadService.findByUsername(username), token);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.application;
|
package io.spring.core.service;
|
||||||
|
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.comment.Comment;
|
import io.spring.core.comment.Comment;
|
@ -1,13 +1,13 @@
|
|||||||
package io.spring.application;
|
package io.spring.core.service;
|
||||||
|
|
||||||
import io.spring.application.user.UserData;
|
import io.spring.core.user.User;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
public interface JwtService {
|
public interface JwtService {
|
||||||
String toToken(UserData userData);
|
String toToken(User user);
|
||||||
|
|
||||||
Optional<String> getSubFromToken(String token);
|
Optional<String> getSubFromToken(String token);
|
||||||
}
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.infrastructure.favorite;
|
package io.spring.infrastructure.mybatis.mapper;
|
||||||
|
|
||||||
import io.spring.core.favorite.ArticleFavorite;
|
import io.spring.core.favorite.ArticleFavorite;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.infrastructure.article;
|
package io.spring.infrastructure.mybatis.mapper;
|
||||||
|
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.Tag;
|
import io.spring.core.article.Tag;
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.infrastructure.comment;
|
package io.spring.infrastructure.mybatis.mapper;
|
||||||
|
|
||||||
import io.spring.core.comment.Comment;
|
import io.spring.core.comment.Comment;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.infrastructure.user;
|
package io.spring.infrastructure.mybatis.mapper;
|
||||||
|
|
||||||
import io.spring.core.user.FollowRelation;
|
import io.spring.core.user.FollowRelation;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
@ -1,6 +1,7 @@
|
|||||||
package io.spring.application.article;
|
package io.spring.infrastructure.mybatis.readservice;
|
||||||
|
|
||||||
import io.spring.application.Page;
|
import io.spring.application.Page;
|
||||||
|
import io.spring.application.data.ArticleData;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
@ -1,5 +1,6 @@
|
|||||||
package io.spring.application.comment;
|
package io.spring.infrastructure.mybatis.readservice;
|
||||||
|
|
||||||
|
import io.spring.application.data.CommentData;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.application.tag;
|
package io.spring.infrastructure.mybatis.readservice;
|
||||||
|
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
@ -1,5 +1,6 @@
|
|||||||
package io.spring.application.user;
|
package io.spring.infrastructure.mybatis.readservice;
|
||||||
|
|
||||||
|
import io.spring.application.data.UserData;
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
@ -9,5 +10,7 @@ import org.springframework.stereotype.Component;
|
|||||||
public interface UserReadService {
|
public interface UserReadService {
|
||||||
|
|
||||||
UserData findByUsername(@Param("username") String username);
|
UserData findByUsername(@Param("username") String username);
|
||||||
|
|
||||||
|
UserData findById(@Param("id") String id);
|
||||||
}
|
}
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
package io.spring.application.profile;
|
package io.spring.infrastructure.mybatis.readservice;
|
||||||
|
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
@ -1,7 +1,8 @@
|
|||||||
package io.spring.infrastructure.favorite;
|
package io.spring.infrastructure.repository;
|
||||||
|
|
||||||
import io.spring.core.favorite.ArticleFavorite;
|
import io.spring.core.favorite.ArticleFavorite;
|
||||||
import io.spring.core.favorite.ArticleFavoriteRepository;
|
import io.spring.core.favorite.ArticleFavoriteRepository;
|
||||||
|
import io.spring.infrastructure.mybatis.mapper.ArticleFavoriteMapper;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
@ -1,8 +1,9 @@
|
|||||||
package io.spring.infrastructure.article;
|
package io.spring.infrastructure.repository;
|
||||||
|
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.article.Tag;
|
import io.spring.core.article.Tag;
|
||||||
|
import io.spring.infrastructure.mybatis.mapper.ArticleMapper;
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
@ -1,7 +1,8 @@
|
|||||||
package io.spring.infrastructure.comment;
|
package io.spring.infrastructure.repository;
|
||||||
|
|
||||||
import io.spring.core.comment.Comment;
|
import io.spring.core.comment.Comment;
|
||||||
import io.spring.core.comment.CommentRepository;
|
import io.spring.core.comment.CommentRepository;
|
||||||
|
import io.spring.infrastructure.mybatis.mapper.CommentMapper;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
@ -1,8 +1,9 @@
|
|||||||
package io.spring.infrastructure.user;
|
package io.spring.infrastructure.repository;
|
||||||
|
|
||||||
import io.spring.core.user.FollowRelation;
|
import io.spring.core.user.FollowRelation;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
|
import io.spring.infrastructure.mybatis.mapper.UserMapper;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
@ -4,8 +4,8 @@ import io.jsonwebtoken.Claims;
|
|||||||
import io.jsonwebtoken.Jws;
|
import io.jsonwebtoken.Jws;
|
||||||
import io.jsonwebtoken.Jwts;
|
import io.jsonwebtoken.Jwts;
|
||||||
import io.jsonwebtoken.SignatureAlgorithm;
|
import io.jsonwebtoken.SignatureAlgorithm;
|
||||||
import io.spring.application.JwtService;
|
import io.spring.core.service.JwtService;
|
||||||
import io.spring.application.user.UserData;
|
import io.spring.core.user.User;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
@ -26,9 +26,9 @@ public class DefaultJwtService implements JwtService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toToken(UserData userData) {
|
public String toToken(User user) {
|
||||||
return Jwts.builder()
|
return Jwts.builder()
|
||||||
.setSubject(userData.getId())
|
.setSubject(user.getId())
|
||||||
.setExpiration(expireTimeFromNow())
|
.setExpiration(expireTimeFromNow())
|
||||||
.signWith(SignatureAlgorithm.HS512, secret)
|
.signWith(SignatureAlgorithm.HS512, secret)
|
||||||
.compact();
|
.compact();
|
||||||
|
@ -4,4 +4,4 @@ jwt.secret=nRvyYC4soFxBdZ-F-5Nnzz5USXstR1YylsTd-mA0aKtI9HUlriGrtkf-TiuDapkLiUCog
|
|||||||
jwt.sessionTime=86400
|
jwt.sessionTime=86400
|
||||||
mybatis.config-location=classpath:mybatis-config.xml
|
mybatis.config-location=classpath:mybatis-config.xml
|
||||||
mybatis.mapper-locations=mapper/*.xml
|
mybatis.mapper-locations=mapper/*.xml
|
||||||
logging.level.io.spring.application.article.ArticleReadService=DEBUG
|
logging.level.io.spring.infrastructure.mybatis.readservice.ArticleReadService=DEBUG
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.infrastructure.favorite.ArticleFavoriteMapper">
|
<mapper namespace="io.spring.infrastructure.mybatis.mapper.ArticleFavoriteMapper">
|
||||||
<insert id="insert">
|
<insert id="insert">
|
||||||
insert into article_favorites (article_id, user_id) values (#{articleFavorite.articleId}, #{articleFavorite.userId})
|
insert into article_favorites (article_id, user_id) values (#{articleFavorite.articleId}, #{articleFavorite.userId})
|
||||||
</insert>
|
</insert>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.application.article.ArticleFavoritesQueryService">
|
<mapper namespace="io.spring.application.ArticleFavoritesQueryService">
|
||||||
<select id="isUserFavorite" resultType="java.lang.Boolean">
|
<select id="isUserFavorite" resultType="java.lang.Boolean">
|
||||||
select count(1) from article_favorites where user_id = #{userId} and article_id = #{articleId}
|
select count(1) from article_favorites where user_id = #{userId} and article_id = #{articleId}
|
||||||
</select>
|
</select>
|
||||||
@ -28,7 +28,7 @@
|
|||||||
and AF.user_id = #{currentUser.id}
|
and AF.user_id = #{currentUser.id}
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<resultMap id="favoriteCount" type="io.spring.application.article.ArticleFavoriteCount">
|
<resultMap id="favoriteCount" type="io.spring.application.ArticleFavoriteCount">
|
||||||
<id column="id" property="id"/>
|
<id column="id" property="id"/>
|
||||||
<result column="favoriteCount" property="count"/>
|
<result column="favoriteCount" property="count"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.infrastructure.article.ArticleMapper">
|
<mapper namespace="io.spring.infrastructure.mybatis.mapper.ArticleMapper">
|
||||||
<insert id="insert">
|
<insert id="insert">
|
||||||
insert into articles(id, slug, title, description, body, user_id, created_at, updated_at)
|
insert into articles(id, slug, title, description, body, user_id, created_at, updated_at)
|
||||||
values(
|
values(
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.application.article.ArticleReadService">
|
<mapper namespace="io.spring.infrastructure.mybatis.readservice.ArticleReadService">
|
||||||
<sql id="profileColumns">
|
<sql id="profileColumns">
|
||||||
U.id userId,
|
U.id userId,
|
||||||
U.username userUsername,
|
U.username userUsername,
|
||||||
@ -81,6 +81,7 @@
|
|||||||
<foreach index="index" collection="articleIds" item="id" open="(" separator="," close=")">
|
<foreach index="index" collection="articleIds" item="id" open="(" separator="," close=")">
|
||||||
#{id}
|
#{id}
|
||||||
</foreach>
|
</foreach>
|
||||||
|
order by A.created_at desc
|
||||||
</select>
|
</select>
|
||||||
<select id="findArticlesOfAuthors" resultMap="articleData">
|
<select id="findArticlesOfAuthors" resultMap="articleData">
|
||||||
<include refid="selectArticleData"/>
|
<include refid="selectArticleData"/>
|
||||||
@ -101,7 +102,7 @@
|
|||||||
<id javaType="string" column="articleId"/>
|
<id javaType="string" column="articleId"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
|
|
||||||
<resultMap id="articleData" type="io.spring.application.article.ArticleData">
|
<resultMap id="articleData" type="io.spring.application.data.ArticleData">
|
||||||
<id column="articleId" property="id"/>
|
<id column="articleId" property="id"/>
|
||||||
<result column="articleSlug" property="slug"/>
|
<result column="articleSlug" property="slug"/>
|
||||||
<result column="articleTitle" property="title"/>
|
<result column="articleTitle" property="title"/>
|
||||||
@ -115,7 +116,7 @@
|
|||||||
</collection>
|
</collection>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
|
|
||||||
<resultMap id="profileData" type="io.spring.application.profile.ProfileData">
|
<resultMap id="profileData" type="io.spring.application.data.ProfileData">
|
||||||
<id column="userId" property="id"/>
|
<id column="userId" property="id"/>
|
||||||
<result column="userUsername" property="username"/>
|
<result column="userUsername" property="username"/>
|
||||||
<result column="userBio" property="bio"/>
|
<result column="userBio" property="bio"/>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.infrastructure.comment.CommentMapper">
|
<mapper namespace="io.spring.infrastructure.mybatis.mapper.CommentMapper">
|
||||||
<insert id="insert">
|
<insert id="insert">
|
||||||
insert into comments(id, body, user_id, article_id, created_at, updated_at)
|
insert into comments(id, body, user_id, article_id, created_at, updated_at)
|
||||||
values (
|
values (
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.application.comment.CommentReadService">
|
<mapper namespace="io.spring.infrastructure.mybatis.readservice.CommentReadService">
|
||||||
<sql id="selectCommentData">
|
<sql id="selectCommentData">
|
||||||
SELECT
|
SELECT
|
||||||
C.id commentId,
|
C.id commentId,
|
||||||
C.body commentBody,
|
C.body commentBody,
|
||||||
C.created_at commentCreatedAt,
|
C.created_at commentCreatedAt,
|
||||||
<include refid="io.spring.application.article.ArticleReadService.profileColumns"/>
|
<include refid="io.spring.infrastructure.mybatis.readservice.ArticleReadService.profileColumns"/>
|
||||||
from comments C
|
from comments C
|
||||||
left join users U
|
left join users U
|
||||||
on C.user_id = U.id
|
on C.user_id = U.id
|
||||||
@ -21,11 +21,11 @@
|
|||||||
where C.article_id = #{articleId}
|
where C.article_id = #{articleId}
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<resultMap id="commentData" type="io.spring.application.comment.CommentData">
|
<resultMap id="commentData" type="io.spring.application.data.CommentData">
|
||||||
<id column="commentId" property="id"/>
|
<id column="commentId" property="id"/>
|
||||||
<result column="commentBody" property="body"/>
|
<result column="commentBody" property="body"/>
|
||||||
<result column="commentCreatedAt" property="createdAt"/>
|
<result column="commentCreatedAt" property="createdAt"/>
|
||||||
<result column="commentCreatedAt" property="updatedAt"/>
|
<result column="commentCreatedAt" property="updatedAt"/>
|
||||||
<association property="profileData" resultMap="io.spring.application.article.ArticleReadService.profileData"/>
|
<association property="profileData" resultMap="io.spring.infrastructure.mybatis.readservice.ArticleReadService.profileData"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
</mapper>
|
</mapper>
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.application.tag.TagReadService">
|
<mapper namespace="io.spring.infrastructure.mybatis.readservice.TagReadService">
|
||||||
<select id="all" resultType="string">
|
<select id="all" resultType="string">
|
||||||
select name from tags
|
select name from tags
|
||||||
</select>
|
</select>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.infrastructure.user.UserMapper">
|
<mapper namespace="io.spring.infrastructure.mybatis.mapper.UserMapper">
|
||||||
<insert id="insert">
|
<insert id="insert">
|
||||||
insert into users (id, username, email, password, bio, image) values(
|
insert into users (id, username, email, password, bio, image) values(
|
||||||
#{user.id},
|
#{user.id},
|
||||||
|
@ -1,7 +1,10 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.application.user.UserReadService">
|
<mapper namespace="io.spring.infrastructure.mybatis.readservice.UserReadService">
|
||||||
<select id="findByUsername" resultType="io.spring.application.user.UserData">
|
<select id="findByUsername" resultType="io.spring.application.data.UserData">
|
||||||
select * from users where username = #{username}
|
select * from users where username = #{username}
|
||||||
</select>
|
</select>
|
||||||
|
<select id="findById" resultType="io.spring.application.data.UserData">
|
||||||
|
select * from users where id = #{id}
|
||||||
|
</select>
|
||||||
</mapper>
|
</mapper>
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
<mapper namespace="io.spring.application.profile.UserRelationshipQueryService">
|
<mapper namespace="io.spring.infrastructure.mybatis.readservice.UserRelationshipQueryService">
|
||||||
<select id="isUserFollowing" resultType="java.lang.Boolean">
|
<select id="isUserFollowing" resultType="java.lang.Boolean">
|
||||||
select count(1) from follows where user_id = #{userId} and follow_id = #{anotherUserId}
|
select count(1) from follows where user_id = #{userId} and follow_id = #{anotherUserId}
|
||||||
</select>
|
</select>
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
package io.spring;
|
package io.spring;
|
||||||
|
|
||||||
import io.spring.application.article.ArticleData;
|
import io.spring.application.data.ArticleData;
|
||||||
import io.spring.application.profile.ProfileData;
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.restassured.RestAssured;
|
import io.restassured.RestAssured;
|
||||||
import io.spring.application.article.ArticleData;
|
import io.spring.application.data.ArticleData;
|
||||||
import io.spring.application.article.ArticleQueryService;
|
import io.spring.application.ArticleQueryService;
|
||||||
import io.spring.application.profile.ProfileData;
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.article.Tag;
|
import io.spring.core.article.Tag;
|
||||||
|
@ -2,13 +2,14 @@ package io.spring.api;
|
|||||||
|
|
||||||
import io.restassured.RestAssured;
|
import io.restassured.RestAssured;
|
||||||
import io.spring.TestHelper;
|
import io.spring.TestHelper;
|
||||||
import io.spring.application.article.ArticleData;
|
import io.spring.application.data.ArticleData;
|
||||||
import io.spring.application.article.ArticleQueryService;
|
import io.spring.application.ArticleQueryService;
|
||||||
import io.spring.application.profile.ProfileData;
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
|
import org.joda.time.format.ISODateTimeFormat;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@ -127,7 +128,7 @@ public class ArticlesApiTest extends TestWithCurrentUser {
|
|||||||
.statusCode(200)
|
.statusCode(200)
|
||||||
.body("article.slug", equalTo(slug))
|
.body("article.slug", equalTo(slug))
|
||||||
.body("article.body", equalTo(articleData.getBody()))
|
.body("article.body", equalTo(articleData.getBody()))
|
||||||
.body("article.createdAt", equalTo(time.toDateTimeISO().toString()));
|
.body("article.createdAt", equalTo(ISODateTimeFormat.dateTime().withZoneUTC().print(time)));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,10 +1,9 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.restassured.RestAssured;
|
import io.restassured.RestAssured;
|
||||||
import io.spring.application.comment.CommentData;
|
import io.spring.application.CommentQueryService;
|
||||||
import io.spring.application.comment.CommentQueryService;
|
import io.spring.application.data.CommentData;
|
||||||
import io.spring.application.profile.ProfileData;
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.application.user.UserData;
|
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.comment.Comment;
|
import io.spring.core.comment.Comment;
|
||||||
@ -142,13 +141,8 @@ public class CommentsApiTest extends TestWithCurrentUser {
|
|||||||
when(userRepository.findByUsername(eq(anotherUser.getUsername()))).thenReturn(Optional.of(anotherUser));
|
when(userRepository.findByUsername(eq(anotherUser.getUsername()))).thenReturn(Optional.of(anotherUser));
|
||||||
|
|
||||||
when(commentRepository.findById(eq(article.getId()), eq(comment.getId()))).thenReturn(Optional.of(comment));
|
when(commentRepository.findById(eq(article.getId()), eq(comment.getId()))).thenReturn(Optional.of(comment));
|
||||||
String token = jwtService.toToken(
|
String token = jwtService.toToken(anotherUser);
|
||||||
new UserData(
|
when(userRepository.findById(eq(anotherUser.getId()))).thenReturn(Optional.of(anotherUser));
|
||||||
anotherUser.getId(),
|
|
||||||
anotherUser.getEmail(),
|
|
||||||
anotherUser.getUsername(),
|
|
||||||
anotherUser.getBio(),
|
|
||||||
anotherUser.getImage()));
|
|
||||||
given()
|
given()
|
||||||
.header("Authorization", "Token " + token)
|
.header("Authorization", "Token " + token)
|
||||||
.when()
|
.when()
|
||||||
|
@ -1,16 +1,13 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.restassured.RestAssured;
|
import io.restassured.RestAssured;
|
||||||
import io.spring.application.JwtService;
|
import io.spring.application.data.UserData;
|
||||||
import io.spring.application.user.UserData;
|
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.boot.context.embedded.LocalServerPort;
|
import org.springframework.boot.context.embedded.LocalServerPort;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.boot.test.mock.mockito.MockBean;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -18,9 +15,6 @@ import java.util.Map;
|
|||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
import static io.restassured.RestAssured.given;
|
import static io.restassured.RestAssured.given;
|
||||||
import static org.hamcrest.CoreMatchers.is;
|
|
||||||
import static org.hamcrest.CoreMatchers.not;
|
|
||||||
import static org.hamcrest.MatcherAssert.assertThat;
|
|
||||||
import static org.hamcrest.core.IsEqual.equalTo;
|
import static org.hamcrest.core.IsEqual.equalTo;
|
||||||
import static org.mockito.Matchers.eq;
|
import static org.mockito.Matchers.eq;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
@ -93,6 +87,9 @@ public class CurrentUserApiTest extends TestWithCurrentUser {
|
|||||||
}});
|
}});
|
||||||
}};
|
}};
|
||||||
|
|
||||||
|
when(userRepository.findByUsername(eq(newUsername))).thenReturn(Optional.empty());
|
||||||
|
when(userRepository.findByEmail(eq(newEmail))).thenReturn(Optional.empty());
|
||||||
|
|
||||||
when(userReadService.findByUsername(eq(newUsername))).thenReturn(new UserData(user.getId(), newEmail, newUsername, newBio, user.getImage()));
|
when(userReadService.findByUsername(eq(newUsername))).thenReturn(new UserData(user.getId(), newEmail, newUsername, newBio, user.getImage()));
|
||||||
|
|
||||||
given()
|
given()
|
||||||
@ -102,8 +99,7 @@ public class CurrentUserApiTest extends TestWithCurrentUser {
|
|||||||
.when()
|
.when()
|
||||||
.put("/user")
|
.put("/user")
|
||||||
.then()
|
.then()
|
||||||
.statusCode(200)
|
.statusCode(200);
|
||||||
.body("user.token", not(token));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -2,8 +2,8 @@ package io.spring.api;
|
|||||||
|
|
||||||
import io.restassured.RestAssured;
|
import io.restassured.RestAssured;
|
||||||
import io.spring.application.Page;
|
import io.spring.application.Page;
|
||||||
import io.spring.application.article.ArticleDataList;
|
import io.spring.application.data.ArticleDataList;
|
||||||
import io.spring.application.article.ArticleQueryService;
|
import io.spring.application.ArticleQueryService;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
@ -1,13 +1,11 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.restassured.RestAssured;
|
import io.restassured.RestAssured;
|
||||||
import io.spring.application.profile.ProfileData;
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.application.profile.ProfileQueryService;
|
import io.spring.application.ProfileQueryService;
|
||||||
import io.spring.application.profile.UserRelationshipQueryService;
|
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.user.FollowRelation;
|
import io.spring.core.user.FollowRelation;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.spring.application.JwtService;
|
import io.spring.core.service.JwtService;
|
||||||
import io.spring.application.user.UserData;
|
import io.spring.application.data.UserData;
|
||||||
import io.spring.application.user.UserReadService;
|
import io.spring.infrastructure.mybatis.readservice.UserReadService;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
@ -37,10 +37,11 @@ class TestWithCurrentUser {
|
|||||||
|
|
||||||
user = new User(email, username, "123", "", defaultAvatar);
|
user = new User(email, username, "123", "", defaultAvatar);
|
||||||
when(userRepository.findByUsername(eq(username))).thenReturn(Optional.of(user));
|
when(userRepository.findByUsername(eq(username))).thenReturn(Optional.of(user));
|
||||||
|
when(userRepository.findById(eq(user.getId()))).thenReturn(Optional.of(user));
|
||||||
|
|
||||||
userData = new UserData(user.getId(), email, username, "", defaultAvatar);
|
userData = new UserData(user.getId(), email, username, "", defaultAvatar);
|
||||||
when(userReadService.findByUsername(eq(username))).thenReturn(userData);
|
when(userReadService.findById(eq(user.getId()))).thenReturn(userData);
|
||||||
|
|
||||||
token = jwtService.toToken(userData);
|
token = jwtService.toToken(user);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
package io.spring.api;
|
package io.spring.api;
|
||||||
|
|
||||||
import io.restassured.RestAssured;
|
import io.restassured.RestAssured;
|
||||||
import io.spring.application.JwtService;
|
import io.spring.core.service.JwtService;
|
||||||
import io.spring.application.user.UserData;
|
import io.spring.application.data.UserData;
|
||||||
import io.spring.application.user.UserReadService;
|
import io.spring.infrastructure.mybatis.readservice.UserReadService;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@ -54,8 +54,9 @@ public class UsersApiTest {
|
|||||||
String username = "johnjacob";
|
String username = "johnjacob";
|
||||||
|
|
||||||
when(jwtService.toToken(any())).thenReturn("123");
|
when(jwtService.toToken(any())).thenReturn("123");
|
||||||
UserData userData = new UserData("123", email, username, "", defaultAvatar);
|
User user = new User(email, username, "123", "", defaultAvatar);
|
||||||
when(userReadService.findByUsername(eq(username))).thenReturn(userData);
|
UserData userData = new UserData(user.getId(), email, username, "", defaultAvatar);
|
||||||
|
when(userReadService.findById(any())).thenReturn(userData);
|
||||||
|
|
||||||
when(userRepository.findByUsername(eq(username))).thenReturn(Optional.empty());
|
when(userRepository.findByUsername(eq(username))).thenReturn(Optional.empty());
|
||||||
when(userRepository.findByEmail(eq(email))).thenReturn(Optional.empty());
|
when(userRepository.findByEmail(eq(email))).thenReturn(Optional.empty());
|
||||||
@ -122,6 +123,7 @@ public class UsersApiTest {
|
|||||||
when(userRepository.findByUsername(eq(username))).thenReturn(Optional.of(new User(
|
when(userRepository.findByUsername(eq(username))).thenReturn(Optional.of(new User(
|
||||||
email, username, "123", "bio", ""
|
email, username, "123", "bio", ""
|
||||||
)));
|
)));
|
||||||
|
when(userRepository.findByEmail(any())).thenReturn(Optional.empty());
|
||||||
|
|
||||||
Map<String, Object> param = prepareRegisterParameter(email, username);
|
Map<String, Object> param = prepareRegisterParameter(email, username);
|
||||||
|
|
||||||
@ -179,6 +181,7 @@ public class UsersApiTest {
|
|||||||
|
|
||||||
when(userRepository.findByEmail(eq(email))).thenReturn(Optional.of(user));
|
when(userRepository.findByEmail(eq(email))).thenReturn(Optional.of(user));
|
||||||
when(userReadService.findByUsername(eq(username))).thenReturn(userData);
|
when(userReadService.findByUsername(eq(username))).thenReturn(userData);
|
||||||
|
when(userReadService.findById(eq(user.getId()))).thenReturn(userData);
|
||||||
when(jwtService.toToken(any())).thenReturn("123");
|
when(jwtService.toToken(any())).thenReturn("123");
|
||||||
|
|
||||||
Map<String, Object> param = new HashMap<String, Object>() {{
|
Map<String, Object> param = new HashMap<String, Object>() {{
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
package io.spring.application.article;
|
package io.spring.application.article;
|
||||||
|
|
||||||
|
import io.spring.application.ArticleQueryService;
|
||||||
import io.spring.application.Page;
|
import io.spring.application.Page;
|
||||||
|
import io.spring.application.data.ArticleData;
|
||||||
|
import io.spring.application.data.ArticleDataList;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.favorite.ArticleFavorite;
|
import io.spring.core.favorite.ArticleFavorite;
|
||||||
@ -8,9 +11,9 @@ import io.spring.core.favorite.ArticleFavoriteRepository;
|
|||||||
import io.spring.core.user.FollowRelation;
|
import io.spring.core.user.FollowRelation;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import io.spring.infrastructure.article.MyBatisArticleRepository;
|
import io.spring.infrastructure.repository.MyBatisArticleRepository;
|
||||||
import io.spring.infrastructure.favorite.MyBatisArticleFavoriteRepository;
|
import io.spring.infrastructure.repository.MyBatisArticleFavoriteRepository;
|
||||||
import io.spring.infrastructure.user.MyBatisUserRepository;
|
import io.spring.infrastructure.repository.MyBatisUserRepository;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@ -22,10 +25,9 @@ import org.springframework.test.context.junit4.SpringRunner;
|
|||||||
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
import static org.hamcrest.CoreMatchers.anyOf;
|
|
||||||
import static org.hamcrest.CoreMatchers.is;
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
import static org.hamcrest.CoreMatchers.notNullValue;
|
import static org.hamcrest.CoreMatchers.notNullValue;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.assertThat;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@MybatisTest
|
@MybatisTest
|
||||||
@ -54,7 +56,7 @@ public class ArticleQueryServiceTest {
|
|||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
user = new User("aisensiy@gmail.com", "aisensiy", "123", "", "");
|
user = new User("aisensiy@gmail.com", "aisensiy", "123", "", "");
|
||||||
userRepository.save(user);
|
userRepository.save(user);
|
||||||
article = new Article("test", "desc", "body", new String[]{"java", "spring"}, user.getId());
|
article = new Article("test", "desc", "body", new String[]{"java", "spring"}, user.getId(), new DateTime());
|
||||||
articleRepository.save(article);
|
articleRepository.save(article);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package io.spring.application.comment;
|
package io.spring.application.comment;
|
||||||
|
|
||||||
|
import io.spring.application.CommentQueryService;
|
||||||
|
import io.spring.application.data.CommentData;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.core.comment.Comment;
|
import io.spring.core.comment.Comment;
|
||||||
@ -7,9 +9,9 @@ import io.spring.core.comment.CommentRepository;
|
|||||||
import io.spring.core.user.FollowRelation;
|
import io.spring.core.user.FollowRelation;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import io.spring.infrastructure.article.MyBatisArticleRepository;
|
import io.spring.infrastructure.repository.MyBatisArticleRepository;
|
||||||
import io.spring.infrastructure.comment.MyBatisCommentRepository;
|
import io.spring.infrastructure.repository.MyBatisCommentRepository;
|
||||||
import io.spring.infrastructure.user.MyBatisUserRepository;
|
import io.spring.infrastructure.repository.MyBatisUserRepository;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
package io.spring.application.profile;
|
package io.spring.application.profile;
|
||||||
|
|
||||||
|
import io.spring.application.ProfileQueryService;
|
||||||
|
import io.spring.application.data.ProfileData;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import io.spring.infrastructure.user.MyBatisUserRepository;
|
import io.spring.infrastructure.repository.MyBatisUserRepository;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
package io.spring.application.tag;
|
package io.spring.application.tag;
|
||||||
|
|
||||||
|
import io.spring.application.TagsQueryService;
|
||||||
import io.spring.core.article.Article;
|
import io.spring.core.article.Article;
|
||||||
import io.spring.core.article.ArticleRepository;
|
import io.spring.core.article.ArticleRepository;
|
||||||
import io.spring.infrastructure.article.MyBatisArticleRepository;
|
import io.spring.infrastructure.repository.MyBatisArticleRepository;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
||||||
|
@ -5,7 +5,8 @@ import io.spring.core.article.ArticleRepository;
|
|||||||
import io.spring.core.article.Tag;
|
import io.spring.core.article.Tag;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
import io.spring.infrastructure.user.MyBatisUserRepository;
|
import io.spring.infrastructure.repository.MyBatisArticleRepository;
|
||||||
|
import io.spring.infrastructure.repository.MyBatisUserRepository;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
@ -2,6 +2,7 @@ package io.spring.infrastructure.comment;
|
|||||||
|
|
||||||
import io.spring.core.comment.Comment;
|
import io.spring.core.comment.Comment;
|
||||||
import io.spring.core.comment.CommentRepository;
|
import io.spring.core.comment.CommentRepository;
|
||||||
|
import io.spring.infrastructure.repository.MyBatisCommentRepository;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
||||||
|
@ -2,6 +2,7 @@ package io.spring.infrastructure.favorite;
|
|||||||
|
|
||||||
import io.spring.core.favorite.ArticleFavorite;
|
import io.spring.core.favorite.ArticleFavorite;
|
||||||
import io.spring.core.favorite.ArticleFavoriteRepository;
|
import io.spring.core.favorite.ArticleFavoriteRepository;
|
||||||
|
import io.spring.infrastructure.repository.MyBatisArticleFavoriteRepository;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
import org.mybatis.spring.boot.test.autoconfigure.MybatisTest;
|
||||||
@ -21,7 +22,7 @@ public class MyBatisArticleFavoriteRepositoryTest {
|
|||||||
private ArticleFavoriteRepository articleFavoriteRepository;
|
private ArticleFavoriteRepository articleFavoriteRepository;
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private ArticleFavoriteMapper articleFavoriteMapper;
|
private io.spring.infrastructure.mybatis.mapper.ArticleFavoriteMapper articleFavoriteMapper;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void should_save_and_fetch_articleFavorite_success() throws Exception {
|
public void should_save_and_fetch_articleFavorite_success() throws Exception {
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
package io.spring.infrastructure.service;
|
package io.spring.infrastructure.service;
|
||||||
|
|
||||||
import io.spring.application.JwtService;
|
import io.spring.core.service.JwtService;
|
||||||
import io.spring.application.user.UserData;
|
import io.spring.core.user.User;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
@ -9,7 +9,7 @@ import java.util.Optional;
|
|||||||
|
|
||||||
import static org.hamcrest.CoreMatchers.is;
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
import static org.hamcrest.core.IsNull.notNullValue;
|
import static org.hamcrest.core.IsNull.notNullValue;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.assertThat;
|
||||||
|
|
||||||
public class DefaultJwtServiceTest {
|
public class DefaultJwtServiceTest {
|
||||||
|
|
||||||
@ -22,14 +22,12 @@ public class DefaultJwtServiceTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void should_generate_and_parse_token() throws Exception {
|
public void should_generate_and_parse_token() throws Exception {
|
||||||
String username = "aisensiy";
|
User user = new User("email@email.com", "username", "123", "", "");
|
||||||
|
String token = jwtService.toToken(user);
|
||||||
UserData userData = new UserData("123", "aisensiy@163.com", username, "", "");
|
|
||||||
String token = jwtService.toToken(userData);
|
|
||||||
assertThat(token, notNullValue());
|
assertThat(token, notNullValue());
|
||||||
Optional<String> optional = jwtService.getSubFromToken(token);
|
Optional<String> optional = jwtService.getSubFromToken(token);
|
||||||
assertThat(optional.isPresent(), is(true));
|
assertThat(optional.isPresent(), is(true));
|
||||||
assertThat(optional.get(), is(username));
|
assertThat(optional.get(), is(user.getId()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -3,6 +3,7 @@ package io.spring.infrastructure.user;
|
|||||||
import io.spring.core.user.FollowRelation;
|
import io.spring.core.user.FollowRelation;
|
||||||
import io.spring.core.user.User;
|
import io.spring.core.user.User;
|
||||||
import io.spring.core.user.UserRepository;
|
import io.spring.core.user.UserRepository;
|
||||||
|
import io.spring.infrastructure.repository.MyBatisUserRepository;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
Loading…
Reference in New Issue
Block a user