2023-08-09 13:06:34 +03: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.
|
|
|
|
|
2023-08-14 23:49:21 +03:00
|
|
|
# #
|
|
|
|
# Raft Protocol definition #
|
|
|
|
# #
|
2023-08-09 13:06:34 +03:00
|
|
|
import types
|
|
|
|
|
|
|
|
type
|
|
|
|
# Raft Node Messages OPs
|
|
|
|
RaftMessageOps* = enum
|
|
|
|
rmoRequestVote = 0,
|
|
|
|
rmoAppendLogEntry = 1,
|
|
|
|
rmoInstallSnapshot = 2 # For dynamic adding of new Raft Nodes
|
|
|
|
|
2023-08-14 23:49:21 +03:00
|
|
|
RaftMessageRespoonseError* = enum # Raft message response errors
|
|
|
|
rmreSuccess = 0,
|
|
|
|
rmreFail = 1
|
2023-08-09 13:06:34 +03:00
|
|
|
|
2023-08-14 23:49:21 +03:00
|
|
|
RaftMessageResponseBase* = ref object of RootObj
|
|
|
|
msgId*: RaftMessageId # Original Message ID
|
|
|
|
senderId*: RaftNodeId # Sender Raft Node ID
|
|
|
|
respondentId: RaftNodeId # Responding RaftNodeId
|
|
|
|
senderTerm*: RaftNodeTerm # Sender Raft Node Term
|
2023-08-09 13:06:34 +03:00
|
|
|
|
2023-08-14 23:49:21 +03:00
|
|
|
RaftMessageRequestVote* = ref object of RaftMessageBase
|
|
|
|
lastLogTerm*: RaftNodeTerm
|
|
|
|
lastLogIndex*: RaftLogIndex
|
|
|
|
|
|
|
|
RaftMessageRequestVoteResponse* = ref object of RaftMessageResponseBase
|
|
|
|
granted*: bool
|
|
|
|
|
|
|
|
RaftMessageAppendEntries*[SmCommandType] = ref object of RaftMessageBase
|
|
|
|
prevLogIndex*: RaftLogIndex
|
|
|
|
prevLogTerm*: RaftNodeTerm
|
|
|
|
commitIndex*: RaftLogIndex
|
|
|
|
logEntries*: Option[seq[RaftNodeLogEntry[SmCommandType]]] # Optional log entry(ies). Will be empty for a Heart-Beat
|
|
|
|
|
|
|
|
RaftMessageAppendEntriesResponse*[SmStateType] = ref object of RaftMessageResponseBase
|
|
|
|
success*: bool
|
|
|
|
lastLogIndex*: RaftLogIndex
|
|
|
|
state*: Option[SmStateType] # Optional Raft Abstract State Machine State
|
2023-08-09 13:06:34 +03:00
|
|
|
|
|
|
|
# Raft Node Client Request/Response definitions
|
2023-08-14 23:49:21 +03:00
|
|
|
RaftNodeClientRequestOps* = enum
|
|
|
|
rncroRequestSmState = 0,
|
|
|
|
rncroExecSmCommand = 1
|
|
|
|
|
|
|
|
RaftNodeClientResponseError = enum
|
2023-08-22 04:04:47 +03:00
|
|
|
rncreSuccess = 0,
|
|
|
|
rncreFail = 1,
|
|
|
|
rncreNotLeader = 2
|
2023-08-09 13:06:34 +03:00
|
|
|
|
2023-08-14 23:49:21 +03:00
|
|
|
RaftNodeClientRequest*[SmCommandType] = ref object
|
2023-08-09 13:06:34 +03:00
|
|
|
op*: RaftNodeClientRequestOps
|
2023-08-14 23:49:21 +03:00
|
|
|
payload*: Option[SmCommandType] # Optional RaftMessagePayload carrying a Log Entry
|
2023-08-09 13:06:34 +03:00
|
|
|
|
|
|
|
RaftNodeClientResponse*[SmStateType] = ref object
|
2023-08-14 23:49:21 +03:00
|
|
|
error*: RaftNodeClientResponseError
|
2023-08-09 13:06:34 +03:00
|
|
|
state*: Option[SmStateType] # Optional Raft Abstract State Machine State
|
|
|
|
raftNodeRedirectId*: Option[RaftNodeId] # Optional Raft Node ID to redirect the request to in case of failure
|