-
Notifications
You must be signed in to change notification settings - Fork 29
REST API
Get the current registered servers
{
"server_name":{
"addr":(string),
"iaddr":{
"ip":(string),
"gateway":(string),
"subnet":(int)
},
"nodes":(int),
"max":(int),
"id":(int),
"serverID":(int),
"iface":(string),
"switches":[
{
"addr":(string),
"iface":(string),
"brand":(int),
"id":(int)
}
]
},
"server2_name":{...}...
}
curl -XGET http://localhost:8000/servers/
Register and add a new server to be controlled by the instance
{
"addr":(string),
"nodes":(int),
"max":(int),
"id":-1,
"subnetID":(int)
}
<server id>
curl -X PUT http://localhost:8000/servers/foxtrot -d \
'{"addr":"172.16.6.5","nodes":0,"max":10,"subnetID":6,"id":-1}'
Get a server by id
{
"addr":(string),
"nodes":(int),
"max":(int),
"id":(int),
"subnetID":(int)
}
curl -X GET http://localhost:8000/servers/5
Remove a server
Success
curl -X DELETE http://localhost:8000/servers/5
Update server information
{
"addr":(string),
"nodes":(int),
"max":(int),
"id":(int),
"subnetID":(int)
}
Success
curl -X UPDATE http://localhost:8000/servers/5 -d \
'{"addr":"172.16.4.5","nodes":0,"max":30,"id":5,"subnetID":4}'
Add and deploy a new testnet
Will return immediately with success, unless there is a JSON parsing error or there is already a build in progress. See GET /status/build/{id}
for how to get the current build progress and to check for build errors.
<json object representing the build, see example and details after it>
Success
curl -X POST http://localhost:8000/testnets/ -d '{
"servers":[1],
"blockchain":"ethereum",
"nodes":3,
"images":["ethereum:latest"],
"resources":[{
"cpus":"2.5",
"memory":"12gb"
}],
"params":{
"networkId":15468,
"difficulty":100000,
"initBalance":"100000000000000000000",
"maxPeers":1000,
"gasLimit":4000000,
"homesteadBlock":0,
"eip155Block":10,
"eip158Block":10
},
"environments":[
{
"NODE":"0"
},
{
"NODE":"1"
}
],
"files":[
{
"config.toml":"TG9yZW0gabnNlY3RldHVyIGFkaXBpc2NpbmcgZdyxX=="
},
{
"config.toml":"UHJvaW4gZmluaWJ1cyBsYW9yZWV0IHRpbmNpZHVudA=="
}
],
"logs":[],
"extras":{
"defaults":{
"files":{
"config.toml":"IEludGVnZXIgYXVjdG9yIHVybmEgbGFvcmVldCBjb252YWxsaXMgdmVzdGlidWx1bS4="
}
},
"postbuild":{
"ssh":{
"pubKeys":[]
}
},
"prebuild":{
"auth":{
"username":"bill",
"password":"big_strong_bill"
},
"build":false,
"dockerfile":null,
"freezeAfterInfrastructure":false,
"pull":false
}
}
}'
- servers : The servers on which to build
- blockchain: The blockchain to build out
- nodes: The total number of nodes to build
- images: The docker images to use in building the nodes, the first image in the list will be used as the default.
- resources: The first resource object is the default.
- cpus: The max number of cpus which can be used by the node.
- memory: The maximum amount of RAM that a node can use.
- params: Blockchain specific parameters to supplement the build
- environments: The environmental variables for the nodes.
- files: The file templates to replace the internal files, key is the file name, value is the file data base64 encoded.
- logs: The log files for each node.
- extras: Extra build information which doesn't fit into any category. Most trivial expansions are done here
- defaults: Contains the default values for certain fields. Used for cases where you might want to differentiate between all nodes and just the first node.
- postbuild: Contains details for after infrastructure deployment functionality
- ssh: Information on addition ssh credentials to allow access to the nodes.
- prebuild:
- auth: Docker login authorization credentials (if needed)
- build: Whether or not it should build from a dockerfile
- dockerfile: The dockerfile encoded in base64, which will be built if build is true
- freezeAfterInfrastructure: Freeze after the context switch from building infrastructure to blockchain genesis ceremony
- pull: Force an update of all of the used images.
Tears down a testnet
Success
curl -X DELETE http://localhost:8000/testnets/2
Get the nodes in a testnet
[
{
"id":(string),
"testNetId":(int),
"server":(int),
"localId":(int),
"ip":(string)
},...
]
curl -X GET http://localhost:8000/testnets/2/nodes/
Get the nodes that are running in the given testnet
[
{
"ip": "10.1.0.2",
"name": "whiteblock-node0",
"resourceUse": {
"cpu": 1.5,
"residentSetSize": 629700,
"virtualMemorySize": 40105576
},
"server": 1,
"up": true
}
]
curl -XGET http://localhost:8000/status/nodes/
Get the build params for a blockchain
[
["chainId","int"]
["homesteadBlock","int"],
["eip155Block","int"],
["eip158Block","int"]
]
curl -X GET http://localhost:8000/params/ethereum
Get the default parameters for a blockchain
{
"chainId":15468,
"networkId":15468,
"difficulty":100000,
"initBalance":100000000000000000000,
"maxPeers":1000,
"gasLimit":4000000,
"homesteadBlock":0,
"eip155Block":0,
"eip158Block":0
}
curl -X GET http://localhost:8000/defaults/ethereum
Get both stdout and stderr from the blockchain process
<The contents>
curl -X POST http://localhost:8000/log/4/0
Get the nodes for the latest testnet
[
{
"id": 1647,
"testnetId": 134,
"server": 3,
"localId": 0,
"ip": "10.6.0.2",
"label": "",
"absNum":4,
"image":"geth:latest",
"blockchain":"geth"
}
]
curl -X GET http://localhost:8000/nodes
Stop the given build
Stop signal has been sent...
curl -X DELETE http://localhost:8000/build
Appends nodes to the given testnet otherwise, acts like POST /testnet/
, main difference is the response is not
the testnet id
Success
curl -X POST http://localhost:8000/nodes/9e09efe8_d7a3_4429_832c_447d876194c8
Delete {num} nodes from the testnet
Success
curl -X DELETE http://localhost:8000/nodes/9e09efe8_d7a3_4429_832c_447d876194c8/5
Turn off emulate for a whole testnet
Success
curl -X DELETE http://localhost:8000/emulate/9e09efe8_d7a3_4429_832c_447d876194c8
Set emulation for a node or nodes
[{"node":1,"limit":1000,"loss":0,"delay":5000,"rate":"","duplicate":0,"corrupt":0,"reorder":0},
{"node":2,"limit":1000,"loss":0,"delay":5000,"rate":"","duplicate":0,"corrupt":0,"reorder":0},
{"node":0,"limit":1000,"loss":0,"delay":5000,"rate":"","duplicate":0,"corrupt":0,"reorder":0}]
Success
curl -X POST http://localhost:8000/emulate/9e09efe8_d7a3_4429_832c_447d876194c8
Set emulation for a whole testnet
{"limit":1000,"loss":0,"delay":5000,"rate":"","duplicate":0,"corrupt":0,"reorder":0}
Success
curl -X POST http://localhost:8000/emulate/all/9e09efe8_d7a3_4429_832c_447d876194c8
Get the static file resources used by genesis for the given blockchain
[
"defaults.json",
"genesis.json",
"params.json"
]
curl -X POST http://localhost:8000/resources/geth
Gets the contents of that file resource for the given blockchain
curl -X GET http://localhost:8000/resources/geth/genesis.json
Gets the details of the latest build
{
"servers": [],
"blockchain": "",
"nodes": 0,
"images": [],
"params": [],
"resources": [],
"environments": [],
"files": [],
"logs": [],
"extras": []
}
curl -X GET http://localhost:8000/build
Gets the details of the given build
{
"servers": [],
"blockchain": "",
"nodes": 0,
"images": [],
"params": [],
"resources": [],
"environments": [],
"files": [],
"logs": [],
"extras": []
}
curl -X GET http://localhost:8000/build/5
Pause the given build
Build has been frozen
curl -X POST http://localhost:8000/build/freeze/5
Unpause the given build
Build has been resumed
curl -X POST http://localhost:8000/build/thaw/5
Unpause the given build
Build has been resumed
curl -X DELETE http://localhost:8000/build/freeze/5
Get the current network conditions for the testnet
[
{
"node": 0,
"limit": 0,
"loss": 0.0,
"delay": 0,
"rate": "",
"duplicate": 0.0,
"corrupt": 0.0,
"reorder": 0.0
}
]
curl -X GET http://localhost:8000/emulate/5
Restart a node on a testnet
Success
curl -X POST http://localhost:8000/nodes/restart/8c80891a-2046-4e4a-a3ca-652a38cb8093/5
Send a signal to the main process of the given node
Sent signal SIGINT to node 1
curl -X POST http://localhost:8000/nodes/raise/8c80891a-2046-4e4a-a3ca-652a38cb8093/1/SIGINT
Attempt to kill the given node
Killed node 1
curl -X POST http://localhost:8000/nodes/kill/8c80891a-2046-4e4a-a3ca-652a38cb8093/1
Prevent the given node1 and node2 from establishing a connection with each other
Success
curl -X POST http://localhost:8000/outage/8c80891a-2046-4e4a-a3ca-652a38cb8093/1/2
Allow the given node1 and node2 to establish a connection with each other
Success
curl -X DELETE http://localhost:8000/outage/8c80891a-2046-4e4a-a3ca-652a38cb8093/1/2
Remove all blocked connections from a testnet
Success
curl -X DELETE http://localhost:8000/outage/8c80891a-2046-4e4a-a3ca-652a38cb8093
Get the currently blocked connections
[
{
"to": 0,
"from": 0
}
]
curl -X GET http://localhost:8000/outage/8c80891a-2046-4e4a-a3ca-652a38cb8093
Get the blocked connections for the given node
[
{
"to": 0,
"from": 0
}
]
curl -X GET http://localhost:8000/outage/8c80891a-2046-4e4a-a3ca-652a38cb8093/1
Create a network partition on a testnet
success
curl -X POST http://localhost:8000/partition/8c80891a-2046-4e4a-a3ca-652a38cb8093
Get the partitions on the testnet
[
[1, 2, 3],
[4, 5, 6]
]
curl -X GET http://localhost:8000/partition/8c80891a-2046-4e4a-a3ca-652a38cb8093
Get the currently supported blockchains by genesis
[
"EOS", "Geth", "RChain"
]
curl -X GET http://localhost:8000/blockchains