Merge branch 'feature/list-membres'
This commit is contained in:
commit
6d2062aecc
5 changed files with 53 additions and 0 deletions
|
@ -65,6 +65,8 @@ var apiCmd = &cobra.Command{
|
|||
|
||||
e.POST("/v5/membres/", h.PostMembres)
|
||||
|
||||
e.GET("/v5/membres/", h.ListMembres)
|
||||
|
||||
e.GET("/v5/membres/:membre_id/", h.ReadMembre)
|
||||
|
||||
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
|
||||
}
|
||||
|
||||
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
|
||||
}
|
||||
|
||||
func (d *DataClient) GetMembres() (membres []models.Membre, err error) {
|
||||
return membres, d.DB.Select(&membres, "SELECT * FROM membres;")
|
||||
}
|
||||
|
|
|
@ -1,8 +1,10 @@
|
|||
package handlers
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"net/http"
|
||||
|
||||
"git.agecem.com/agecem/bottin/v5/responses"
|
||||
"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
|
||||
}
|
||||
}
|
Reference in a new issue