Ajouter GET /v5/membres pour lister membres en json
This commit is contained in:
parent
ae0f8fd38e
commit
6ede2083fa
5 changed files with 53 additions and 0 deletions
|
@ -65,6 +65,8 @@ var apiCmd = &cobra.Command{
|
||||||
|
|
||||||
e.POST("/v5/membres/", h.PostMembres)
|
e.POST("/v5/membres/", h.PostMembres)
|
||||||
|
|
||||||
|
e.GET("/v5/membres/", h.ListMembres)
|
||||||
|
|
||||||
e.GET("/v5/membres/:membre_id/", h.ReadMembre)
|
e.GET("/v5/membres/:membre_id/", h.ReadMembre)
|
||||||
|
|
||||||
e.PUT("/v5/membres/:membre_id/prefered_name/", h.PutMembrePreferedName)
|
e.PUT("/v5/membres/:membre_id/prefered_name/", h.PutMembrePreferedName)
|
||||||
|
|
|
@ -68,3 +68,7 @@ func (a *ApiClient) GetMembre(membreID string) (models.Membre, error) {
|
||||||
|
|
||||||
return getMembreResponse.Data.Membre, nil
|
return getMembreResponse.Data.Membre, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (a *ApiClient) ListMembres() (r responses.ListMembresResponse, err error) {
|
||||||
|
return r, a.Voki.Unmarshal(http.MethodGet, "/v5/membres", nil, true, &r)
|
||||||
|
}
|
||||||
|
|
|
@ -182,3 +182,7 @@ func (d *DataClient) UpdateMembreName(membreID, newName string) (int64, error) {
|
||||||
|
|
||||||
return rows, nil
|
return rows, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (d *DataClient) GetMembres() (membres []models.Membre, err error) {
|
||||||
|
return membres, d.DB.Select(&membres, "SELECT * FROM membres;")
|
||||||
|
}
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
package handlers
|
package handlers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
|
"git.agecem.com/agecem/bottin/v5/responses"
|
||||||
"github.com/labstack/echo/v4"
|
"github.com/labstack/echo/v4"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -29,3 +31,31 @@ func (h *Handler) ReadMembre(c echo.Context) error {
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (h *Handler) ListMembres(c echo.Context) error {
|
||||||
|
var r responses.ListMembresResponse
|
||||||
|
|
||||||
|
membres, err := h.DataClient.GetMembres()
|
||||||
|
if err != nil {
|
||||||
|
r.StatusCode = http.StatusInternalServerError
|
||||||
|
r.Error = err.Error()
|
||||||
|
r.Message = "Error during (*handlers.Handler).DataClient.GetMembres"
|
||||||
|
|
||||||
|
return c.JSON(r.StatusCode, r)
|
||||||
|
}
|
||||||
|
|
||||||
|
r.StatusCode = http.StatusOK
|
||||||
|
|
||||||
|
switch membres := len(membres); membres {
|
||||||
|
case 0:
|
||||||
|
r.Message = "No membres returned from database"
|
||||||
|
case 1:
|
||||||
|
r.Message = "Membre returned from database"
|
||||||
|
default:
|
||||||
|
r.Message = fmt.Sprintf("%d membres returned from database", membres)
|
||||||
|
}
|
||||||
|
|
||||||
|
r.Data.Membres = membres
|
||||||
|
|
||||||
|
return c.JSON(r.StatusCode, r)
|
||||||
|
}
|
||||||
|
|
13
responses/list.go
Normal file
13
responses/list.go
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
package responses
|
||||||
|
|
||||||
|
import (
|
||||||
|
"codeberg.org/vlbeaudoin/voki/response"
|
||||||
|
"git.agecem.com/agecem/bottin/v5/models"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ListMembresResponse struct {
|
||||||
|
response.ResponseWithError
|
||||||
|
Data struct {
|
||||||
|
Membres []models.Membre
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue