2023-09-08 18:45:37 +03:00
|
|
|
import basic_state_machine
|
2023-09-11 19:55:30 +03:00
|
|
|
import basic_cluster
|
|
|
|
|
2023-09-08 20:03:05 +03:00
|
|
|
import std/json
|
2023-09-09 19:56:54 +03:00
|
|
|
import msgpack4nim
|
2023-09-11 19:55:30 +03:00
|
|
|
import strutils
|
|
|
|
import std/strformat
|
|
|
|
import httpclient
|
2023-09-08 18:45:37 +03:00
|
|
|
|
2023-09-08 20:03:05 +03:00
|
|
|
type
|
2023-09-11 19:55:30 +03:00
|
|
|
RaftPeerConf* = object
|
|
|
|
id*: UUID
|
|
|
|
host*: string
|
|
|
|
port*: int
|
2023-09-08 20:03:05 +03:00
|
|
|
|
2023-09-11 19:55:30 +03:00
|
|
|
RaftPeersConfContainer* = seq[RaftPeerConf]
|
2023-09-08 20:03:05 +03:00
|
|
|
|
|
|
|
var
|
|
|
|
conf: RaftPeersConfContainer
|
|
|
|
|
|
|
|
proc loadConfig() =
|
|
|
|
let jsonFile = "raft_node_config.json"
|
|
|
|
# read and parse file
|
|
|
|
let jsConf = parseFile(jsonFile)
|
|
|
|
for n in jsConf["raftPeers"]:
|
2023-09-11 19:55:30 +03:00
|
|
|
conf.add(RaftPeerConf(id: parseUUID(n["id"].astToStr), host: n["host"].astToStr, port: parseInt(n["port"].astToStr)))
|
|
|
|
debug "Conf", conf=conf
|
2023-09-08 20:03:05 +03:00
|
|
|
info "Conf", config=repr(conf)
|
2023-09-08 18:45:37 +03:00
|
|
|
|
2023-09-11 19:55:30 +03:00
|
|
|
proc TestRaftMessageSendCallbackCreate(): RaftMessageSendCallback =
|
|
|
|
proc (msg: RaftMessageBase): Future[RaftMessageResponseBase] {.async, gcsafe.} =
|
|
|
|
var
|
|
|
|
host: string
|
|
|
|
port: int
|
|
|
|
for c in conf:
|
|
|
|
if c.id == msg.receiverId:
|
|
|
|
host = c.host
|
|
|
|
port = c.port
|
|
|
|
var
|
|
|
|
client = newAsyncHttpClient()
|
|
|
|
s = MsgStream.init() # besides MsgStream, you can also use Nim StringStream or FileStream
|
|
|
|
|
|
|
|
s.pack(msg) #here the magic happened
|
|
|
|
|
|
|
|
var
|
|
|
|
resp = await client.post(fmt"http://host:port", s.data)
|
|
|
|
|
|
|
|
echo resp.status
|
|
|
|
var
|
|
|
|
ss = MsgStream.init(resp.body)
|
|
|
|
xx: RaftMessageResponseBase
|
|
|
|
ss.unpack(xx) #and here too
|
|
|
|
result = xx
|
|
|
|
|
2023-09-08 18:45:37 +03:00
|
|
|
if isMainModule:
|
2023-09-09 19:56:54 +03:00
|
|
|
loadConfig()
|
2023-09-11 19:55:30 +03:00
|
|
|
var
|
|
|
|
nodesIds: seq[UUID]
|
|
|
|
node: BasicRaftNode
|
|
|
|
|
|
|
|
for c in conf:
|
|
|
|
debug "single conf", single_conf=c
|
|
|
|
nodesIds.add(c.id)
|
|
|
|
|
|
|
|
var
|
|
|
|
nodeId = parseUUID("f9695ea4-4f37-11ee-8e75-8ff5a48faa42")
|
|
|
|
peersIds = nodesIds
|
|
|
|
|
|
|
|
peersIds.del(peersIds.find(nodeId))
|
|
|
|
|
|
|
|
node = BasicRaftNode.new(nodeId, peersIds, TestRaftMessageSendCallbackCreate())
|