completed user controller
This commit is contained in:
parent
232662adea
commit
017e4c1643
@ -18,6 +18,7 @@ dependencies {
|
|||||||
implementation 'io.springfox:springfox-swagger2:2.9.2'
|
implementation 'io.springfox:springfox-swagger2:2.9.2'
|
||||||
implementation 'io.springfox:springfox-swagger-ui:2.9.2'
|
implementation 'io.springfox:springfox-swagger-ui:2.9.2'
|
||||||
|
|
||||||
|
runtimeOnly 'mysql:mysql-connector-java'
|
||||||
runtimeOnly 'org.postgresql:postgresql'
|
runtimeOnly 'org.postgresql:postgresql'
|
||||||
compileOnly 'org.projectlombok:lombok'
|
compileOnly 'org.projectlombok:lombok'
|
||||||
annotationProcessor 'org.projectlombok:lombok'
|
annotationProcessor 'org.projectlombok:lombok'
|
||||||
|
@ -12,7 +12,7 @@ public class BaseEntity<ID extends Serializable> implements Serializable, Persis
|
|||||||
@GeneratedValue(strategy = GenerationType.AUTO)
|
@GeneratedValue(strategy = GenerationType.AUTO)
|
||||||
private ID id;
|
private ID id;
|
||||||
|
|
||||||
@Column(name = "created_date")
|
@Column(name = "created_date", updatable = false)
|
||||||
@Temporal(TemporalType.TIMESTAMP)
|
@Temporal(TemporalType.TIMESTAMP)
|
||||||
private Date createdDate;
|
private Date createdDate;
|
||||||
|
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
package com.cubetiqs.demo.repository;
|
package com.cubetiqs.demo.repository;
|
||||||
|
|
||||||
import com.cubetiqs.demo.domain.UserEntity;
|
import com.cubetiqs.demo.domain.UserEntity;
|
||||||
import org.springframework.data.domain.Page;
|
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
import org.springframework.data.jpa.repository.Query;
|
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
@Repository
|
@Repository
|
||||||
|
@ -5,9 +5,11 @@ import com.cubetiqs.demo.repository.UserRepository;
|
|||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.data.domain.Page;
|
import org.springframework.data.domain.Page;
|
||||||
import org.springframework.data.domain.Pageable;
|
import org.springframework.data.domain.Pageable;
|
||||||
|
import org.springframework.http.HttpStatus;
|
||||||
|
import org.springframework.http.ResponseEntity;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.Optional;
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping(path = {"/users"})
|
@RequestMapping(path = {"/users"})
|
||||||
@ -24,10 +26,45 @@ public class UserController {
|
|||||||
return userRepository.findAll(pageable);
|
return userRepository.findAll(pageable);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping("/{id}")
|
||||||
|
public UserEntity getUserById(
|
||||||
|
@PathVariable Long id
|
||||||
|
) {
|
||||||
|
return userRepository.findById(id).orElse(null);
|
||||||
|
}
|
||||||
|
|
||||||
@PostMapping
|
@PostMapping
|
||||||
public UserEntity createUser(
|
public UserEntity createUser(
|
||||||
@RequestBody UserEntity user
|
@RequestBody UserEntity user
|
||||||
) {
|
) {
|
||||||
return userRepository.save(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");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
12
src/main/resources/application-mysql.yml
Normal file
12
src/main/resources/application-mysql.yml
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
server:
|
||||||
|
port: 8080
|
||||||
|
|
||||||
|
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
|
12
src/main/resources/application-postgres.yml
Normal file
12
src/main/resources/application-postgres.yml
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
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
|
@ -1,12 +1,3 @@
|
|||||||
server:
|
|
||||||
port: 8080
|
|
||||||
|
|
||||||
spring:
|
spring:
|
||||||
jpa:
|
profiles:
|
||||||
hibernate:
|
active: postgres
|
||||||
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
|
|
Loading…
Reference in New Issue
Block a user