2023-06-06 02:22:57 -04:00
|
|
|
package handlers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"git.agecem.com/agecem/bottin-agenda/data"
|
|
|
|
"git.agecem.com/agecem/bottin-agenda/models"
|
|
|
|
"git.agecem.com/agecem/bottin-agenda/responses"
|
2023-06-08 04:04:02 -04:00
|
|
|
bottindata "git.agecem.com/agecem/bottin/v5/data"
|
2023-06-06 02:22:57 -04:00
|
|
|
"github.com/labstack/echo/v4"
|
2023-06-08 04:04:02 -04:00
|
|
|
"github.com/spf13/viper"
|
2023-06-06 02:22:57 -04:00
|
|
|
)
|
|
|
|
|
2023-06-08 21:08:20 -04:00
|
|
|
// GetTransactions handles the listing of transactions
|
2023-06-08 00:53:05 -04:00
|
|
|
func GetTransactions(c echo.Context) error {
|
|
|
|
var statusCode int = http.StatusInternalServerError
|
|
|
|
var response responses.GetTransactionsResponse
|
|
|
|
|
|
|
|
client, err := data.NewDataClientFromViper()
|
|
|
|
if err != nil {
|
|
|
|
response.Message = fmt.Sprintf("Error during data.NewDataClientFromViper(): %s", err)
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
defer client.DB.Close()
|
|
|
|
|
|
|
|
transactions, err := client.ListTransactions()
|
|
|
|
response.Data.Transactions = transactions
|
|
|
|
if err != nil {
|
|
|
|
response.Message = fmt.Sprintf("Error during client.ListTransactions(): %s", err)
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(transactions) == 0 {
|
|
|
|
response.Message = "No transactions found"
|
|
|
|
statusCode = http.StatusNotFound
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
|
|
|
response.Message = "List successful"
|
|
|
|
statusCode = http.StatusOK
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
2023-06-08 21:08:20 -04:00
|
|
|
// PostTransactions handles the creation of transactions
|
2023-06-06 02:22:57 -04:00
|
|
|
func PostTransactions(c echo.Context) error {
|
|
|
|
var statusCode int = http.StatusInternalServerError
|
|
|
|
var response responses.PostTransactionsResponse
|
|
|
|
|
|
|
|
var transactions []models.Transaction
|
|
|
|
|
|
|
|
if err := c.Bind(&transactions); err != nil {
|
|
|
|
statusCode = http.StatusBadRequest
|
|
|
|
response.Message = fmt.Sprintf("Error during c.Bind(): %s", err)
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
|
|
|
client, err := data.NewDataClientFromViper()
|
|
|
|
if err != nil {
|
|
|
|
response.Message = fmt.Sprintf("Error during data.NewDataClientFromViper(): %s", err)
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
defer client.DB.Close()
|
|
|
|
|
|
|
|
if len(transactions) == 0 {
|
|
|
|
response.Message = fmt.Sprintf("Nothing to do")
|
|
|
|
statusCode = http.StatusOK
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
2023-06-08 04:04:02 -04:00
|
|
|
bottinApiKey := viper.GetString("bottin.api.key")
|
|
|
|
bottinApiHost := viper.GetString("bottin.api.host")
|
|
|
|
bottinApiProtocol := viper.GetString("bottin.api.protocol")
|
|
|
|
bottinApiPort := viper.GetInt("bottin.api.port")
|
|
|
|
|
|
|
|
// Using bottin's API client
|
|
|
|
bottinApiClient := bottindata.NewApiClient(
|
|
|
|
bottinApiKey,
|
|
|
|
bottinApiHost,
|
|
|
|
bottinApiProtocol,
|
|
|
|
bottinApiPort,
|
|
|
|
)
|
|
|
|
|
|
|
|
// Check if membre_id exists according to bottin
|
|
|
|
for _, transaction := range transactions {
|
|
|
|
if transaction.MembreID == "" {
|
|
|
|
response.Message = fmt.Sprintf("Cannot insert transaction without a membre_id")
|
|
|
|
statusCode = http.StatusBadRequest
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
membre, err := bottinApiClient.GetMembre(transaction.MembreID)
|
|
|
|
if err != nil {
|
|
|
|
response.Message = fmt.Sprintf("Error during bottinApiClient.GetMembre(): %s", err)
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
|
|
|
if membre.ID == "" {
|
|
|
|
response.Message = fmt.Sprintf("Cannot insert transaction for non-existent membre %s", membre.ID)
|
|
|
|
statusCode = http.StatusNotFound
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
|
|
|
// membre exists, can keep going
|
|
|
|
}
|
|
|
|
|
2023-06-06 02:22:57 -04:00
|
|
|
// Check for already-existing transactions
|
|
|
|
for _, transaction := range transactions {
|
|
|
|
transaction, err := client.GetTransaction(transaction.MembreID, transaction.IsPerpetual)
|
|
|
|
if err != nil {
|
|
|
|
if err.Error() != "sql: no rows in result set" {
|
|
|
|
response.Message = fmt.Sprintf("Error during client.GetTransaction(): %s", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if transaction.ID != "" {
|
|
|
|
agendaType := "non-perpetual"
|
|
|
|
if transaction.IsPerpetual {
|
|
|
|
agendaType = "perpetual"
|
|
|
|
}
|
|
|
|
|
|
|
|
response.Message = fmt.Sprintf("Membre %s already received %s", transaction.MembreID, agendaType)
|
|
|
|
|
|
|
|
statusCode = http.StatusBadRequest
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-08 01:31:34 -04:00
|
|
|
insertedTransactions, err := client.InsertTransactions(transactions)
|
|
|
|
response.Data.Transactions = insertedTransactions
|
2023-06-06 02:22:57 -04:00
|
|
|
if err != nil {
|
|
|
|
response.Message = fmt.Sprintf("Error during client.InsertTransactions(): %s", err)
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|
|
|
|
|
|
|
|
statusCode = http.StatusCreated
|
|
|
|
response.Message = "Insert successful"
|
|
|
|
|
|
|
|
return c.JSON(statusCode, response)
|
|
|
|
}
|