agendas/handler.go

147 lines
3.5 KiB
Go
Raw Normal View History

2024-12-23 20:57:58 -05:00
package main
import (
"context"
"fmt"
"log"
"net/http"
"git.agecem.com/bottin/bottin/v10/pkg/bottin"
"github.com/labstack/echo/v4"
)
// Handling
2024-12-30 15:00:42 -05:00
func UIIndex(ctx context.Context, bottinClient *bottin.APIClient, dbClient *DBClient) echo.HandlerFunc {
2024-12-23 20:57:58 -05:00
return func(c echo.Context) error {
type data struct {
Error string
BottinHealthResponse bottin.ReadHealthResponse
2024-12-30 15:00:42 -05:00
IsDBUp bool
2024-12-30 19:13:05 -05:00
Result string
2024-12-23 20:57:58 -05:00
}
2024-12-30 19:14:49 -05:00
return c.Render(http.StatusOK, "app", func() (d data) {
2024-12-23 20:57:58 -05:00
if err := func() error {
select {
case <-ctx.Done():
return fmt.Errorf("Impossible de contacter le serveur: %s", ctx.Err())
default:
// Check client
if bottinClient == nil {
return fmt.Errorf("Impossible de contacter le serveur, le client API est nil")
}
// Check bottin health
bottinHealthResponse, err := bottinClient.ReadHealth(ctx)
if err != nil {
return err
}
d.BottinHealthResponse = bottinHealthResponse
2024-12-30 15:00:42 -05:00
// Check db health
if dbClient == nil {
return fmt.Errorf("Impossible de contacter la base de données, le client DB est nil")
}
if err := dbClient.Ping(ctx); err != nil {
return err
}
d.IsDBUp = true
2024-12-23 20:57:58 -05:00
// No errors
return nil
}
}(); err != nil {
// Send error to user
d.Error = err.Error()
// Log error
log.Println("err:", d.Error)
}
return
}())
}
}
2024-12-30 15:00:42 -05:00
/*
UICreateTransaction gère la création des transactions
TODO:
- Fully implement
- Check context is not closed
*/
func UICreateTransaction(ctx context.Context, cfg Config, bottinClient *bottin.APIClient, dbClient *DBClient) echo.HandlerFunc {
return func(c echo.Context) error {
type data struct {
2024-12-30 19:13:05 -05:00
Error string
Result string
//BottinHealth bottin.ReadHealthResponse
2024-12-30 15:00:42 -05:00
}
2024-12-30 19:14:49 -05:00
return c.Render(http.StatusOK, "app", func() (d data) {
2024-12-30 15:00:42 -05:00
if err := func() error {
if bottinClient == nil {
return fmt.Errorf("Cannot operate on nil *bottin.APIClient")
}
2024-12-30 19:13:05 -05:00
/*
bottinReadHealthResponse, err := bottinClient.ReadHealth(ctx)
if err != nil {
return err
}
2024-12-30 15:00:42 -05:00
2024-12-30 19:13:05 -05:00
d.BottinHealth = bottinReadHealthResponse
*/
2024-12-30 15:00:42 -05:00
isPerpetual := c.FormValue("is_perpetual") == "on"
membreID := c.FormValue("membre_id")
if membreID == "" {
2024-12-30 19:44:56 -05:00
return fmt.Errorf("Aucun numéro étudiant sélectionné. Assurez-vous de cliquer sur la case 'Numéro étudiant:' avant de scanner.")
2024-12-30 15:00:42 -05:00
}
2024-12-30 19:38:01 -05:00
//TODO check if membre already received before checking bottin
// check if membre exists in bottin
membreResponse, err := bottinClient.ReadMembre(ctx, membreID)
if err != nil {
if err.Error() == "400 no rows in result set" {
2024-12-30 19:44:56 -05:00
return fmt.Errorf("Numéro étudiant introuvable %s", membreID)
2024-12-30 19:38:01 -05:00
}
return err
}
if membreResponse.Data.Membre.ID != membreID {
2024-12-30 19:44:56 -05:00
return fmt.Errorf("Bottin a retourné '%s' en demandant '%s'", membreID, membreResponse.Data.Membre.ID)
2024-12-30 19:38:01 -05:00
}
2024-12-30 15:00:42 -05:00
// dbclient.CreateTransaction
if err := dbClient.CreateTransaction(ctx, Transaction{
MembreID: membreID,
IsPerpetual: isPerpetual,
}); err != nil {
return err
}
// Prepare result message
2024-12-30 19:44:56 -05:00
d.Result = fmt.Sprintf("Membre %s peut recevoir son agenda %s",
2024-12-30 19:38:01 -05:00
membreID,
func() string {
if isPerpetual {
return "perpétuel"
} else {
return "non-perpétuel"
}
}(),
)
return nil
2024-12-30 15:00:42 -05:00
}(); err != nil {
d.Error = err.Error()
log.Println("err:", d.Error)
}
return
}())
}
}