2024-10-14 14:58:51 -04:00
|
|
|
package history
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/libp2p/go-libp2p/core/peer"
|
|
|
|
)
|
|
|
|
|
|
|
|
type SortedStorenode struct {
|
2024-10-28 15:46:39 -04:00
|
|
|
Storenode peer.AddrInfo
|
2024-10-14 14:58:51 -04:00
|
|
|
RTT time.Duration
|
|
|
|
CanConnectAfter time.Time
|
|
|
|
}
|
|
|
|
|
|
|
|
type byRTTMsAndCanConnectBefore []SortedStorenode
|
|
|
|
|
|
|
|
func (s byRTTMsAndCanConnectBefore) Len() int {
|
|
|
|
return len(s)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s byRTTMsAndCanConnectBefore) Swap(i, j int) {
|
|
|
|
s[i], s[j] = s[j], s[i]
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s byRTTMsAndCanConnectBefore) Less(i, j int) bool {
|
|
|
|
// Slightly inaccurate as time sensitive sorting, but it does not matter so much
|
|
|
|
now := time.Now()
|
|
|
|
if s[i].CanConnectAfter.Before(now) && s[j].CanConnectAfter.Before(now) {
|
|
|
|
return s[i].RTT < s[j].RTT
|
|
|
|
}
|
|
|
|
return s[i].CanConnectAfter.Before(s[j].CanConnectAfter)
|
|
|
|
}
|