Blame view

src/main/java/etunicorn/controller/PersonneController.java 5.91 KB
2f1f76a9   Geoffrey PREUD'HOMME   Mise sous packages
1
  package etunicorn.controller;
d167a387   Geoffrey PREUD'HOMME   On génère mieux
2
  
2f1f76a9   Geoffrey PREUD'HOMME   Mise sous packages
3
4
5
  import etunicorn.RestrictedTo;
  import etunicorn.entity.Personne;
  import etunicorn.entity.Role;
5596f9d9   Geoffrey PREUD'HOMME   Début de l'implém...
6
7
  import etunicorn.generated.model.UpdatePersonneByIdRequest;
  import etunicorn.generated.model.UpdatePersonneRequest;
0fd5cbb2   Geoffrey PREUD'HOMME   Changements API &...
8
  import etunicorn.generated.model.UpdateVirerRequest;
2f1f76a9   Geoffrey PREUD'HOMME   Mise sous packages
9
10
  import etunicorn.repository.PersonneRepository;
  import etunicorn.repository.RoleRepository;
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
11
  import org.springframework.beans.factory.annotation.Autowired;
8f05ee77   Geoffrey PREUD'HOMME   API /role et amél...
12
  import org.springframework.dao.DataIntegrityViolationException;
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
13
  import org.springframework.http.HttpStatus;
d167a387   Geoffrey PREUD'HOMME   On génère mieux
14
15
  import org.springframework.http.ResponseEntity;
  import org.springframework.web.bind.annotation.PathVariable;
5596f9d9   Geoffrey PREUD'HOMME   Début de l'implém...
16
  import org.springframework.web.bind.annotation.RequestBody;
d167a387   Geoffrey PREUD'HOMME   On génère mieux
17
18
  import org.springframework.web.bind.annotation.RestController;
  
5596f9d9   Geoffrey PREUD'HOMME   Début de l'implém...
19
  import javax.validation.Valid;
3e3b38c1   badetitou   VITE JE SUIS LE P...
20
21
  import java.text.ParseException;
  import java.text.SimpleDateFormat;
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
22
  import java.util.LinkedHashMap;
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
23
  import java.util.List;
d167a387   Geoffrey PREUD'HOMME   On génère mieux
24
25
  
  /**
3064f583   Geoffrey PREUD'HOMME   Copyright
26
27
28
   * etunicorn-server
   * Copyright © 2017 Le Club Info Polytech Lille
   * Tous droits réservés
d167a387   Geoffrey PREUD'HOMME   On génère mieux
29
30
31
   */
  
  @RestController
8f35fffd   Geoffrey PREUD'HOMME   Ajout de la sécurité
32
  public class PersonneController extends BaseController implements etunicorn.generated.PersonneController {
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
33
34
35
      @Autowired
      private PersonneRepository personneRepository;
  
8f05ee77   Geoffrey PREUD'HOMME   API /role et amél...
36
37
38
      @Autowired
      private RoleRepository roleRepository;
  
d167a387   Geoffrey PREUD'HOMME   On génère mieux
39
      @Override
8f35fffd   Geoffrey PREUD'HOMME   Ajout de la sécurité
40
      @RestrictedTo("PERSONNE_LIST")
d167a387   Geoffrey PREUD'HOMME   On génère mieux
41
      public ResponseEntity<?> getPersonne() {
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
42
          return new ResponseEntity<List>((List) this.personneRepository.findAll(), HttpStatus.OK);
d167a387   Geoffrey PREUD'HOMME   On génère mieux
43
44
      }
  
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
45
      private ResponseEntity<?> mergePersonne(Personne personne, UpdatePersonneRequest updatePersonneRequest) {
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
46
          if (updatePersonneRequest.getNaissance() != null) {
4fd7a7fc   Geoffrey PREUD'HOMME   /evenement
47
              SimpleDateFormat format = new SimpleDateFormat("Y-M-d");
3e3b38c1   badetitou   VITE JE SUIS LE P...
48
49
50
              try {
                  personne.setNaissance(format.parse(updatePersonneRequest.getNaissance()));
              } catch (ParseException e) {
3c4951b9   Geoffrey PREUD'HOMME   Date & Avancement...
51
                  return generateError(HttpStatus.BAD_REQUEST, e, "La date n'est pas au format " + format.toString());
3e3b38c1   badetitou   VITE JE SUIS LE P...
52
              }
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
53
          }
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
54
55
          if (updatePersonneRequest.getCarte() != null) {
              personne.setCarte(updatePersonneRequest.getCarte());
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
56
          }
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
57
58
          if (updatePersonneRequest.getLogin() != null) {
              personne.setLogin(updatePersonneRequest.getLogin());
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
59
          }
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
60
          if (updatePersonneRequest.getRole() != null) {
8799baa6   Geoffrey PREUD'HOMME   Ajout des entitée...
61
62
63
64
65
66
67
68
69
70
71
72
              if (updatePersonneRequest.getRole() instanceof LinkedHashMap) {
                  LinkedHashMap<String, String> roleMap = (LinkedHashMap<String, String>) updatePersonneRequest.getRole();
                  Role role = roleRepository.findByNom(roleMap.get("nom"));
                  if (role == null) {
                      return generateError(HttpStatus.NOT_FOUND, "Rôle inconnu");
                  }
                  if (personne.getRole() != role) {
                      if (hasPermission("PERSONNE_ROLE")) {
                          personne.setRole(role);
                      } else {
                          return generateError(HttpStatus.FORBIDDEN, "Vous ne pouvez pas changer le rôle");
                      }
8f35fffd   Geoffrey PREUD'HOMME   Ajout de la sécurité
73
                  }
8799baa6   Geoffrey PREUD'HOMME   Ajout des entitée...
74
              } else {
2cc8026e   Geoffrey PREUD'HOMME   WIP Achat
75
                  return generateError(HttpStatus.BAD_REQUEST, "Rôle doit être un objet");
8f05ee77   Geoffrey PREUD'HOMME   API /role et amél...
76
77
              }
          }
3c4951b9   Geoffrey PREUD'HOMME   Date & Avancement...
78
79
80
81
82
83
84
85
  
          if (personne.getCarte() == null && personne.getLogin() == null) {
              return generateError(HttpStatus.BAD_REQUEST, "Le login ou la carte doivent être au moins renseignés.");
          }
          if (personne.getRole() == null) {
              personne.setRole(roleRepository.findByNom("etudiant"));
          }
  
8f05ee77   Geoffrey PREUD'HOMME   API /role et amél...
86
87
88
          try {
              this.personneRepository.save(personne);
          } catch (DataIntegrityViolationException e) {
8799baa6   Geoffrey PREUD'HOMME   Ajout des entitée...
89
              return generateError(HttpStatus.CONFLICT, "Un utilisateur avec la même carte ou le même login existe déjà");
8f05ee77   Geoffrey PREUD'HOMME   API /role et amél...
90
          }
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
91
          return new ResponseEntity<Object>(personne, HttpStatus.CREATED);
d167a387   Geoffrey PREUD'HOMME   On génère mieux
92
93
94
      }
  
      @Override
8f35fffd   Geoffrey PREUD'HOMME   Ajout de la sécurité
95
      @RestrictedTo("PERSONNE_ADD")
5596f9d9   Geoffrey PREUD'HOMME   Début de l'implém...
96
97
      public ResponseEntity<?> updatePersonne(@Valid @RequestBody UpdatePersonneRequest updatePersonneRequest) {
          Personne personne = new Personne();
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
98
          return mergePersonne(personne, updatePersonneRequest);
8f05ee77   Geoffrey PREUD'HOMME   API /role et amél...
99
100
101
      }
  
      @Override
8f35fffd   Geoffrey PREUD'HOMME   Ajout de la sécurité
102
      @RestrictedTo("PERSONNE_GET")
6b23f1ca   Geoffrey PREUD'HOMME   Correction /conso...
103
      public ResponseEntity<?> getPersonneById(@PathVariable Long idPersonne) {
0fd5cbb2   Geoffrey PREUD'HOMME   Changements API &...
104
          Personne personne = personneRepository.findById(idPersonne.intValue());
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
105
106
107
108
          if (personne == null) {
              return new ResponseEntity<Object>(HttpStatus.NOT_FOUND);
          }
          return new ResponseEntity<Object>(personne, HttpStatus.OK);
d167a387   Geoffrey PREUD'HOMME   On génère mieux
109
110
111
      }
  
      @Override
8f35fffd   Geoffrey PREUD'HOMME   Ajout de la sécurité
112
      @RestrictedTo("PERSONNE_EDIT")
6b23f1ca   Geoffrey PREUD'HOMME   Correction /conso...
113
      public ResponseEntity<?> updatePersonneById(@PathVariable Long idPersonne, @Valid @RequestBody UpdatePersonneByIdRequest updatePersonneByIdRequest) {
0fd5cbb2   Geoffrey PREUD'HOMME   Changements API &...
114
          Personne personne = personneRepository.findById(idPersonne.intValue());
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
115
          if (personne == null) {
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
116
              return generateError(HttpStatus.NOT_FOUND, "Personne introuvable");
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
117
          }
474776a8   Geoffrey PREUD'HOMME   Implémentation JS...
118
119
120
121
122
123
          UpdatePersonneRequest updatePersonneRequest = new UpdatePersonneRequest();
          updatePersonneRequest.setCarte(updatePersonneByIdRequest.getCarte());
          updatePersonneRequest.setNaissance(updatePersonneByIdRequest.getNaissance());
          updatePersonneRequest.setLogin(updatePersonneByIdRequest.getLogin());
          updatePersonneRequest.setRole(updatePersonneByIdRequest.getRole());
          return mergePersonne(personne, updatePersonneRequest);
d167a387   Geoffrey PREUD'HOMME   On génère mieux
124
125
126
      }
  
      @Override
8f35fffd   Geoffrey PREUD'HOMME   Ajout de la sécurité
127
      @RestrictedTo("PERSONNE_REMOVE")
6b23f1ca   Geoffrey PREUD'HOMME   Correction /conso...
128
      public ResponseEntity<?> deletePersonneById(@PathVariable Long idPersonne) {
0fd5cbb2   Geoffrey PREUD'HOMME   Changements API &...
129
          Personne personne = personneRepository.findById(idPersonne.intValue());
3c4951b9   Geoffrey PREUD'HOMME   Date & Avancement...
130
  
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
131
132
133
134
135
          if (personne == null) {
              return new ResponseEntity<Object>(HttpStatus.NOT_FOUND);
          }
          personneRepository.delete(personne);
          return new ResponseEntity<Object>(personne, HttpStatus.NO_CONTENT);
d167a387   Geoffrey PREUD'HOMME   On génère mieux
136
      }
790d94b4   Geoffrey PREUD'HOMME   Base de données, ...
137
  
0fd5cbb2   Geoffrey PREUD'HOMME   Changements API &...
138
      @Override
6b23f1ca   Geoffrey PREUD'HOMME   Correction /conso...
139
      public ResponseEntity<?> updateVirer(@PathVariable Long idPersonne, @Valid @RequestBody UpdateVirerRequest updateVirerRequest) {
0fd5cbb2   Geoffrey PREUD'HOMME   Changements API &...
140
141
          return null;
      }
d167a387   Geoffrey PREUD'HOMME   On génère mieux
142
  }