From 1ea17797ce21c6f5b442bc275211ba8037a5b96c Mon Sep 17 00:00:00 2001 From: lucashemi Date: Tue, 10 Jan 2023 17:05:09 -0300 Subject: first commit --- .../com/alura/DaysOfCodeSpring/ApiController.java | 69 ++++++++++++++++++++++ .../br/com/alura/DaysOfCodeSpring/Application.java | 22 +++++++ .../com/alura/DaysOfCodeSpring/HTMLGenerator.java | 55 +++++++++++++++++ .../com/alura/DaysOfCodeSpring/imdbApiClient.java | 27 +++++++++ 4 files changed, 173 insertions(+) create mode 100644 src/main/java/br/com/alura/DaysOfCodeSpring/ApiController.java create mode 100644 src/main/java/br/com/alura/DaysOfCodeSpring/Application.java create mode 100644 src/main/java/br/com/alura/DaysOfCodeSpring/HTMLGenerator.java create mode 100644 src/main/java/br/com/alura/DaysOfCodeSpring/imdbApiClient.java (limited to 'src/main/java/br/com/alura') diff --git a/src/main/java/br/com/alura/DaysOfCodeSpring/ApiController.java b/src/main/java/br/com/alura/DaysOfCodeSpring/ApiController.java new file mode 100644 index 0000000..7111c5d --- /dev/null +++ b/src/main/java/br/com/alura/DaysOfCodeSpring/ApiController.java @@ -0,0 +1,69 @@ +package br.com.alura.DaysOfCodeSpring; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; +import org.springframework.web.servlet.ModelAndView; + +import java.io.PrintWriter; +import java.util.ArrayList; +import java.util.List; + +@RestController +@RequestMapping("/imdb") +public class ApiController { + + @Autowired + private imdbApiClient apiClient; + + @Value("${imdb.apiKey}") + private String apiKey; + + private List favoritos = new ArrayList<>(); + + @GetMapping + public ModelAndView getFilmesHTML() throws Exception { + List filmes = apiClient.getBody(apiKey); + + PrintWriter writer = new PrintWriter("src/main/resources/static/content.html"); + new HTMLGenerator(writer).generate(filmes); + writer.close(); + + return new ModelAndView("content.html"); + } + + @GetMapping("/api") + public List getFilmes(@RequestParam(required = false) String titulo) throws Exception { + if (titulo != null) { + return apiClient.getBody(apiKey).stream().filter(f -> titulo.toLowerCase().contains(f.title.toLowerCase())).toList(); + } + return apiClient.getBody(apiKey); + } + + @PostMapping("/favoritos/{id}") + public ResponseEntity addFilmeFavorito(@PathVariable String id) throws Exception { + favoritos.addAll(apiClient.getBody(apiKey).stream().filter(f -> id.equals(f.id)).toList()); + return ResponseEntity.ok().build(); + } + + @GetMapping("/favoritos") + public List getFilmesFavoritos() { + return favoritos; + } + + @GetMapping("/favoritos/{id}") + public List getFilmeFavorito(@PathVariable String id) { + List filme = favoritos.stream().filter(f -> id.equals(f.id)).toList(); + return filme; + } + + @DeleteMapping("/favoritos/{id}") + public List deleteFilmeFavoritos(@PathVariable String id) { + favoritos.removeAll(favoritos.stream().filter(f -> id.equals(f.id)).toList()); + return favoritos; + } + + record Filme(String id, Long rank, String title, String fullTitle, String year, String image, String crew, String imDbRating, Long imDbRatingCount){} + +} diff --git a/src/main/java/br/com/alura/DaysOfCodeSpring/Application.java b/src/main/java/br/com/alura/DaysOfCodeSpring/Application.java new file mode 100644 index 0000000..c016fa1 --- /dev/null +++ b/src/main/java/br/com/alura/DaysOfCodeSpring/Application.java @@ -0,0 +1,22 @@ +package br.com.alura.DaysOfCodeSpring; + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; +import org.springframework.context.annotation.Bean; +import org.springframework.http.ResponseEntity; +import org.springframework.web.client.RestTemplate; + +@SpringBootApplication +public class Application { + + @Bean + public RestTemplate restTemplate() { + return new RestTemplate(); + } + + public static void main(String[] args) { + SpringApplication.run(Application.class, args); + } + +} diff --git a/src/main/java/br/com/alura/DaysOfCodeSpring/HTMLGenerator.java b/src/main/java/br/com/alura/DaysOfCodeSpring/HTMLGenerator.java new file mode 100644 index 0000000..9e3e42b --- /dev/null +++ b/src/main/java/br/com/alura/DaysOfCodeSpring/HTMLGenerator.java @@ -0,0 +1,55 @@ +package br.com.alura.DaysOfCodeSpring; + +import java.io.PrintWriter; +import java.util.List; + +public class HTMLGenerator { + private PrintWriter writer; + + public HTMLGenerator(PrintWriter writer) { + this.writer = writer; + } + + private String head = + """ + + + + + + + + """; + + private String card = + """ +
+

%s

+
+ %ss +

Nota: %s - Ano: %s

+
+
+ """; + + public void generate(List filmes) { + writer.println(head); + + writer.println(""" + +

IMDb

+
+ """); + + filmes.forEach(filme -> { + writer.println(String.format(card, filme.title(), filme.image(), filme.title(), filme.imDbRating(), filme.year())); + }); + + writer.println( + """ +
+ + + """); + } +} diff --git a/src/main/java/br/com/alura/DaysOfCodeSpring/imdbApiClient.java b/src/main/java/br/com/alura/DaysOfCodeSpring/imdbApiClient.java new file mode 100644 index 0000000..d7db714 --- /dev/null +++ b/src/main/java/br/com/alura/DaysOfCodeSpring/imdbApiClient.java @@ -0,0 +1,27 @@ +package br.com.alura.DaysOfCodeSpring; + +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.ObjectMapper; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.ResponseEntity; +import org.springframework.stereotype.Component; +import org.springframework.web.client.RestTemplate; + +import java.util.Arrays; +import java.util.List; + +@Component +public class imdbApiClient { + + @Autowired + public RestTemplate restTemplate; + + public List getBody(String apiKey) throws JsonProcessingException { + String url = "https://imdb-api.com/en/API/Top250Movies/"; + ResponseEntity response = restTemplate.getForEntity(url + apiKey, String.class); + String parsed = response.getBody().substring(9,response.getBody().length() - 19); + + ObjectMapper objectMapper = new ObjectMapper(); + return Arrays.stream(objectMapper.readValue(parsed, ApiController.Filme[].class)).toList(); + } +} -- cgit v1.2.3-18-g5258