3 Commits
day6 ... day8

Author SHA1 Message Date
d79ad3eab8 Add query and native query 2020-06-22 20:04:51 +07:00
f14bede40b Add base repository 2020-06-18 19:47:20 +07:00
0121fd4bcb Just updated for demo 2020-06-17 20:22:26 +07:00
18 changed files with 234 additions and 9 deletions

View File

@@ -0,0 +1,5 @@
package com.cubetiqs.demo;
public final class Constants {
public static final String STATUS = "status";
}

View File

@@ -0,0 +1,10 @@
package com.cubetiqs.demo.config;
import com.cubetiqs.demo.repository.BaseRepositoryImpl;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
@Configuration
@EnableJpaRepositories(repositoryBaseClass = BaseRepositoryImpl.class, basePackages = "com.cubetiqs.demo.repository")
public class BaseRepositoryConfig {
}

View File

@@ -1,5 +1,6 @@
package com.cubetiqs.demo.domain;
import com.cubetiqs.demo.Constants;
import org.springframework.data.domain.Persistable;
import javax.persistence.*;
@@ -16,6 +17,10 @@ public class BaseEntity<ID extends Serializable> implements Serializable, Persis
@Temporal(TemporalType.TIMESTAMP)
private Date createdDate;
@Column(name = Constants.STATUS)
@Enumerated(EnumType.ORDINAL)
private Status status;
public void setId(ID id) {
this.id = id;
}
@@ -38,6 +43,14 @@ public class BaseEntity<ID extends Serializable> implements Serializable, Persis
this.createdDate = createdDate;
}
public void setStatus(Status status) {
this.status = status;
}
public Status getStatus() {
return status;
}
@PrePersist
public void beforeSave() {
if (createdDate == null) {

View File

@@ -0,0 +1,6 @@
package com.cubetiqs.demo.domain;
public enum Status {
ACTIVE,
DEACTIVE
}

View File

@@ -0,0 +1,20 @@
package com.cubetiqs.demo.domain.view;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
@Data
@NoArgsConstructor
@AllArgsConstructor
@JsonPropertyOrder(value = {
"email",
"id"
})
public class UserView implements Serializable {
private Long id;
private String email;
}

View File

@@ -4,7 +4,9 @@ import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.repository.NoRepositoryBean;
import java.io.Serializable;
import java.util.List;
@NoRepositoryBean
public interface BaseRepository<T, ID extends Serializable> extends JpaRepository<T, ID> {
List<T> findAllActives();
}

View File

@@ -0,0 +1,30 @@
package com.cubetiqs.demo.repository;
import com.cubetiqs.demo.Constants;
import com.cubetiqs.demo.domain.Status;
import org.springframework.data.jpa.domain.Specification;
import org.springframework.data.jpa.repository.support.JpaEntityInformation;
import org.springframework.data.jpa.repository.support.SimpleJpaRepository;
import org.springframework.data.repository.NoRepositoryBean;
import javax.persistence.EntityManager;
import java.io.Serializable;
import java.util.List;
@NoRepositoryBean
public class BaseRepositoryImpl<T, ID extends Serializable>
extends SimpleJpaRepository<T, ID>
implements BaseRepository<T, ID> {
private final EntityManager entityManager;
public BaseRepositoryImpl(JpaEntityInformation<T, ?> entityInformation, EntityManager entityManager) {
super(entityInformation, entityManager);
this.entityManager = entityManager;
}
@Override
public List<T> findAllActives() {
Specification<T> specification = (Specification<T>) (root, query, criteriaBuilder) ->
criteriaBuilder.equal(root.get(Constants.STATUS), Status.ACTIVE);
return findAll(specification);
}
}

View File

@@ -3,7 +3,8 @@ package com.cubetiqs.demo.repository;
import com.cubetiqs.demo.domain.PostEntity;
import org.springframework.stereotype.Repository;
@Repository
public interface PostRepository extends BaseRepository<PostEntity, Long> {
}

View File

@@ -1,9 +1,24 @@
package com.cubetiqs.demo.repository;
import com.cubetiqs.demo.domain.UserEntity;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;
import java.util.Optional;
@SuppressWarnings("ALL")
@Repository
public interface UserRepository extends BaseRepository<UserEntity, Long> {
Optional<UserEntity> findFirstByEmail(String email);
@Query(value = "select * from users u where u.email = ?1", nativeQuery = true)
Optional<UserEntity> fetchFirstByEmail(String email);
@Query(value = "select * from users u", nativeQuery = true)
Page<UserEntity> fetchAllUsers(Pageable pageable);
@Query(value = "select * from users u where lower(u.email) like ?1", nativeQuery = true)
Page<UserEntity> searchByEmail(String likeEmail, Pageable pageable);
}

View File

@@ -1,15 +1,14 @@
package com.cubetiqs.demo.rest;
import com.cubetiqs.demo.domain.PostEntity;
import com.cubetiqs.demo.service.PostService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Pageable;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping(path = {"/posts"})
public class PostController {
@@ -21,7 +20,14 @@ public class PostController {
}
@GetMapping
public List<PostEntity> getAllPosts(Pageable pageable) {
return postService.findAll();
public ResponseEntity<Object> getAllPosts(
Pageable pageable,
@RequestParam(value = "view", defaultValue = "list") String viewType,
@RequestParam(value = "q", defaultValue = "") String q
) {
if ("list".equalsIgnoreCase(viewType)) {
return ResponseEntity.ok(postService.findAllActives());
}
return ResponseEntity.ok(postService.findAll(pageable));
}
}

View File

@@ -1,9 +1,13 @@
package com.cubetiqs.demo.rest;
import com.cubetiqs.demo.domain.UserEntity;
import com.cubetiqs.demo.domain.view.UserView;
import com.cubetiqs.demo.repository.UserRepository;
import com.cubetiqs.demo.service.UserNotFoundException;
import com.cubetiqs.demo.service.UserService;
import com.cubetiqs.demo.util.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
@@ -12,6 +16,7 @@ import org.springframework.web.bind.annotation.*;
import java.util.List;
import java.util.Optional;
@RestController
@RequestMapping(path = {"/users"})
public class UserController {
@@ -26,7 +31,31 @@ public class UserController {
@GetMapping
public List<UserEntity> getAllUsers(Pageable pageable) {
return userService.findAll();
return userService.findAllActives();
}
@GetMapping("/searchByEmail")
public Page<UserView> searchByEmail(
Pageable pageable,
@RequestParam(value = "q", defaultValue = "") String q
) {
return userService.searchByEmailAsView(StringUtils.stringQuery(q), pageable);
}
@GetMapping("/allUsers")
public Page<UserEntity> fetchAllUsers(Pageable pageable) {
return userRepository.fetchAllUsers(Pageable.unpaged());
}
@GetMapping("/findByEmail/{email}")
public ResponseEntity<Object> getUserById(
@PathVariable String email
) {
try {
return ResponseEntity.ok(userService.findByEmail(email));
} catch (UserNotFoundException ex) {
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(ex.getMessage());
}
}
@GetMapping("/{id}")

View File

@@ -1,6 +1,8 @@
package com.cubetiqs.demo.service;
import com.cubetiqs.demo.repository.BaseRepository;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.repository.NoRepositoryBean;
import java.io.Serializable;
@@ -9,5 +11,8 @@ import java.util.List;
@NoRepositoryBean
public interface BaseService<T, ID extends Serializable> {
BaseRepository<T, ID> getRepository();
Page<T> findAll(Pageable pageable, String q);
Page<T> findAll(Pageable pageable);
List<T> findAll();
List<T> findAllActives();
}

View File

@@ -1,5 +1,7 @@
package com.cubetiqs.demo.service;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.repository.NoRepositoryBean;
import java.io.Serializable;
@@ -11,4 +13,14 @@ public abstract class BaseServiceImpl<T, ID extends Serializable> implements Bas
public List<T> findAll() {
return getRepository().findAll();
}
@Override
public Page<T> findAll(Pageable pageable) {
return getRepository().findAll(pageable);
}
@Override
public List<T> findAllActives() {
return getRepository().findAllActives();
}
}

View File

@@ -4,8 +4,12 @@ import com.cubetiqs.demo.domain.PostEntity;
import com.cubetiqs.demo.repository.BaseRepository;
import com.cubetiqs.demo.repository.PostRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class PostServiceImpl extends BaseServiceImpl<PostEntity, Long> implements PostService {
private final PostRepository postRepository;
@@ -19,4 +23,14 @@ public class PostServiceImpl extends BaseServiceImpl<PostEntity, Long> implement
public BaseRepository<PostEntity, Long> getRepository() {
return postRepository;
}
@Override
public Page<PostEntity> findAll(Pageable pageable, String q) {
return null;
}
@Override
public List<PostEntity> findAllActives() {
return postRepository.findAllActives();
}
}

View File

@@ -0,0 +1,7 @@
package com.cubetiqs.demo.service;
public class UserNotFoundException extends Exception {
public UserNotFoundException(String message) {
super(message);
}
}

View File

@@ -1,9 +1,14 @@
package com.cubetiqs.demo.service;
import com.cubetiqs.demo.domain.UserEntity;
import com.cubetiqs.demo.domain.view.UserView;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.stereotype.Service;
@Service
public interface UserService extends BaseService<UserEntity, Long> {
UserEntity findByEmail(String email) throws UserNotFoundException;
Page<UserEntity> searchByEmail(String email, Pageable pageable);
Page<UserView> searchByEmailAsView(String email, Pageable pageable);
}

View File

@@ -1,11 +1,17 @@
package com.cubetiqs.demo.service;
import com.cubetiqs.demo.domain.UserEntity;
import com.cubetiqs.demo.domain.view.UserView;
import com.cubetiqs.demo.repository.BaseRepository;
import com.cubetiqs.demo.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.stereotype.Service;
import java.util.List;
import java.util.Optional;
@Service
public class UserServiceImpl extends BaseServiceImpl<UserEntity, Long> implements UserService {
private final UserRepository userRepository;
@@ -19,4 +25,35 @@ public class UserServiceImpl extends BaseServiceImpl<UserEntity, Long> implement
public BaseRepository<UserEntity, Long> getRepository() {
return userRepository;
}
@Override
public Page<UserEntity> findAll(Pageable pageable, String q) {
return null;
}
@Override
public List<UserEntity> findAllActives() {
return userRepository.findAllActives();
}
@Override
public UserEntity findByEmail(String email) throws UserNotFoundException {
Optional<UserEntity> opt = userRepository.fetchFirstByEmail(email);
if (opt.isPresent()) {
return opt.get();
}
throw new UserNotFoundException("user does not exists");
}
@Override
public Page<UserEntity> searchByEmail(String email, Pageable pageable) {
return userRepository.searchByEmail(email, pageable);
}
@Override
public Page<UserView> searchByEmailAsView(String email, Pageable pageable) {
Page<UserEntity> users = userRepository.searchByEmail(email, pageable);
return users.map(s -> new UserView(s.getId(), s.getEmail()));
}
}

View File

@@ -0,0 +1,8 @@
package com.cubetiqs.demo.util;
public final class StringUtils {
public static String stringQuery(String q) {
return "%" + q.toLowerCase() + "%";
}
}