2023-08-31 20:52:52 +00:00
|
|
|
# nim-raft
|
|
|
|
# Copyright (c) 2023 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
|
|
|
# at your option.
|
|
|
|
# This file may not be copied, modified, or distributed except according to
|
|
|
|
# those terms.
|
|
|
|
|
|
|
|
import basic_timers
|
|
|
|
import basic_state_machine
|
|
|
|
|
2023-08-31 22:00:39 +00:00
|
|
|
export raft_api
|
|
|
|
|
2023-08-31 20:52:52 +00:00
|
|
|
type
|
|
|
|
BasicRaftNode* = RaftNode[SmCommand, SmState]
|
|
|
|
|
|
|
|
BasicRaftCluster* = ref object
|
|
|
|
nodes*: seq[BasicRaftNode]
|
|
|
|
|
|
|
|
proc BasicRaftClusterRaftMessageSendCallbackCreate(cluster: BasicRaftCluster): RaftMessageSendCallback =
|
2023-09-01 02:55:55 +00:00
|
|
|
proc (msg: RaftMessageBase): Future[RaftMessageResponseBase] {.async, gcsafe.} =
|
2023-08-31 20:52:52 +00:00
|
|
|
var
|
|
|
|
nodeIdx: int = -1
|
|
|
|
|
|
|
|
for i in 0..cluster.nodes.len:
|
2023-08-31 23:56:15 +00:00
|
|
|
if RaftNodeIdGet(cluster.nodes[i]) == msg.receiverId:
|
2023-08-31 20:52:52 +00:00
|
|
|
nodeIdx = i
|
|
|
|
break
|
|
|
|
|
2023-09-01 02:55:55 +00:00
|
|
|
result = await cluster.nodes[nodeIdx].RaftNodeMessageDeliver(msg)
|
2023-08-31 20:52:52 +00:00
|
|
|
|
2023-08-31 23:56:15 +00:00
|
|
|
proc BasicRaftClusterStart*(cluster: BasicRaftCluster) =
|
|
|
|
for node in cluster.nodes:
|
|
|
|
RaftNodeStart(node)
|
|
|
|
|
|
|
|
proc BasicRaftClusterGetLeader*(cluster: BasicRaftCluster): UUID =
|
|
|
|
result = DefaultUUID
|
|
|
|
for node in cluster.nodes:
|
|
|
|
if RaftNodeIsLeader(node):
|
|
|
|
return RaftNodeIdGet(node)
|
|
|
|
|
2023-08-31 20:52:52 +00:00
|
|
|
proc BasicRaftClusterClientRequest*(cluster: BasicRaftCluster, req: RaftNodeClientRequest): RaftNodeClientResponse =
|
|
|
|
discard
|
|
|
|
|
|
|
|
proc BasicRaftClusterInit*(nodesIds: seq[RaftNodeId]): BasicRaftCluster =
|
|
|
|
new(result)
|
|
|
|
for nodeId in nodesIds:
|
|
|
|
var
|
|
|
|
peersIds = nodesIds
|
|
|
|
|
|
|
|
peersIds.del(peersIds.find(nodeId))
|
2023-08-31 23:56:15 +00:00
|
|
|
result.nodes.add(BasicRaftNode.new(nodeId, peersIds, BasicRaftClusterRaftMessageSendCallbackCreate(result)))
|
2023-08-31 20:52:52 +00:00
|
|
|
|