2022-05-12 11:42:18 +00:00
|
|
|
import std/osproc
|
|
|
|
import std/os
|
|
|
|
import std/streams
|
|
|
|
import std/strutils
|
2023-06-22 10:32:18 +00:00
|
|
|
import pkg/ethers
|
|
|
|
import ./codexclient
|
2022-05-12 11:42:18 +00:00
|
|
|
|
|
|
|
const workingDir = currentSourcePath() / ".." / ".." / ".."
|
2022-05-19 19:56:03 +00:00
|
|
|
const executable = "build" / "codex"
|
2022-05-12 11:42:18 +00:00
|
|
|
|
2023-06-22 10:32:18 +00:00
|
|
|
type
|
|
|
|
NodeProcess* = ref object
|
|
|
|
process: Process
|
|
|
|
arguments: seq[string]
|
|
|
|
debug: bool
|
2023-08-01 23:47:57 +00:00
|
|
|
Role* {.pure.} = enum
|
2023-06-22 10:32:18 +00:00
|
|
|
Client,
|
|
|
|
Provider,
|
|
|
|
Validator
|
|
|
|
RunningNode* = ref object
|
|
|
|
role*: Role
|
|
|
|
node*: NodeProcess
|
|
|
|
restClient*: CodexClient
|
|
|
|
datadir*: string
|
|
|
|
ethAccount*: Address
|
|
|
|
StartNodes* = object
|
|
|
|
clients*: uint
|
|
|
|
providers*: uint
|
|
|
|
validators*: uint
|
|
|
|
DebugNodes* = object
|
|
|
|
client*: bool
|
|
|
|
provider*: bool
|
|
|
|
validator*: bool
|
|
|
|
topics*: string
|
|
|
|
|
|
|
|
proc new*(_: type RunningNode,
|
|
|
|
role: Role,
|
|
|
|
node: NodeProcess,
|
|
|
|
restClient: CodexClient,
|
|
|
|
datadir: string,
|
|
|
|
ethAccount: Address): RunningNode =
|
|
|
|
RunningNode(role: role,
|
|
|
|
node: node,
|
|
|
|
restClient: restClient,
|
|
|
|
datadir: datadir,
|
|
|
|
ethAccount: ethAccount)
|
|
|
|
|
|
|
|
proc init*(_: type StartNodes,
|
|
|
|
clients, providers, validators: uint): StartNodes =
|
|
|
|
StartNodes(clients: clients, providers: providers, validators: validators)
|
|
|
|
|
|
|
|
proc init*(_: type DebugNodes,
|
|
|
|
client, provider, validator: bool,
|
|
|
|
topics: string = "validator,proving,market"): DebugNodes =
|
|
|
|
DebugNodes(client: client, provider: provider, validator: validator,
|
|
|
|
topics: topics)
|
2022-11-08 07:10:17 +00:00
|
|
|
|
|
|
|
proc start(node: NodeProcess) =
|
|
|
|
if node.debug:
|
2023-08-01 23:47:57 +00:00
|
|
|
node.process = osproc.startProcess(
|
2022-11-08 07:10:17 +00:00
|
|
|
executable,
|
|
|
|
workingDir,
|
|
|
|
node.arguments,
|
|
|
|
options={poParentStreams}
|
|
|
|
)
|
2022-05-12 11:42:18 +00:00
|
|
|
sleep(1000)
|
|
|
|
else:
|
2023-08-01 23:47:57 +00:00
|
|
|
node.process = osproc.startProcess(
|
2022-11-08 07:10:17 +00:00
|
|
|
executable,
|
|
|
|
workingDir,
|
|
|
|
node.arguments
|
|
|
|
)
|
|
|
|
for line in node.process.outputStream.lines:
|
2022-05-19 19:56:03 +00:00
|
|
|
if line.contains("Started codex node"):
|
2022-05-12 11:42:18 +00:00
|
|
|
break
|
|
|
|
|
2023-05-15 07:02:57 +00:00
|
|
|
proc startNode*(args: openArray[string], debug: string | bool = false): NodeProcess =
|
2022-11-08 07:10:17 +00:00
|
|
|
## Starts a Codex Node with the specified arguments.
|
|
|
|
## Set debug to 'true' to see output of the node.
|
2023-05-15 07:02:57 +00:00
|
|
|
let node = NodeProcess(arguments: @args, debug: ($debug != "false"))
|
2022-11-08 07:10:17 +00:00
|
|
|
node.start()
|
|
|
|
node
|
|
|
|
|
|
|
|
proc stop*(node: NodeProcess) =
|
2023-04-19 13:06:00 +00:00
|
|
|
if node.process != nil:
|
|
|
|
node.process.terminate()
|
|
|
|
discard node.process.waitForExit(timeout=5_000)
|
|
|
|
node.process.close()
|
|
|
|
node.process = nil
|
2022-11-08 07:10:17 +00:00
|
|
|
|
|
|
|
proc restart*(node: NodeProcess) =
|
|
|
|
node.stop()
|
|
|
|
node.start()
|