summaryrefslogtreecommitdiffstats
path: root/src/main/java/com/odiparpack/back/odiparback/student
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/com/odiparpack/back/odiparback/student')
-rw-r--r--src/main/java/com/odiparpack/back/odiparback/student/Student.java95
-rw-r--r--src/main/java/com/odiparpack/back/odiparback/student/StudentController.java41
-rw-r--r--src/main/java/com/odiparpack/back/odiparback/student/StudentRepository.java17
-rw-r--r--src/main/java/com/odiparpack/back/odiparback/student/StudentService.java69
-rw-r--r--src/main/java/com/odiparpack/back/odiparback/student/studentConfig.java35
5 files changed, 257 insertions, 0 deletions
diff --git a/src/main/java/com/odiparpack/back/odiparback/student/Student.java b/src/main/java/com/odiparpack/back/odiparback/student/Student.java
new file mode 100644
index 0000000..aaf89ab
--- /dev/null
+++ b/src/main/java/com/odiparpack/back/odiparback/student/Student.java
@@ -0,0 +1,95 @@
+package com.odiparpack.back.odiparback.student;
+
+// Make sure to use this javax.persistence instead of Hibernate or other
+// provider (of what?)
+import javax.persistence.*;
+import java.time.LocalDate;
+import java.time.Period;
+
+@Entity // For Hibernate
+@Table // Table in DB
+public class Student {
+ @Id
+ @SequenceGenerator(
+ name = "student_sequence",
+ sequenceName = "student_sequence",
+ allocationSize = 1
+ )
+ @GeneratedValue(
+ strategy = GenerationType.SEQUENCE,
+ generator = "student_sequence"
+ )
+ private Long id;
+ private String name;
+ private String email;
+ private LocalDate dob;
+ @Transient
+ private Integer age;
+
+ public Student() {
+ }
+
+ public Student(Long id, String name, String email, LocalDate dob) {
+ this.id = id;
+ this.name = name;
+ this.email = email;
+ this.dob = dob;
+ }
+
+ public Student(String name, String email, LocalDate dob) {
+ this.name = name;
+ this.email = email;
+ this.dob = dob;
+ }
+
+ public Long getId() {
+ return id;
+ }
+
+ public void setId(Long id) {
+ this.id = id;
+ }
+
+ public String getName() {
+ return name;
+ }
+
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ public String getEmail() {
+ return email;
+ }
+
+ public void setEmail(String email) {
+ this.email = email;
+ }
+
+ public LocalDate getDob() {
+ return dob;
+ }
+
+ public void setDob(LocalDate dob) {
+ this.dob = dob;
+ }
+
+ public Integer getAge() {
+ return Period.between(this.dob, LocalDate.now()).getYears();
+ }
+
+ public void setAge(Integer age) {
+ this.age = age;
+ }
+
+ @Override
+ public String toString() {
+ return "Student{" +
+ "id=" + id +
+ ", name='" + name + '\'' +
+ ", email='" + email + '\'' +
+ ", dob=" + dob +
+ ", age=" + age +
+ '}';
+ }
+}
diff --git a/src/main/java/com/odiparpack/back/odiparback/student/StudentController.java b/src/main/java/com/odiparpack/back/odiparback/student/StudentController.java
new file mode 100644
index 0000000..ce3e6e0
--- /dev/null
+++ b/src/main/java/com/odiparpack/back/odiparback/student/StudentController.java
@@ -0,0 +1,41 @@
+package com.odiparpack.back.odiparback.student;
+
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+
+@RestController
+@RequestMapping(path = "api/v1/student")
+public class StudentController {
+
+ private final StudentService studentService;
+
+ @Autowired
+ public StudentController(StudentService studentService) {
+ this.studentService = studentService;
+ }
+
+ @GetMapping
+ public List<Student> getStudents() {
+ return studentService.getStudents();
+ }
+
+ @PostMapping
+ public void registerNewStudent(@RequestBody Student student) {
+ studentService.addNewStudent(student);
+ }
+
+ @DeleteMapping(path = "{studentId}")
+ public void deleteStudent(@PathVariable("studentId") Long studentId) {
+ studentService.deleteStudent(studentId);
+ }
+
+ @PutMapping(path = "{studentId}")
+ public void updateStudent(
+ @PathVariable Long studentId,
+ @RequestParam(required = false) String name,
+ @RequestParam(required = false) String email) {
+ studentService.updateStudent(studentId, name, email);
+ }
+}
diff --git a/src/main/java/com/odiparpack/back/odiparback/student/StudentRepository.java b/src/main/java/com/odiparpack/back/odiparback/student/StudentRepository.java
new file mode 100644
index 0000000..2d0fc31
--- /dev/null
+++ b/src/main/java/com/odiparpack/back/odiparback/student/StudentRepository.java
@@ -0,0 +1,17 @@
+package com.odiparpack.back.odiparback.student;
+
+import org.springframework.data.jpa.repository.JpaRepository;
+import org.springframework.data.jpa.repository.Query;
+import org.springframework.stereotype.Repository;
+
+import java.util.Optional;
+
+@Repository
+public interface StudentRepository extends JpaRepository<Student, Long> {
+
+ // Transforms to an SQL such as: select * from student where email = ?
+ //@Query("SELECT s FROM Student s WHERE s.email = ?1")
+ // ^ JPQL
+ Optional<Student> findStudentByEmail(String email);
+
+}
diff --git a/src/main/java/com/odiparpack/back/odiparback/student/StudentService.java b/src/main/java/com/odiparpack/back/odiparback/student/StudentService.java
new file mode 100644
index 0000000..6831dd8
--- /dev/null
+++ b/src/main/java/com/odiparpack/back/odiparback/student/StudentService.java
@@ -0,0 +1,69 @@
+package com.odiparpack.back.odiparback.student;
+
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import javax.transaction.Transactional;
+import java.time.LocalDate;
+import java.time.Month;
+import java.util.List;
+import java.util.Objects;
+import java.util.Optional;
+
+@Service
+public class StudentService {
+
+ private final StudentRepository studentRepository;
+
+ @Autowired
+ public StudentService(StudentRepository studentRepository) {
+ this.studentRepository = studentRepository;
+ }
+
+ public List<Student> getStudents() {
+ return studentRepository.findAll();
+ }
+
+ public void addNewStudent(Student student) {
+ /* check if the email is already registered, if so throw error */
+ Optional<Student> studentOptional =
+ studentRepository.findStudentByEmail(student.getEmail());
+ if (studentOptional.isPresent()) {
+ throw new IllegalStateException("email taken");
+ // email validation is also possible here
+ }
+ studentRepository.save(student);
+ }
+
+ public void deleteStudent(Long studentId) {
+ boolean exists = studentRepository.existsById(studentId);
+ if (!exists) {
+ throw new IllegalStateException(
+ "student with id " + studentId + " does not exists");
+ }
+ studentRepository.deleteById(studentId);
+ }
+
+ // "The entity goes into a managed state". Changes are seaved automatically
+ @Transactional
+ public void updateStudent(Long studentId, String name, String email) {
+ Student student = studentRepository.findById(studentId)
+ .orElseThrow(() -> new IllegalStateException(
+ "student with id " + studentId + " does not exist"
+ ));
+ /* check that attributes are valid before updating object/record */
+ if (name != null && name.length() > 0 &&
+ !Objects.equals(student.getName(), name)) {
+ student.setName(name);
+ }
+ if (email != null && email.length() > 0 &&
+ !Objects.equals(student.getName(), email)) {
+ Optional<Student> studentOptional = studentRepository
+ .findStudentByEmail(email);
+ if (studentOptional.isPresent()) {
+ throw new IllegalStateException("email taken");
+ }
+ student.setEmail(email);
+ }
+ }
+}
diff --git a/src/main/java/com/odiparpack/back/odiparback/student/studentConfig.java b/src/main/java/com/odiparpack/back/odiparback/student/studentConfig.java
new file mode 100644
index 0000000..cd6668a
--- /dev/null
+++ b/src/main/java/com/odiparpack/back/odiparback/student/studentConfig.java
@@ -0,0 +1,35 @@
+package com.odiparpack.back.odiparback.student;
+
+import org.springframework.boot.CommandLineRunner;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+
+import java.time.LocalDate;
+import java.time.Month;
+import java.util.List;
+
+@Configuration
+public class studentConfig {
+
+ @Bean
+ CommandLineRunner commandLineRunner(StudentRepository repository) {
+ return args -> {
+ Student ana = new Student(
+ "Ana",
+ LocalDate.of(2000, Month.JANUARY, 5)
+ );
+
+ Student bob = new Student(
+ "Bob",
+ LocalDate.of(2000, Month.JANUARY, 5)
+ );
+
+ repository.saveAll(
+ List.of(ana, bob)
+ );
+ };
+
+ }
+}