/
payload-unregister.go
79 lines (63 loc) · 1.99 KB
/
payload-unregister.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
71
72
73
74
75
76
77
78
79
// Copyright 2015 Canonical Ltd.
// Licensed under the AGPLv3, see LICENCE file for details.
package jujuc
import (
"github.com/juju/cmd/v3"
"github.com/juju/errors"
jujucmd "github.com/juju/juju/cmd"
)
// PayloadUnregisterCmd implements the untrack command.
type PayloadUnregisterCmd struct {
cmd.CommandBase
ctx ContextPayloads
class string
id string
}
// NewPayloadUnregisterCmd returns a new PayloadUnregisterCmd that wraps the given context.
func NewPayloadUnregisterCmd(ctx Context) (cmd.Command, error) {
return &PayloadUnregisterCmd{ctx: ctx}, nil
}
// Info implements cmd.Command.
func (c PayloadUnregisterCmd) Info() *cmd.Info {
return jujucmd.Info(&cmd.Info{
Name: "payload-unregister",
Args: "<class> <id>",
Purpose: "stop tracking a payload",
Doc: `
"payload-unregister" is used while a hook is running to let Juju know
that a payload has been manually stopped. The <class> and <id> provided
must match a payload that has been previously registered with juju using
payload-register.
`,
})
}
// Init implements cmd.Command.
func (c *PayloadUnregisterCmd) Init(args []string) error {
if len(args) < 2 {
return errors.Errorf("missing required arguments")
}
c.class = args[0]
c.id = args[1]
if err := cmd.CheckEmpty(args[2:]); err != nil {
return errors.Trace(err)
}
return nil
}
// Run runs the unregister command.
func (c *PayloadUnregisterCmd) Run(ctx *cmd.Context) error {
//TODO(wwitzel3) make Unregister accept class and id and
// compose the ID in the API layer using BuildID
logger.Tracef(`Running unregister command with id "%s/%s"`, c.class, c.id)
// TODO(ericsnow) Verify that Untrack gives a meaningful error when
// the ID is not found.
if err := c.ctx.UntrackPayload(c.class, c.id); err != nil {
return errors.Trace(err)
}
// TODO(ericsnow) Is the flush really necessary?
// We flush to state immediately so that status reflects the
// payload correctly.
if err := c.ctx.FlushPayloads(); err != nil {
return errors.Trace(err)
}
return nil
}