queues-go/app/routers/take.go
Egor Matveev c9871c80c8
All checks were successful
Deploy Dev / Build (pull_request) Successful in 42s
Deploy Dev / Push (pull_request) Successful in 25s
Deploy Dev / Deploy dev (pull_request) Successful in 7s
fix
2025-01-06 13:07:17 +03:00

51 lines
943 B
Go

package routers
import (
"fmt"
"net/http"
tasks "queues-go/app/storage/mongo/collections"
"queues-go/app/storage/redis"
"time"
)
type TaskResponse struct {
Id string `json:"id"`
Attempt int `json:"attempt"`
Payload interface{} `json:"payload"`
}
type TakeResponse struct {
Task *TaskResponse `json:"task"`
}
func Take(r *http.Request) (interface{}, int) {
queue := r.Header.Get("queue")
mutex := redis.Sync.NewMutex(fmt.Sprintf("lock_queues_%s", queue))
for {
err := mutex.Lock()
if err != nil {
time.Sleep(time.Millisecond * 5)
} else {
break
}
}
task, err := tasks.Take(queue)
mutex.Unlock()
if err != nil {
return nil, http.StatusInternalServerError
}
var response TakeResponse
if task == nil {
response.Task = nil
} else {
response.Task = &TaskResponse{
Id: task.Id.Hex(),
Attempt: task.Attempts,
Payload: task.Payload,
}
}
return response, http.StatusOK
}