 9bdcbe0447
			
		
	
	9bdcbe0447
	
	
	
		
			
			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>
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package timecache
 | |
| 
 | |
| import (
 | |
| 	"time"
 | |
| 
 | |
| 	logger "github.com/ipfs/go-log/v2"
 | |
| )
 | |
| 
 | |
| var log = logger.Logger("pubsub/timecache")
 | |
| 
 | |
| // Stategy is the TimeCache expiration strategy to use.
 | |
| type Strategy uint8
 | |
| 
 | |
| const (
 | |
| 	// Strategy_FirstSeen expires an entry from the time it was added.
 | |
| 	Strategy_FirstSeen Strategy = iota
 | |
| 	// Stategy_LastSeen expires an entry from the last time it was touched by an Add or Has.
 | |
| 	Strategy_LastSeen
 | |
| )
 | |
| 
 | |
| // TimeCache is a cahe of recently seen messages (by id).
 | |
| type TimeCache interface {
 | |
| 	// Add adds an id into the cache, if it is not already there.
 | |
| 	// Returns true if the id was newly added to the cache.
 | |
| 	// Depending on the implementation strategy, it may or may not update the expiry of
 | |
| 	// an existing entry.
 | |
| 	Add(string) bool
 | |
| 	// Has checks the cache for the presence of an id.
 | |
| 	// Depending on the implementation strategy, it may or may not update the expiry of
 | |
| 	// an existing entry.
 | |
| 	Has(string) bool
 | |
| 	// Done signals that the user is done with this cache, which it may stop background threads
 | |
| 	// and relinquish resources.
 | |
| 	Done()
 | |
| }
 | |
| 
 | |
| // NewTimeCache defaults to the original ("first seen") cache implementation
 | |
| func NewTimeCache(ttl time.Duration) TimeCache {
 | |
| 	return NewTimeCacheWithStrategy(Strategy_FirstSeen, ttl)
 | |
| }
 | |
| 
 | |
| func NewTimeCacheWithStrategy(strategy Strategy, ttl time.Duration) TimeCache {
 | |
| 	switch strategy {
 | |
| 	case Strategy_FirstSeen:
 | |
| 		return newFirstSeenCache(ttl)
 | |
| 	case Strategy_LastSeen:
 | |
| 		return newLastSeenCache(ttl)
 | |
| 	default:
 | |
| 		// Default to the original time cache implementation
 | |
| 		return newFirstSeenCache(ttl)
 | |
| 	}
 | |
| }
 |