--- date: 2016-12-14 13:45:00 +0100 author: "Geoffrey Preud'homme" tags: ci --- # Flashmob de l'associatif Le principe aurait été de faire une chorée club de 30 secondes et une chorée avec tous les autres clubs d'une minute. Les répétitions sont pendant les examens donc personne n'est chaud pour faire la chorégraphie, pas même les autres clubs :) # Kilobits Le repo est prêt pour bosser. On utilise le protocole REST pour accéder et modifier les ressources depuis les applications clientes et le serveur. Pour cela, c'est Spring qu'on utilise (à titre informatif, on utilise plus le faux Spring mais le vrai. Ça a rien changé parce qu'on l'avait pas utilisé ^^). On peut demander à ce qu'une ressource soit récupérée (GET), ajoutée (POST), modifiée (PUT) ou supprimée (DELETE), que l'on envoie à un certaine adresse correspondant à la ressource. Exemple de déclaration d'une classe, que l'on crée pour chaque type de ressource. ```java @RestController @RequestMapping("/user") public class UserRest { ``` Exemple d'une fonction : ```java @RequestMapping(value = "/list", method = RequestMethod.GET) public List<User> getAllUser() { return dao.getAllUser(); } ``` Par exemple, ici en faisant une requête GET sur `/user/list` le serveur nous retournera la liste des utilisateurs. Plus d'exemples : [https://github.com/ClubInfoPolytechLille/kilobits-serv/blob/master/src/main/java/com/tbe/rest/UserREST.java](https://github.com/ClubInfoPolytechLille/kilobits-serv/blob/master/src/main/java/com/tbe/rest/UserREST.java) On utilise JDBI pour simplifier la manière dont on accède aux bases de données. On peut du coup écrire une requête en deux lignes (à peu près). On crée aussi une classe par type de ressource : ```java public interface UserDao { String strCreateUtilisateurTable = "Create table if not exists Utilisateur (...)" ``` Et on déclare ici ce qui est était appelé dans la fonction REST pour récupérer les utilisateurs : ```java @SqlQuery("Select * from utilisateur") @RegisterMapperFactory(BeanMapperFactory.class) List<User> getAllUser(); ``` Un autre exemple avec modification de données (donc POST) : ```java @SqlUpdate("insert into langue (langue) values (:langue)") @GetGeneratedKeys int addLangue(@Bind("langue") String langue); ``` Et tout ça, ça se passe ici : [https://github.com/ClubInfoPolytechLille/kilobits-serv/tree/master/src/main/java/com/tbe/database](https://github.com/ClubInfoPolytechLille/kilobits-serv/tree/master/src/main/java/com/tbe/database) Petites explications sur le code directement, c'est un peu compliqué à écrire directement sur un compte rendu donc fermez les yeux et imaginez. Ou ouvrez le code c'est mieux. Ré-éxplication de Trello, cf [compte-rendu de la dernière fois](https://clubinfo.plil.net/cr/2016/12/07/compte-rendu-reunion.html#nouveaux-outils-de-gestion-de-projet).