/
cmd_simplefs_force_conflict.go
70 lines (60 loc) · 1.78 KB
/
cmd_simplefs_force_conflict.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// Copyright 2019 Keybase, Inc. All rights reserved. Use of
// this source code is governed by the included BSD license.
package client
import (
"context"
"fmt"
"github.com/keybase/cli"
"github.com/adamwalz/keybase-client/go/libcmdline"
"github.com/adamwalz/keybase-client/go/libkb"
"github.com/adamwalz/keybase-client/go/protocol/keybase1"
)
// CmdSimpleForceConflict is the 'fs force-conflict' command.
type CmdSimpleFSForceConflict struct {
libkb.Contextified
path keybase1.Path
}
// NewCmdSimpleFSForceConflict creates a new cli.Command. Right now
// it just triggers a "stuck" conflict, but maybe in the future we'll
// want to add more types of manual conflicts.
func NewCmdSimpleFSForceConflict(
cl *libcmdline.CommandLine, g *libkb.GlobalContext) cli.Command {
return cli.Command{
Name: "force-conflict",
ArgumentHelp: "<path-to-folder>",
Usage: "forces a conflict in the given folder",
Action: func(c *cli.Context) {
cl.ChooseCommand(&CmdSimpleFSForceConflict{
Contextified: libkb.NewContextified(g)}, "force-conflict", c)
cl.SetNoStandalone()
},
}
}
// Run runs the command in client/server mode.
func (c *CmdSimpleFSForceConflict) Run() error {
cli, err := GetSimpleFSClient(c.G())
if err != nil {
return err
}
return cli.SimpleFSForceStuckConflict(context.TODO(), c.path)
}
// ParseArgv gets the path.
func (c *CmdSimpleFSForceConflict) ParseArgv(ctx *cli.Context) error {
if len(ctx.Args()) != 1 {
return fmt.Errorf("wrong number of arguments")
}
p, err := makeSimpleFSPath(ctx.Args()[0])
if err != nil {
return err
}
c.path = p
return nil
}
// GetUsage says what this command needs to operate.
func (c *CmdSimpleFSForceConflict) GetUsage() libkb.Usage {
return libkb.Usage{
Config: true,
KbKeyring: true,
API: true,
}
}