commands

package
v0.0.36 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 1, 2021 License: Apache-2.0, MIT Imports: 19 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var CommonFlags []cli.Flag = []cli.Flag{
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "wallet",
		Usage:   "deal client wallet address on node",
		Aliases: []string{"w"},
		EnvVars: []string{"DEALBOT_WALLET_ADDRESS"},
	}),
}
View Source
var ControllerCmd = &cli.Command{
	Name:   "controller",
	Usage:  "Start the dealbot controller",
	Flags:  ControllerFlags,
	Action: controllerCommand,
}
View Source
var ControllerFlags = []cli.Flag{
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "listen",
		Usage:   "host:port to bind http server on",
		Aliases: []string{"l"},
		EnvVars: []string{"DEALBOT_LISTEN"},
		Value:   "127.0.0.1:33258",
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "graphql",
		Usage:   "host:port to bind graphql server on",
		EnvVars: []string{"DEALBOT_GRAPHQL_LISTEN"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "metrics",
		Usage:   "value of 'prometheus' or 'log'",
		Aliases: []string{"m"},
		EnvVars: []string{"DEALBOT_METRICS"},
	}),
	altsrc.NewPathFlag(&cli.PathFlag{
		Name:    "identity",
		Usage:   "location of node identity for authenticating results",
		Aliases: []string{"i"},
		EnvVars: []string{"DEALBOT_IDENTITY_KEYPAIR"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "driver",
		Usage:   "type of database backend to use",
		EnvVars: []string{"DEALBOT_PERSISTENCE_DRIVER"},
		Value:   "postgres",
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "dbloc",
		Usage:   "connection string for sql DB",
		EnvVars: []string{"DEALBOT_PERSISTENCE_CONN"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "gqlAccessToken",
		Usage:   "set an access secret for access to inprogress data over gql",
		EnvVars: []string{"DEALBOT_GRAPHQL_ACCESS_TOKEN"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "daemon-driver",
		Usage:   "system to use when starting daemons",
		EnvVars: []string{"DEALBOT_DAEMON_DRIVER"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:  "devAssetDir",
		Usage: "build frontend assets from directory instead of embedded version (set to location of 'controller'; the directory containing static and app)",
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "basicauth",
		Usage:   "the basic auth credentials needed to access the controller if in place",
		EnvVars: []string{"DEALBOT_BASICAUTH"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "datapointlog",
		Usage:   "file / stream to write out a json line for each task as it updates",
		EnvVars: []string{"DEALBOT_DATAPOINT_LOG"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "gateway-api",
		Usage:   "address for a lotus gateway to collect chain information",
		EnvVars: []string{"DEALBOT_LOTUS_GATEWAY"},
	}),
}
View Source
var DaemonCmd = &cli.Command{
	Name:   "daemon",
	Usage:  "Start a dealbot daemon, accepting tasks over RPC",
	Flags:  DaemonFlags,
	Action: daemonCommand,
}
View Source
var DaemonFlags = append(DealFlags, append(CommonFlags, append(EndpointFlags, []cli.Flag{
	idFlag,
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "listen",
		Usage:   "host:port to bind http server on",
		Aliases: []string{"l"},
		EnvVars: []string{"DEALBOT_LISTEN"},
	}),
	altsrc.NewStringSliceFlag(&cli.StringSliceFlag{
		Name:    "stage-timeout",
		Usage:   "stagename=duration (example: DealAccepted=15m), DefaultRetrieval and DefaultStorage set defaults",
		EnvVars: []string{"STAGE_TIMEOUT"},
	}),
	altsrc.NewStringSliceFlag(&cli.StringSliceFlag{
		Name:    "tags",
		Usage:   "comma separated tag strings",
		EnvVars: []string{"DEALBOT_TAGS"},
	}),
	altsrc.NewIntFlag(&cli.IntFlag{
		Name:    "workers",
		Usage:   "number of concurrent task workers",
		EnvVars: []string{"DEALBOT_WORKERS"},
		Value:   1,
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "minfil",
		Usage:   "min amount of fil needed (in attofil) in wallet for tasks to be popped by daemon",
		EnvVars: []string{"DEALBOT_MIN_FIL"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "mincap",
		Usage:   "min amount of datacap needed (in bytes) in wallet for tasks to be popped by daemon",
		EnvVars: []string{"DEALBOT_MIN_CAP"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "posthook",
		Usage:   "bash script to run when a deal finishes",
		EnvVars: []string{"DEALBOT_POST_HOOK"},
	}),
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:    "datapointlog",
		Usage:   "file / stream to write out a json line for each task as it updates",
		EnvVars: []string{"DEALBOT_DATAPOINT_LOG"},
	}),
}...)...)...)
View Source
var DealFlags = []cli.Flag{
	altsrc.NewPathFlag(&cli.PathFlag{
		Name:     "data-dir",
		Usage:    "writable directory used to transfer data to node",
		Aliases:  []string{"d"},
		EnvVars:  []string{"DEALBOT_DATA_DIRECTORY"},
		Required: true,
	}),
	altsrc.NewPathFlag(&cli.PathFlag{
		Name:    "node-data-dir",
		Usage:   "data-dir from relative to node's location [data-dir]",
		Aliases: []string{"n"},
		EnvVars: []string{"DEALBOT_NODE_DATA_DIRECTORY"},
	}),
}
View Source
var DrainCmd = &cli.Command{
	Name:   "drain",
	Usage:  "Stop a dealbot daemon",
	Flags:  append(EndpointFlags, idFlag),
	Action: drainCommand,
}
View Source
var EndpointFlags = []cli.Flag{
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:     "endpoint",
		Usage:    "HTTP endpoint of the controller",
		Aliases:  []string{"e"},
		EnvVars:  []string{"DEALBOT_CONTROLLER_ENDPOINT"},
		Required: true,
	}),
}
View Source
var MakeRetrievalDealCmd = &cli.Command{
	Name:   "retrieval-deal",
	Usage:  "Make retrieval deals with provided miners.",
	Flags:  append(SingleTaskFlags, RetrievalFlags...),
	Action: makeRetrievalDeal,
}
View Source
var MakeStorageDealCmd = &cli.Command{
	Name:   "storage-deal",
	Usage:  "Make storage deals with provided miners.",
	Flags:  append(SingleTaskFlags, StorageFlags...),
	Action: makeStorageDeal,
}
View Source
var MinerFlags = []cli.Flag{
	altsrc.NewStringFlag(&cli.StringFlag{
		Name:     "miner",
		Usage:    "address of miner to make deal with",
		Aliases:  []string{"m"},
		EnvVars:  []string{"DEALBOT_MINER_ADDRESS"},
		Required: true,
	}),
}
View Source
var MockCmd = &cli.Command{
	Name:   "mock",
	Usage:  "Start a mock dealbot daemon, simulating tasks over RPC",
	Flags:  append(EndpointFlags, MockFlags...),
	Action: mockCommand,
}
View Source
var MockFlags = []cli.Flag{
	altsrc.NewFloat64Flag(&cli.Float64Flag{
		Name:    "success_rate",
		Usage:   "rate of deal successes (1.0 = full success, 0 = full failure)",
		Aliases: []string{"r"},
		EnvVars: []string{"MOCK_DEALBOT_SUCCESS_RATE"},
		Value:   0.5,
	}),
	altsrc.NewDurationFlag(&cli.DurationFlag{
		Name:    "success_avg",
		Usage:   "avergage time for a successful deal",
		Aliases: []string{"S"},
		EnvVars: []string{"MOCK_DEALBOT_SUCCESS_AVG"},
		Value:   1 * time.Minute,
	}),
	altsrc.NewDurationFlag(&cli.DurationFlag{
		Name:    "success_deviation",
		Usage:   "std deviation from average for successful deals",
		Aliases: []string{"s"},
		EnvVars: []string{"MOCK_DEALBOT_SUCCESS_DEVIATION"},
		Value:   1 * time.Second,
	}),
	altsrc.NewDurationFlag(&cli.DurationFlag{
		Name:    "failure_avg",
		Usage:   "avergage time for a failed deal",
		Aliases: []string{"F"},
		EnvVars: []string{"MOCK_DEALBOT_FAILURE_AVG"},
		Value:   2 * time.Minute,
	}),
	altsrc.NewDurationFlag(&cli.DurationFlag{
		Name:    "failure_deviation",
		Usage:   "std deviation from average for failed deals",
		Aliases: []string{"f"},
		EnvVars: []string{"MOCK_DEALBOT_FAILURE_AVG"},
		Value:   20 * time.Second,
	}),
	altsrc.NewIntFlag(&cli.IntFlag{
		Name:    "workers",
		Usage:   "number of simultaneous workers",
		Aliases: []string{"w"},
		EnvVars: []string{"MOCK_DEALBOT_WORKERS"},
		Value:   1,
	}),
}
View Source
var MockTaskFlags = []cli.Flag{
	altsrc.NewIntFlag(&cli.IntFlag{
		Name:    "count",
		Usage:   "number of mock tasks to generate",
		Aliases: []string{"c"},
		EnvVars: []string{"MOCK_DEALBOT_TASK_COUNT"},
		Value:   100,
	}),
	altsrc.NewIntFlag(&cli.IntFlag{
		Name:    "retrievals",
		Usage:   "number of mock tasks to should be retrievals",
		Aliases: []string{"r"},
		EnvVars: []string{"MOCK_DEALBOT_RETRIEVAL_COUNT"},
		Value:   0,
	}),
}
View Source
var MockTasksCmd = &cli.Command{
	Name:   "mock_tasks",
	Usage:  "Generate tasks to run on the mock dealbot",
	Flags:  append(EndpointFlags, MockTaskFlags...),
	Action: mockTasksCommand,
}

MockTasksCmd generates a series of mock tasks and adds them to the controller

View Source
var QueueRetrievalCmd = &cli.Command{
	Name:   "queue-retrieval",
	Usage:  "Queue retrieval deal in the controller",
	Flags:  append(EndpointFlags, RetrievalFlags...),
	Action: queueRetrievalDeal,
}

QueueRetrievalCmd queues a retrieval with the controller (as opposed to executing directly with lotus)

View Source
var QueueStorageCmd = &cli.Command{
	Name:   "queue-storage",
	Usage:  "Queue storage deal in the controller",
	Flags:  append(append(EndpointFlags, MinerFlags...), StorageFlags...),
	Action: queueStorageDeal,
}

QueueStorageCmd queues a storage deal with the controller (as opposed to executing directly with lotus)

View Source
var RetrievalFlags = []cli.Flag{
	&cli.StringFlag{
		Name:  "cid",
		Usage: "payload cid to fetch from miner",
		Value: "bafykbzacedikkmeotawrxqquthryw3cijaonobygdp7fb5bujhuos6wdkwomm",
	},
	altsrc.NewStringSliceFlag(&cli.StringSliceFlag{
		Name:    "stage-timeout",
		Usage:   "stagename=duration (example: DealAccepted=15m), DefaultRetrieval sets default",
		EnvVars: []string{"STAGE_TIMEOUT"},
	}),
}
View Source
var SingleTaskFlags = append(DealFlags, MinerFlags...)
View Source
var StorageFlags = []cli.Flag{
	&cli.BoolFlag{
		Name:    "fast-retrieval",
		Usage:   "request fast retrieval [true]",
		Aliases: []string{"f"},
		EnvVars: []string{"DEALBOT_FAST_RETRIEVAL"},
		Value:   true,
	},
	&cli.BoolFlag{
		Name:    "verified-deal",
		Usage:   "true if deal is verified [false]",
		Aliases: []string{"v"},
		EnvVars: []string{"DEALBOT_VERIFIED_DEAL"},
		Value:   false,
	},
	&cli.StringFlag{
		Name:    "size",
		Usage:   "size of deal (1KB, 2MB, 12GB, etc.) [1MB]",
		Aliases: []string{"s"},
		EnvVars: []string{"DEALBOT_DEAL_SIZE"},
		Value:   "1KB",
	},
	&cli.Int64Flag{
		Name:    "max-price",
		Usage:   "maximum Attofil to pay per byte per epoch []",
		EnvVars: []string{"DEALBOT_MAX_PRICE"},
		Value:   5e16,
	},
	&cli.Int64Flag{
		Name:    "start-offset",
		Usage:   "epochs deal start will be offset from now [30760 (10 days)]",
		EnvVars: []string{"DEALBOT_START_OFFSET"},
		Value:   30760,
	},
	altsrc.NewStringSliceFlag(&cli.StringSliceFlag{
		Name:    "stage-timeout",
		Usage:   "stagename=duration (example: ProposeDeal=15m), DefaultStorage sets default",
		EnvVars: []string{"STAGE_TIMEOUT"},
	}),
}

Functions

func ProcessContext added in v0.0.3

func ProcessContext() context.Context

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL