Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var AllFlags = append(DealFlags, append(SingleTaskFlags, append(DaemonFlags, append(ControllerFlags, MockFlags...)...)...)...)
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
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.