|
@@ -13,7 +13,31 @@ import (
|
|
)
|
|
)
|
|
|
|
|
|
var failOverCtxMutex = &sync.RWMutex{}
|
|
var failOverCtxMutex = &sync.RWMutex{}
|
|
|
|
+var failOverCacheMutex = &sync.RWMutex{}
|
|
|
|
+var failOverCache = make(map[models.NetworkID]string)
|
|
|
|
|
|
|
|
+func InitFailOverCache() {
|
|
|
|
+ failOverCacheMutex.Lock()
|
|
|
|
+ defer failOverCacheMutex.Unlock()
|
|
|
|
+ networks, err := logic.GetNetworks()
|
|
|
|
+ if err != nil {
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ allNodes, err := logic.GetAllNodes()
|
|
|
|
+ if err != nil {
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for _, network := range networks {
|
|
|
|
+ networkNodes := logic.GetNetworkNodesMemory(allNodes, network.NetID)
|
|
|
|
+ for _, node := range networkNodes {
|
|
|
|
+ if node.IsFailOver {
|
|
|
|
+ failOverCache[models.NetworkID(network.NetID)] = node.ID.String()
|
|
|
|
+ break
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+}
|
|
func SetFailOverCtx(failOverNode, victimNode, peerNode models.Node) error {
|
|
func SetFailOverCtx(failOverNode, victimNode, peerNode models.Node) error {
|
|
failOverCtxMutex.Lock()
|
|
failOverCtxMutex.Lock()
|
|
defer failOverCtxMutex.Unlock()
|
|
defer failOverCtxMutex.Unlock()
|
|
@@ -50,17 +74,26 @@ func GetFailOverNode(network string, allNodes []models.Node) (models.Node, error
|
|
return models.Node{}, errors.New("auto relay not found")
|
|
return models.Node{}, errors.New("auto relay not found")
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+func RemoveFailOverFromCache(network string) {
|
|
|
|
+ failOverCacheMutex.Lock()
|
|
|
|
+ defer failOverCacheMutex.Unlock()
|
|
|
|
+ delete(failOverCache, models.NetworkID(network))
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+func SetFailOverInCache(node models.Node) {
|
|
|
|
+ failOverCacheMutex.Lock()
|
|
|
|
+ defer failOverCacheMutex.Unlock()
|
|
|
|
+ failOverCache[models.NetworkID(node.Network)] = node.ID.String()
|
|
|
|
+}
|
|
|
|
+
|
|
// FailOverExists - checks if failOver exists already in the network
|
|
// FailOverExists - checks if failOver exists already in the network
|
|
func FailOverExists(network string) (failOverNode models.Node, exists bool) {
|
|
func FailOverExists(network string) (failOverNode models.Node, exists bool) {
|
|
- nodes, err := logic.GetNetworkNodes(network)
|
|
|
|
- if err != nil {
|
|
|
|
- return
|
|
|
|
- }
|
|
|
|
- for _, node := range nodes {
|
|
|
|
- if node.IsFailOver {
|
|
|
|
- exists = true
|
|
|
|
- failOverNode = node
|
|
|
|
- return
|
|
|
|
|
|
+ failOverCacheMutex.RLock()
|
|
|
|
+ defer failOverCacheMutex.RUnlock()
|
|
|
|
+ if nodeID, ok := failOverCache[models.NetworkID(network)]; ok {
|
|
|
|
+ failOverNode, err := logic.GetNodeByID(nodeID)
|
|
|
|
+ if err == nil {
|
|
|
|
+ return failOverNode, true
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return
|
|
return
|
|
@@ -185,5 +218,6 @@ func CreateFailOver(node models.Node) error {
|
|
slog.Error("failed to upsert node", "node", node.ID.String(), "error", err)
|
|
slog.Error("failed to upsert node", "node", node.ID.String(), "error", err)
|
|
return err
|
|
return err
|
|
}
|
|
}
|
|
|
|
+ SetFailOverInCache(node)
|
|
return nil
|
|
return nil
|
|
}
|
|
}
|