Major integrations and fixes: - Added BACKBEAT SDK integration for P2P operation timing - Implemented beat-aware status tracking for distributed operations - Added Docker secrets support for secure license management - Resolved KACHING license validation via HTTPS/TLS - Updated docker-compose configuration for clean stack deployment - Disabled rollback policies to prevent deployment failures - Added license credential storage (CHORUS-DEV-MULTI-001) Technical improvements: - BACKBEAT P2P operation tracking with phase management - Enhanced configuration system with file-based secrets - Improved error handling for license validation - Clean separation of KACHING and CHORUS deployment stacks 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
30 lines
452 B
Go
30 lines
452 B
Go
package internal
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/go-redis/redis/v8/internal/rand"
|
|
)
|
|
|
|
func RetryBackoff(retry int, minBackoff, maxBackoff time.Duration) time.Duration {
|
|
if retry < 0 {
|
|
panic("not reached")
|
|
}
|
|
if minBackoff == 0 {
|
|
return 0
|
|
}
|
|
|
|
d := minBackoff << uint(retry)
|
|
if d < minBackoff {
|
|
return maxBackoff
|
|
}
|
|
|
|
d = minBackoff + time.Duration(rand.Int63n(int64(d)))
|
|
|
|
if d > maxBackoff || d < minBackoff {
|
|
d = maxBackoff
|
|
}
|
|
|
|
return d
|
|
}
|