From ad37e97ef75cbe8f48a98d71874d4632dc157d59 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adri=C3=A1n=20Oliva?= Date: Thu, 25 May 2023 21:35:01 -0600 Subject: New GET for sorted to dos. GET request with path "/todos/{field}/{order}", where {field} can be "Id", "Priority" or "DueDate" for sorting the corresponding fields, and {order} can be "ASC" or "DESC" for ascending or descending order, respectively. --- src/main/java/com/encora/Main.java | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'src/main/java/com/encora/Main.java') diff --git a/src/main/java/com/encora/Main.java b/src/main/java/com/encora/Main.java index 63c6a48..a233550 100644 --- a/src/main/java/com/encora/Main.java +++ b/src/main/java/com/encora/Main.java @@ -2,11 +2,13 @@ package com.encora; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; +import org.springframework.data.domain.Sort; import org.springframework.http.HttpStatus; import org.springframework.web.bind.annotation.*; import java.util.Date; import java.util.List; +import java.util.Objects; @SpringBootApplication @RestController @@ -100,4 +102,23 @@ public class Main { selectedToDo.setDoneDate(null); toDosRepository.save(selectedToDo); } + + + // Getting sorted to dos. + enum SortingsFields { + Id, Priority, DueDate + } + enum SortingOrders { + ASC, DESC + } + @GetMapping("/todos/{field}/{order}") + @ResponseStatus(value=HttpStatus.OK) + public List getFilteredToDos(@PathVariable("field") SortingsFields field, @PathVariable("order") SortingOrders order) { + Sort sortingMethod = Sort.by(String.valueOf(field)); + if (Objects.equals(String.valueOf(order), "DESC")) { + sortingMethod = sortingMethod.descending(); + } + + return toDosRepository.findAll(sortingMethod); + } } -- cgit v1.2.3