mirror of
https://github.com/router-for-me/CLIProxyAPI.git
synced 2026-02-02 20:40:52 +08:00
fix(auth): handle quota cooldown in retry logic for transient errors
This commit is contained in:
@@ -1371,8 +1371,12 @@ func (m *Manager) MarkResult(ctx context.Context, result Result) {
|
|||||||
shouldSuspendModel = true
|
shouldSuspendModel = true
|
||||||
setModelQuota = true
|
setModelQuota = true
|
||||||
case 408, 500, 502, 503, 504:
|
case 408, 500, 502, 503, 504:
|
||||||
next := now.Add(1 * time.Minute)
|
if quotaCooldownDisabled.Load() {
|
||||||
state.NextRetryAfter = next
|
state.NextRetryAfter = time.Time{}
|
||||||
|
} else {
|
||||||
|
next := now.Add(1 * time.Minute)
|
||||||
|
state.NextRetryAfter = next
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
state.NextRetryAfter = time.Time{}
|
state.NextRetryAfter = time.Time{}
|
||||||
}
|
}
|
||||||
@@ -1623,7 +1627,11 @@ func applyAuthFailureState(auth *Auth, resultErr *Error, retryAfter *time.Durati
|
|||||||
auth.NextRetryAfter = next
|
auth.NextRetryAfter = next
|
||||||
case 408, 500, 502, 503, 504:
|
case 408, 500, 502, 503, 504:
|
||||||
auth.StatusMessage = "transient upstream error"
|
auth.StatusMessage = "transient upstream error"
|
||||||
auth.NextRetryAfter = now.Add(1 * time.Minute)
|
if quotaCooldownDisabled.Load() {
|
||||||
|
auth.NextRetryAfter = time.Time{}
|
||||||
|
} else {
|
||||||
|
auth.NextRetryAfter = now.Add(1 * time.Minute)
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
if auth.StatusMessage == "" {
|
if auth.StatusMessage == "" {
|
||||||
auth.StatusMessage = "request failed"
|
auth.StatusMessage = "request failed"
|
||||||
|
|||||||
Reference in New Issue
Block a user