From efcecbce6eb5fb7420ba89e2f39fe11afdf3d67a Mon Sep 17 00:00:00 2001 From: Victor Lacasse-Beaudoin Date: Sat, 16 Sep 2023 23:07:52 -0400 Subject: [PATCH] =?UTF-8?q?Impl=C3=A9menter=20apihandler.APIHandler.ScanPO?= =?UTF-8?q?ST?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apihandler/apihandler.go | 64 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 62 insertions(+), 2 deletions(-) diff --git a/apihandler/apihandler.go b/apihandler/apihandler.go index a7a21bf..a584e8a 100644 --- a/apihandler/apihandler.go +++ b/apihandler/apihandler.go @@ -7,6 +7,7 @@ import ( "git.agecem.com/agecem/bottin-ag/apiresponse" "git.agecem.com/agecem/bottin-ag/dbclient" + "git.agecem.com/agecem/bottin-ag/dbstruct" bottindata "git.agecem.com/agecem/bottin/v5/data" "github.com/labstack/echo/v4" ) @@ -15,6 +16,7 @@ import ( func DeclareRoutes(e *echo.Group, h *APIHandler) { e.GET("/health/", h.HealthGET) e.GET("/scan/:membre_id/", h.ScanGET) + e.POST("/scan/:membre_id/", h.ScanPOST) } /* @@ -97,6 +99,8 @@ func (a *APIHandler) ScanGET(c echo.Context) error { r.Message = fmt.Sprintf("%s est membre de l'AGECEM", membreID) } + //TODO remplir r.Data.IsScanned + return c.JSON(r.StatusCode, r) } @@ -104,7 +108,63 @@ func (a *APIHandler) ScanGET(c echo.Context) error { func (a *APIHandler) ScanPOST(c echo.Context) error { var r apiresponse.ScanPOST - _ = r + membreID := c.Param("membre_id") - return nil + membre, err := a.BottinAPIClient.GetMembre(membreID) + if err != nil { + switch err.Error() { + case "Ce numéro étudiant ne correspond à aucunE membre": + r.Message = fmt.Sprintf("%s n'est pas membre de l'AGECEM", membreID) + r.Error = err.Error() + r.StatusCode = http.StatusNotFound + + return c.JSON(r.StatusCode, r) + case "Veuillez fournir un numéro étudiant à rechercher": + r.Error = "membre_id ne peut pas être vide" + r.StatusCode = http.StatusBadRequest + r.Message = err.Error() + + return c.JSON(r.StatusCode, r) + default: + r.Error = err.Error() + r.Message = "Erreur lors de BottinAPIClient.GetMembre" + r.StatusCode = http.StatusInternalServerError + + return c.JSON(r.StatusCode, r) + } + } + + var presence dbstruct.Presence + + presence.ID = membre.ID + presence.ProgrammeID = membre.ProgrammeID + + switch membre.PreferedName != "" { + case true: + presence.Name = membre.PreferedName + case false: + presence.Name = fmt.Sprintf("%s, %s", membre.LastName, membre.FirstName) + } + + insertedPresence, err := a.DBClient.InsertPresence(presence) + if err != nil { + r.Error = err.Error() + r.Message = "Erreur lors de DBClient.InsertPresence" + r.StatusCode = http.StatusInternalServerError + + return c.JSON(r.StatusCode, r) + } + + if insertedPresence.ID == "" { + r.Error = "Membre déjà enregistré·e" + r.Message = fmt.Sprintf("Membre '%s' (%s) déjà enregistré·e.", presence.Name, presence.ID) + r.StatusCode = http.StatusBadRequest + + return c.JSON(r.StatusCode, r) + } + + r.StatusCode = http.StatusOK + r.Message = fmt.Sprintf("Membre '%s' (%s) enregistré·e avec succès, veuillez lui donner son carton de vote. Bonne assemblée!", insertedPresence.Name, insertedPresence.ID) + + return c.JSON(r.StatusCode, r) }