2017-10-05 01:44:58 +06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2018-10-05 21:17:36 +06:00
|
|
|
"context"
|
2017-10-05 01:44:58 +06:00
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2018-10-05 21:17:36 +06:00
|
|
|
var timerSinceCtxKey = ctxKey("timerSince")
|
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
func setTimerSince(ctx context.Context) context.Context {
|
|
|
|
return context.WithValue(ctx, timerSinceCtxKey, time.Now())
|
2018-10-05 21:17:36 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
func getTimerSince(ctx context.Context) time.Duration {
|
|
|
|
return time.Since(ctx.Value(timerSinceCtxKey).(time.Time))
|
2017-10-05 01:44:58 +06:00
|
|
|
}
|
|
|
|
|
2018-10-05 21:17:36 +06:00
|
|
|
func checkTimeout(ctx context.Context) {
|
2017-10-05 01:44:58 +06:00
|
|
|
select {
|
2018-10-05 21:17:36 +06:00
|
|
|
case <-ctx.Done():
|
2018-10-25 19:24:34 +06:00
|
|
|
d := getTimerSince(ctx)
|
|
|
|
|
2020-01-31 20:00:05 +06:00
|
|
|
if ctx.Err() != context.DeadlineExceeded {
|
|
|
|
panic(newError(499, fmt.Sprintf("Request was cancelled after %v", d), "Cancelled"))
|
|
|
|
}
|
|
|
|
|
2018-10-25 19:24:34 +06:00
|
|
|
if newRelicEnabled {
|
|
|
|
sendTimeoutToNewRelic(ctx, d)
|
|
|
|
}
|
|
|
|
|
2018-10-29 18:04:47 +06:00
|
|
|
if prometheusEnabled {
|
|
|
|
incrementPrometheusErrorsTotal("timeout")
|
|
|
|
}
|
|
|
|
|
2018-10-25 19:24:34 +06:00
|
|
|
panic(newError(503, fmt.Sprintf("Timeout after %v", d), "Timeout"))
|
2017-10-05 01:44:58 +06:00
|
|
|
default:
|
|
|
|
// Go ahead
|
|
|
|
}
|
|
|
|
}
|