Files
sendico/api/server/internal/server/siteimp/demo.go
Stephan D 36d1a94cf6
Some checks failed
ci/woodpecker/push/billing_fees Pipeline was successful
ci/woodpecker/push/bff Pipeline was successful
ci/woodpecker/push/db Pipeline was successful
ci/woodpecker/push/chain_gateway Pipeline was successful
ci/woodpecker/push/frontend Pipeline was successful
ci/woodpecker/push/fx_oracle Pipeline was successful
ci/woodpecker/push/fx_ingestor Pipeline was successful
ci/woodpecker/push/bump_version Pipeline failed
ci/woodpecker/push/nats Pipeline was successful
ci/woodpecker/push/ledger Pipeline was successful
ci/woodpecker/push/notification Pipeline was successful
ci/woodpecker/push/payments_orchestrator Pipeline was successful
+ call request
2025-11-19 22:19:27 +01:00

32 lines
1.0 KiB
Go

package siteimp
import (
"encoding/json"
"net/http"
"github.com/tech/sendico/pkg/api/http/response"
snotifications "github.com/tech/sendico/pkg/messaging/notifications/site"
"github.com/tech/sendico/pkg/model"
"go.uber.org/zap"
)
func (a *SiteAPI) demoRequest(r *http.Request) http.HandlerFunc {
var request model.DemoRequest
if err := json.NewDecoder(r.Body).Decode(&request); err != nil {
a.logger.Warn("Failed to decode demo request payload", zap.Error(err))
return response.BadRequest(a.logger, a.Name(), "invalid_payload", "Failed to decode demo request payload")
}
request.Normalize()
if err := request.Validate(); err != nil {
a.logger.Warn("Demo request validation failed", zap.Error(err))
return response.BadPayload(a.logger, a.Name(), err)
}
if err := a.producer.SendMessage(snotifications.DemoRequest(a.Name(), &request)); err != nil {
a.logger.Warn("Failed to enqueue demo request notification", zap.Error(err))
return response.Internal(a.logger, a.Name(), err)
}
return a.acceptedQueued()
}