5 Commits
day2 ... day6

Author SHA1 Message Date
50d6479c8d Add Repository and Service 2020-06-17 17:54:21 +07:00
9ee0199b50 Add user service 2020-06-16 19:19:26 +07:00
017e4c1643 completed user controller 2020-06-15 19:38:02 +07:00
232662adea Add Guide and Todo Tasks for Days 2020-06-11 21:41:47 +07:00
73e0c0df14 Add Repository, Controller (User) 2020-06-11 19:13:29 +07:00
21 changed files with 274 additions and 14 deletions

8
README.md Normal file
View File

@@ -0,0 +1,8 @@
### Backend Classrom Demo
CUBETIQ Backend Training
### TODO
- [x] Entity
- [x] Repository
- [ ] Service
- [x] Controller

View File

@@ -18,6 +18,7 @@ dependencies {
implementation 'io.springfox:springfox-swagger2:2.9.2'
implementation 'io.springfox:springfox-swagger-ui:2.9.2'
runtimeOnly 'mysql:mysql-connector-java'
runtimeOnly 'org.postgresql:postgresql'
compileOnly 'org.projectlombok:lombok'
annotationProcessor 'org.projectlombok:lombok'

5
homework/Home.md Normal file
View File

@@ -0,0 +1,5 @@
### Homework
- [ ] Create project all functions from start
- [ ] Add functions into BaseService (CRUD)
- [ ] Create BaseController

View File

@@ -1,15 +1,18 @@
package com.cubetiqs.demo;
import com.cubetiqs.demo.domain.UserEntity;
import com.cubetiqs.demo.rest.UserController;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import java.io.File;
@SpringBootApplication
public class DemoApplication implements CommandLineRunner {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
SpringApplication.run(DemoApplication.class, args);
}

View File

@@ -12,7 +12,7 @@ public class BaseEntity<ID extends Serializable> implements Serializable, Persis
@GeneratedValue(strategy = GenerationType.AUTO)
private ID id;
@Column(name = "created_date")
@Column(name = "created_date", updatable = false)
@Temporal(TemporalType.TIMESTAMP)
private Date createdDate;

View File

@@ -7,7 +7,6 @@ import lombok.NoArgsConstructor;
import javax.persistence.*;
import java.util.Collection;
import java.util.List;
@Entity
@Table(name = "posts")
@@ -18,8 +17,10 @@ import java.util.List;
public class PostEntity extends BaseEntity<Long> {
@Column
private String title;
@Column(columnDefinition = "TEXT")
private String contents;
@ManyToOne(fetch = FetchType.EAGER, cascade = {CascadeType.REFRESH, CascadeType.DETACH})
@JoinColumn(name = "user_id")
private UserEntity user;
@@ -27,3 +28,4 @@ public class PostEntity extends BaseEntity<Long> {
@OneToMany(mappedBy = "post", fetch = FetchType.EAGER, cascade = {CascadeType.ALL}, orphanRemoval = true)
private Collection<CommentEntity> comments;
}

View File

@@ -0,0 +1,10 @@
package com.cubetiqs.demo.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.repository.NoRepositoryBean;
import java.io.Serializable;
@NoRepositoryBean
public interface BaseRepository<T, ID extends Serializable> extends JpaRepository<T, ID> {
}

View File

@@ -0,0 +1,10 @@
package com.cubetiqs.demo.repository;
import com.cubetiqs.demo.domain.CommentEntity;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface CommentRepository extends JpaRepository<CommentEntity, Long> {
}

View File

@@ -0,0 +1,9 @@
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

@@ -0,0 +1,9 @@
package com.cubetiqs.demo.repository;
import com.cubetiqs.demo.domain.UserEntity;
import org.springframework.stereotype.Repository;
@Repository
public interface UserRepository extends BaseRepository<UserEntity, Long> {
}

View File

@@ -0,0 +1,27 @@
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.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping(path = {"/posts"})
public class PostController {
private final PostService postService;
@Autowired
public PostController(PostService postService) {
this.postService = postService;
}
@GetMapping
public List<PostEntity> getAllPosts(Pageable pageable) {
return postService.findAll();
}
}

View File

@@ -0,0 +1,73 @@
package com.cubetiqs.demo.rest;
import com.cubetiqs.demo.domain.UserEntity;
import com.cubetiqs.demo.repository.UserRepository;
import com.cubetiqs.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Pageable;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
import java.util.List;
import java.util.Optional;
@RestController
@RequestMapping(path = {"/users"})
public class UserController {
private final UserRepository userRepository;
private final UserService userService;
@Autowired
public UserController(UserRepository userRepository, UserService userService) {
this.userRepository = userRepository;
this.userService = userService;
}
@GetMapping
public List<UserEntity> getAllUsers(Pageable pageable) {
return userService.findAll();
}
@GetMapping("/{id}")
public UserEntity getUserById(
@PathVariable Long id
) {
return userRepository.findById(id).orElse(null);
}
@PostMapping
public UserEntity createUser(
@RequestBody UserEntity user
) {
return userRepository.save(user);
}
@PutMapping("/{id}")
public UserEntity updateUser(
@PathVariable Long id,
@RequestBody UserEntity user
) {
Optional<UserEntity> userEntityOptional = userRepository.findById(id);
if(userEntityOptional.isPresent()) {
// found
user.setId(id);
return userRepository.save(user);
} else {
return null;
}
}
@DeleteMapping("/{id}")
public ResponseEntity<Object> deleteUser(
@PathVariable Long id
) {
Optional<UserEntity> userEntityOptional = userRepository.findById(id);
if (userEntityOptional.isPresent()) {
userRepository.delete(userEntityOptional.get());
return ResponseEntity.status(HttpStatus.OK).body("user deleted");
} else {
return ResponseEntity.badRequest().body("not found");
}
}
}

View File

@@ -0,0 +1,13 @@
package com.cubetiqs.demo.service;
import com.cubetiqs.demo.repository.BaseRepository;
import org.springframework.data.repository.NoRepositoryBean;
import java.io.Serializable;
import java.util.List;
@NoRepositoryBean
public interface BaseService<T, ID extends Serializable> {
BaseRepository<T, ID> getRepository();
List<T> findAll();
}

View File

@@ -0,0 +1,14 @@
package com.cubetiqs.demo.service;
import org.springframework.data.repository.NoRepositoryBean;
import java.io.Serializable;
import java.util.List;
@NoRepositoryBean
public abstract class BaseServiceImpl<T, ID extends Serializable> implements BaseService<T, ID> {
@Override
public List<T> findAll() {
return getRepository().findAll();
}
}

View File

@@ -0,0 +1,8 @@
package com.cubetiqs.demo.service;
import com.cubetiqs.demo.domain.PostEntity;
import org.springframework.stereotype.Service;
@Service
public interface PostService extends BaseService<PostEntity, Long> {
}

View File

@@ -0,0 +1,22 @@
package com.cubetiqs.demo.service;
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.stereotype.Service;
@Service
public class PostServiceImpl extends BaseServiceImpl<PostEntity, Long> implements PostService {
private final PostRepository postRepository;
@Autowired
public PostServiceImpl(PostRepository postRepository) {
this.postRepository = postRepository;
}
@Override
public BaseRepository<PostEntity, Long> getRepository() {
return postRepository;
}
}

View File

@@ -0,0 +1,9 @@
package com.cubetiqs.demo.service;
import com.cubetiqs.demo.domain.UserEntity;
import org.springframework.stereotype.Service;
@Service
public interface UserService extends BaseService<UserEntity, Long> {
}

View File

@@ -0,0 +1,22 @@
package com.cubetiqs.demo.service;
import com.cubetiqs.demo.domain.UserEntity;
import com.cubetiqs.demo.repository.BaseRepository;
import com.cubetiqs.demo.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UserServiceImpl extends BaseServiceImpl<UserEntity, Long> implements UserService {
private final UserRepository userRepository;
@Autowired
public UserServiceImpl(UserRepository userRepository) {
this.userRepository = userRepository;
}
@Override
public BaseRepository<UserEntity, Long> getRepository() {
return userRepository;
}
}

View File

@@ -0,0 +1,12 @@
server:
port: 8081
spring:
jpa:
hibernate:
ddl-auto: update
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
username: cubetiq
password: Root$
url: jdbc:mysql://192.168.0.150:3306/demo

View File

@@ -0,0 +1,12 @@
server:
port: 8081
spring:
jpa:
hibernate:
ddl-auto: update
datasource:
driver-class-name: org.postgresql.Driver
username: cubetiq
password: Root$
url: jdbc:postgresql://${POSTGRES_HOST:192.168.0.150}:5432/demo

View File

@@ -1,12 +1,3 @@
server:
port: 8080
spring:
jpa:
hibernate:
ddl-auto: update
datasource:
driver-class-name: org.postgresql.Driver
username: cubetiq
password: Root$
url: jdbc:postgresql://${POSTGRES_HOST:192.168.0.150}:5432/demo
profiles:
active: postgres