queue.go 1.2 KB

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