fix #12

Merged
emmatveev merged 1 commits from master into dev 2025-01-06 13:21:10 +03:00

View File

@ -1,8 +1,11 @@
package routers
import (
"fmt"
"net/http"
tasks "queues-go/app/storage/mongo/collections"
"queues-go/app/storage/redis"
"time"
)
type TaskResponse struct {
@ -17,17 +20,17 @@ type TakeResponse struct {
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
// }
// }
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()
mutex.Unlock()
if err != nil {
return nil, http.StatusInternalServerError
}