Merge branch 'feature/list-membres'

This commit is contained in:
Victor Lacasse-Beaudoin 2023-09-19 19:21:58 -04:00
commit 6d2062aecc
5 changed files with 53 additions and 0 deletions

View file

@ -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)

View file

@ -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)
}

View file

@ -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;")
}

View file

@ -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
View 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
}
}