{"id":19453279,"url":"https://github.com/chrissperb/chucknorris-jokes-api","last_synced_at":"2026-04-18T17:04:35.275Z","repository":{"id":262089618,"uuid":"875373230","full_name":"chrissperb/chucknorris-jokes-api","owner":"chrissperb","description":"Este projeto consiste em uma API RESTful simples construida com Java e Spring Boot, que fornece piadas aleatorias sobre Chuck Norris. A API consome dados de uma API externa de piadas sobre Chuck Norris e os expoe por meio de um endpoint acessivel via HTTP.","archived":false,"fork":false,"pushed_at":"2024-11-10T12:57:25.000Z","size":58,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-06-05T19:49:25.611Z","etag":null,"topics":["api-rest","gradle","java","postman","spring-boot"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/chrissperb.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-10-19T19:52:53.000Z","updated_at":"2024-11-10T12:57:29.000Z","dependencies_parsed_at":"2024-11-10T13:39:46.640Z","dependency_job_id":"819be97f-1bff-449c-a088-90740ac3de2e","html_url":"https://github.com/chrissperb/chucknorris-jokes-api","commit_stats":null,"previous_names":["chrissperb/chucknorris-jokes-api"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/chrissperb/chucknorris-jokes-api","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chrissperb%2Fchucknorris-jokes-api","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chrissperb%2Fchucknorris-jokes-api/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chrissperb%2Fchucknorris-jokes-api/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chrissperb%2Fchucknorris-jokes-api/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/chrissperb","download_url":"https://codeload.github.com/chrissperb/chucknorris-jokes-api/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chrissperb%2Fchucknorris-jokes-api/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31976806,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-18T16:27:12.723Z","status":"ssl_error","status_checked_at":"2026-04-18T16:27:11.140Z","response_time":103,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api-rest","gradle","java","postman","spring-boot"],"created_at":"2024-11-10T17:03:20.731Z","updated_at":"2026-04-18T17:04:35.237Z","avatar_url":"https://github.com/chrissperb.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Chuck Norris Jokes API\n\nEste projeto consiste em uma API RESTful simples construída com **Java** e **Spring Boot**, que fornece piadas aleatórias sobre Chuck Norris. A API consome dados de uma API externa de piadas sobre Chuck Norris e os expõe por meio de um endpoint acessível via HTTP.\n**IMPORTANTE:** A responsabilidade do conteúdo e teor das piadas é de inteira responsabilidade do site original [chucknorris.io](https://api.chucknorris.io). \n\n## Tecnologias Utilizadas\n\n* **Java 17+**\n* **Spring Boot 3.x**\n* **Spring Web**: Para criação e configuração da API RESTful.\n* **RestTemplate**: Para fazer requisições HTTP à API externa de piadas.\n* **Lombok**: Para reduzir o código boilerplate.\n* **Maven**: Para gerenciamento de dependências e build.\n* **DeepL Translation API**: Para traduzir as piadas do inglês para o português.\n\n## Funcionalidades\n\n* **Obter piada aleatória**: A API fornece uma piada aleatória sobre Chuck Norris através de uma chamada `GET` no endpoint `/api/joke`.\n* **Obter piada traduzida**: A API traduz a piada para o português usando a DeepL Translate API via o endpoint `/api/joke/pt`.\n* **Integração com API externa**: A API consome a API pública de piadas [chucknorris.io](https://api.chucknorris.io), garantindo que cada resposta traga uma nova piada aleatória.\n\n## Endpoints\n\n* `GET /api/joke`: Retorna uma piada aleatória sobre Chuck Norris no formato JSON.\n* `GET /api/joke/pt`: Retorna uma piada aleatória traduzida para português.\n\n## Estrutura do Projeto\n\n```bash\nchucknorris-jokes-api\n│\n├── src\n│   ├── main\n│   │   ├── java\n│   │   │   └── com\n│   │   │       └── chrissperb\n│   │   │           └── chucknorrisjokesapi\n│   │   │               ├── ChuckNorrisController.java\n│   │   │               ├── ChuckNorrisService.java\n│   │   │               └── ChuckNorrisApiApplication.java\n│   │   └── resources\n│   │       └── application.properties\n├── pom.xml\n└── README.md\n```\n## Diagrama de classes\n\n```mermaid\nclassDiagram\n    class ChucknorrisJokesApiApplication {\n        +main(String[] args)\n    }\n\n    class ChuckNorrisService {\n        -RestTemplate restTemplate\n        -String deeplApiKey\n        +getRandomJoke() String\n        -translateToPortuguese(String text) String\n    }\n\n    class ChuckNorrisController {\n        -ChuckNorrisService chuckNorrisService\n        +getRandomJoke() String\n    }\n\n    ChucknorrisJokesApiApplication --\u003e ChuckNorrisService : uses\n    ChuckNorrisController --\u003e ChuckNorrisService : depends on\n\n```\n\n## Como executar:\n### 1. Clone o repositório:\n`git clone https://github.com/chrissperb/chucknorris-jokes-api.git`\n\n`cd chucknorris-jokes-api`\n\n### 2. Adicione a sua chave de API do DeepL no arquivo `application.properties`:\n`deep.api.key=YOUR_DEEPL_API_KEY`\n\n### 3. Compile e execute a aplicação na sua IDE preferida.\n\n### 4. Faça as requisições:\nAcesse o endpoint `http://localhost:8080/api/joke` para obter uma piada em inglês ou `http://localhost:8080/api/joke/pt` para obter uma piada em português.\n\n## Contribuições\nSinta-se à vontade para fazer um fork deste projeto e enviar pull requests com melhorias, novas funcionalidades ou correções. Toda contribuição é bem-vinda!\n\n## Licença\nEste projeto está licenciado sob os termos da MIT License. Consulte o arquivo [LICENSE]() para mais informações.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fchrissperb%2Fchucknorris-jokes-api","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fchrissperb%2Fchucknorris-jokes-api","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fchrissperb%2Fchucknorris-jokes-api/lists"}