Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Padronização com responseEntity #27

Merged
merged 2 commits into from
Mar 10, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Jump to
Jump to file
Failed to load files.
Diff view
Diff view
6 changes: 5 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ Veja mais informações das lições aprendidas na [Wiki](https://github.com/jal

## Conteúdo

* [API Rest]()
* [API Rest](https://github.com/jalussa-santos/formacao-spring-boot#api-rest)
* [Boas práticas]()
* [Desenvolvimento avançado]()

Expand All @@ -21,6 +21,10 @@ Veja mais informações das lições aprendidas na [Wiki](https://github.com/jal
* [Atualizando dados com Spring Data JPA](https://github.com/jalussa-santos/formacao-spring-boot/issues/21)
* [Deletando dados com Spring Data JPA](https://github.com/jalussa-santos/formacao-spring-boot/issues/23)

>### Boas práticas
* [Padronizando retornos da API](https://github.com/jalussa-santos/formacao-spring-boot/issues/26)


>### Tecnologias:

* Java 17
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,21 @@
package com.formacao.springbootapi.controller;

import static org.springframework.http.ResponseEntity.created;
import static org.springframework.http.ResponseEntity.noContent;
import static org.springframework.http.ResponseEntity.ok;

import com.formacao.springbootapi.model.medico.CadastroMedicoDto;
import com.formacao.springbootapi.model.medico.DadosAtualizacaoMedicoDto;
import com.formacao.springbootapi.model.medico.DadosListagemMedicoDto;
import com.formacao.springbootapi.model.medico.DadosMedicoRequestDto;
import com.formacao.springbootapi.model.medico.DadosMedicoResponseDto;
import com.formacao.springbootapi.model.medico.Medico;
import com.formacao.springbootapi.model.medico.MedicoRepository;
import jakarta.validation.Valid;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.web.PageableDefault;
import org.springframework.http.ResponseEntity;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
Expand All @@ -19,6 +25,7 @@
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.util.UriComponentsBuilder;

@RestController
@RequestMapping("medicos")
Expand All @@ -29,29 +36,50 @@ public class MedicoController {

@PostMapping
@Transactional
public void cadastrar(@RequestBody @Valid CadastroMedicoDto dados) {
repository.save(new Medico(dados));
public ResponseEntity cadastrar(@RequestBody @Valid CadastroMedicoDto dados,
UriComponentsBuilder uriBuilder) {

var medico = new Medico(dados);
repository.save(medico);

var uri = uriBuilder.path("/medicos/{id}").buildAndExpand(medico.getId()).toUri();

return created(uri).body(new DadosMedicoResponseDto(medico));
}

@GetMapping
public Page<DadosListagemMedicoDto> listar(@PageableDefault(size = 10, sort = {"nome"}) Pageable paginacao) {
return repository.findAllByAtivoTrue(paginacao)
public ResponseEntity<Page<DadosListagemMedicoDto>> listar(
@PageableDefault(size = 10, sort = {"nome"}) Pageable paginacao) {
var page = repository.findAllByAtivoTrue(paginacao)
.map(DadosListagemMedicoDto::new);

return ok(page);
}

@PutMapping
@Transactional
public void atualizar(@RequestBody @Valid DadosAtualizacaoMedicoDto dados) {
public ResponseEntity atualizar(@RequestBody @Valid DadosMedicoRequestDto dados) {

var medico = repository.getReferenceById(dados.id());
medico.atualizarInformacoes(dados);

return ok(new DadosMedicoResponseDto(medico));
}

@DeleteMapping("/{id}")
@Transactional
public void excluir(@PathVariable Long id) {
public ResponseEntity excluir(@PathVariable Long id) {

var medico = repository.getReferenceById(id);
medico.excluir();

return noContent().build();
}

@GetMapping("/{id}")
public ResponseEntity detalhar(@PathVariable Long id) {

var medico = repository.getReferenceById(id);
return ok(new DadosMedicoResponseDto(medico));
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import com.formacao.springbootapi.model.endereco.EnderecoDto;
import jakarta.validation.constraints.NotNull;

public record DadosAtualizacaoMedicoDto(
public record DadosMedicoRequestDto(
@NotNull
Long id,
String nome,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package com.formacao.springbootapi.model.medico;

import com.formacao.springbootapi.model.endereco.Endereco;

public record DadosMedicoResponseDto(Long id, String nome, String email, String crm,
String telefone, Especialidade especialidade,
Endereco endereco) {

public DadosMedicoResponseDto(Medico medico) {
this(medico.getId(), medico.getNome(), medico.getEmail(), medico.getCrm(), medico.getTelefone(),
medico.getEspecialidade(), medico.getEndereco());

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ public Medico(CadastroMedicoDto medico) {
this.endereco = new Endereco(medico.endereco());
}

public void atualizarInformacoes(DadosAtualizacaoMedicoDto dados) {
public void atualizarInformacoes(DadosMedicoRequestDto dados) {

if (dados.nome() != null) {
this.nome = dados.nome();
Expand Down