Skip to content

threefold.grid #

TFGrid Deployments

Create workloads in native low level format, and then use a gridriver go binary to post it to TFChain as well as send it to ZOS.

fn get #

fn get(instance string, cfg Config) !TFGridClient[Config]

fn get_mnemonics #

fn get_mnemonics() !string

fn heroplay #

fn heroplay(mut plbook playbook.PlayBook) !

fn new_deployer #

fn new_deployer(mnemonics string, chain_network ChainNetwork) !Deployer

fn (DeploymentStateDB) set #

fn (db DeploymentStateDB) set(deployment_name string, key string, val string) !

fn (TFGridClient[Config]) config_interactive #

fn (mut self TFGridClient[Config]) config_interactive() !

fn (VMDeployed) builder_node #

fn (vm VMDeployed) builder_node() !&builder.Node

fn (ZDBDeployed) ping #

fn (zdb ZDBDeployed) ping() bool

test zdb is answering

fn (ZDBDeployed) redisclient #

fn (zdb ZDBDeployed) redisclient() !redisclient.Redis

enum ChainNetwork #

enum ChainNetwork {
	dev
	qa
	test
	main
}

struct Config #

@[params]
struct Config {
pub mut:
	mnemonics string @[secret]
	network   string
}

struct Contract #

struct Contract {
pub:
	contract_id     string @[json: contractID]
	deployment_data string @[json: deploymentData]
	state           string
	node_id         u32 @[json: nodeID]
	name            string
}

struct Contracts #

struct Contracts {
pub mut:
	name_contracts []Contract @[json: nameContracts]
	node_contracts []Contract @[json: nodeContracts]
	rent_contracts []Contract @[json: rentContracts]
}

struct Deployer #

@[heap]
struct Deployer {
pub:
	mnemonics     string
	substrate_url string
	twin_id       u32
	relay_url     string
	chain_network ChainNetwork
	env           string
pub mut:
	client griddriver.Client
	logger log.Log
}

fn (Deployer) assign_wg_port #

fn (mut d Deployer) assign_wg_port(node_id u32) !u16

fn (Deployer) batch_deploy #

fn (mut d Deployer) batch_deploy(name_contracts []string, mut dls map[u32]&models.Deployment, solution_provider ?u64) !(map[string]u64, map[u32]&models.Deployment)

fn (Deployer) delete_deployment #

fn (mut d Deployer) delete_deployment(contract_id u64, node_id u32) !models.Deployment

fn (Deployer) deploy #

fn (mut d Deployer) deploy(node_id u32, mut dl models.Deployment, body string, solution_provider u64) !u64

fn (Deployer) deployment_changes #

fn (mut d Deployer) deployment_changes(node_id u32, contract_id u64) ![]models.Workload

fn (Deployer) get_deployment #

fn (mut d Deployer) get_deployment(contract_id u64, node_id u32) !models.Deployment

fn (Deployer) get_node_pub_config #

fn (mut d Deployer) get_node_pub_config(node_id u32) !models.PublicConfig

fn (Deployer) rmb_deployment_changes #

fn (mut d Deployer) rmb_deployment_changes(dst u32, contract_id u64) !string

Todo: decode/encode the params/result here

fn (Deployer) rmb_deployment_delete #

fn (mut d Deployer) rmb_deployment_delete(dst u32, data string) !string

fn (Deployer) rmb_deployment_deploy #

fn (mut d Deployer) rmb_deployment_deploy(dst u32, data string) !string

fn (Deployer) rmb_deployment_get #

fn (mut d Deployer) rmb_deployment_get(dst u32, data string) !string

fn (Deployer) rmb_deployment_update #

fn (mut d Deployer) rmb_deployment_update(dst u32, data string) !string

fn (Deployer) update_deployment #

fn (mut d Deployer) update_deployment(node_id u32, mut dl models.Deployment, body string) !

fn (Deployer) wait_deployment #

fn (mut d Deployer) wait_deployment(node_id u32, mut dl models.Deployment, workload_versions map[string]u32) !

struct GraphQl #

struct GraphQl {
	url string
pub mut:
	logger log.Log
}

fn (GraphQl) list_twin_contracts #

fn (mut g GraphQl) list_twin_contracts(twin_id u32, states []string) !Contracts

contractsList, err := c.ListContractsByTwinID([]string{"Created, GracePeriod"})

fn (GraphQl) get_contract_by_project_name #

fn (mut g GraphQl) get_contract_by_project_name(mut deployer Deployer, project_name string) !Contracts

struct TFGridClient #

struct TFGridClient[T] {
	base.BaseConfig[T]
}