Spaces:
Sleeping
Sleeping
package stock | |
import ( | |
"fmt" | |
"log" | |
"sync" | |
"time" | |
"context" | |
"net/http" | |
"github.com/gofiber/fiber/v2" | |
) | |
/* | |
* --- Stock Prediction Handler --- | |
*/ | |
func StockPredictionHandler(service StockService) fiber.Handler { | |
return func(c *fiber.Ctx) error { | |
ctx, cancel := context.WithTimeout(c.Context(), 120 * time.Second) | |
defer cancel() | |
ch := make(chan ApiResponse, 1) | |
var wg sync.WaitGroup | |
wg.Add(1) | |
go func() { | |
defer wg.Done() | |
var predictionReq PredictionRequest | |
if err := c.BodyParser(&predictionReq); err != nil { | |
log.Printf("[%s] Failed to parse request body: %v", | |
time.Now().Format("2006-01-02 15:04:05"), err) | |
ch <- ApiResponse{ | |
Message: fmt.Sprintf("Failed to parse request body: %v", err), | |
StatusCode: http.StatusBadRequest, | |
} | |
return | |
} | |
apiResponse, err := service.StockPredictionService(ctx, predictionReq) | |
if err != nil { | |
log.Printf("[%s] %v", time.Now().Format("2006-01-02 15:04:05"), err) | |
ch <- apiResponse | |
return | |
} | |
ch <- apiResponse | |
}() | |
go func() { | |
wg.Wait() | |
close(ch) | |
}() | |
select { | |
case apiResponse, ok := <-ch: | |
if !ok { | |
return c.Status(http.StatusInternalServerError).JSON(fiber.Map{ | |
"error": "Failed to get a response from the server", | |
}) | |
} | |
return c.Status(apiResponse.StatusCode).JSON(apiResponse) | |
case <-ctx.Done(): | |
log.Printf("[%s] Timeout: %v", time.Now().Format("2006-01-02 15:04:05"), ctx.Err()) | |
return c.Status(http.StatusRequestTimeout).JSON(fiber.Map{ | |
"error": "Request timeout", | |
}) | |
} | |
} | |
} | |