queue.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. package web
  2. import (
  3. "log"
  4. "net/http"
  5. "time"
  6. "github.com/gin-contrib/sessions"
  7. "github.com/gin-gonic/gin"
  8. "code.osinet.fr/fgm/sqs_demo/back/services/redriver"
  9. )
  10. func makeQueueHandler(rd redriver.Redriver) gin.HandlerFunc {
  11. return func(c *gin.Context) {
  12. ctx := c.Request.Context()
  13. qName := c.Param("name")
  14. sess := sessions.Default(c)
  15. flashes := sess.Flashes()
  16. _ = sess.Save()
  17. t0 := time.Now()
  18. qi, err := rd.GetQueueInfo(ctx, qName)
  19. if err != nil {
  20. log.Printf("failed getting info for queue %q: %v", qName, err)
  21. c.JSON(http.StatusInternalServerError, nil)
  22. return
  23. }
  24. infoLatency := time.Since(t0)
  25. items, err := rd.GetQueueItems(ctx, qName)
  26. if err != nil {
  27. log.Printf("failed getting items for queue %q: %v", qName, err)
  28. c.JSON(http.StatusInternalServerError, nil)
  29. return
  30. }
  31. itemsLatency := time.Since(t0) - infoLatency
  32. c.HTML(http.StatusOK, "queue-get", map[string]any{
  33. "flashes": flashes,
  34. "info": qi,
  35. "items": items,
  36. "latency": map[string]time.Duration{
  37. "info": infoLatency,
  38. "items": itemsLatency,
  39. },
  40. })
  41. }
  42. }