fix: worker: add all task type flag
Add all flag for the `lotus-worker tasks enable/disable` cmd
This commit is contained in:
parent
8066833b3a
commit
cf0997b434
@ -45,6 +45,12 @@ var tasksEnableCmd = &cli.Command{
|
||||
Name: "enable",
|
||||
Usage: "Enable a task type",
|
||||
ArgsUsage: "[" + settableStr + "]",
|
||||
Flags: []cli.Flag{
|
||||
&cli.BoolFlag{
|
||||
Name: "all",
|
||||
Usage: "Enable all task types",
|
||||
},
|
||||
},
|
||||
Action: taskAction(api.Worker.TaskEnable),
|
||||
}
|
||||
|
||||
@ -52,16 +58,29 @@ var tasksDisableCmd = &cli.Command{
|
||||
Name: "disable",
|
||||
Usage: "Disable a task type",
|
||||
ArgsUsage: "[" + settableStr + "]",
|
||||
Flags: []cli.Flag{
|
||||
&cli.BoolFlag{
|
||||
Name: "all",
|
||||
Usage: "Disable all task types",
|
||||
},
|
||||
},
|
||||
Action: taskAction(api.Worker.TaskDisable),
|
||||
}
|
||||
|
||||
func taskAction(tf func(a api.Worker, ctx context.Context, tt sealtasks.TaskType) error) func(cctx *cli.Context) error {
|
||||
return func(cctx *cli.Context) error {
|
||||
if cctx.NArg() != 1 {
|
||||
return xerrors.Errorf("expected 1 argument")
|
||||
allFlag := cctx.Bool("all")
|
||||
|
||||
if cctx.NArg() == 1 && allFlag {
|
||||
return xerrors.Errorf("Cannot use --all flag with task type argument")
|
||||
}
|
||||
|
||||
if cctx.NArg() == 0 && !allFlag {
|
||||
return xerrors.Errorf("Expected 1 argument or use --all flag")
|
||||
}
|
||||
|
||||
var tt sealtasks.TaskType
|
||||
if cctx.NArg() == 1 {
|
||||
for taskType := range allowSetting {
|
||||
if taskType.Short() == cctx.Args().First() {
|
||||
tt = taskType
|
||||
@ -72,6 +91,7 @@ func taskAction(tf func(a api.Worker, ctx context.Context, tt sealtasks.TaskType
|
||||
if tt == "" {
|
||||
return xerrors.Errorf("unknown task type '%s'", cctx.Args().First())
|
||||
}
|
||||
}
|
||||
|
||||
api, closer, err := lcli.GetWorkerAPI(cctx)
|
||||
if err != nil {
|
||||
@ -81,6 +101,15 @@ func taskAction(tf func(a api.Worker, ctx context.Context, tt sealtasks.TaskType
|
||||
|
||||
ctx := lcli.ReqContext(cctx)
|
||||
|
||||
if allFlag {
|
||||
for taskType := range allowSetting {
|
||||
if err := tf(api, ctx, taskType); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
return tf(api, ctx, tt)
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user