-
Notifications
You must be signed in to change notification settings - Fork 928
/
v3_stage_command.go
99 lines (79 loc) · 3.18 KB
/
v3_stage_command.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
package v6
import (
"strings"
"time"
"code.cloudfoundry.org/cli/actor/sharedaction"
"code.cloudfoundry.org/cli/actor/v3action"
"code.cloudfoundry.org/cli/command"
"code.cloudfoundry.org/cli/command/flag"
"code.cloudfoundry.org/cli/command/v6/shared"
)
//go:generate counterfeiter . V3StageActor
type V3StageActor interface {
GetStreamingLogsForApplicationByNameAndSpace(appName string, spaceGUID string, client v3action.NOAAClient) (<-chan *v3action.LogMessage, <-chan error, v3action.Warnings, error)
StagePackage(packageGUID string, appName string) (<-chan v3action.Droplet, <-chan v3action.Warnings, <-chan error)
}
type V3StageCommand struct {
RequiredArgs flag.AppName `positional-args:"yes"`
PackageGUID string `long:"package-guid" description:"The guid of the package to stage" required:"true"`
usage interface{} `usage:"CF_NAME v3-stage APP_NAME --package-guid PACKAGE_GUID"`
envCFStagingTimeout interface{} `environmentName:"CF_STAGING_TIMEOUT" environmentDescription:"Max wait time for buildpack staging, in minutes" environmentDefault:"15"`
UI command.UI
Config command.Config
NOAAClient v3action.NOAAClient
SharedActor command.SharedActor
Actor V3StageActor
}
func (cmd *V3StageCommand) Setup(config command.Config, ui command.UI) error {
cmd.UI = ui
cmd.Config = config
cmd.SharedActor = sharedaction.NewActor(config)
ccClient, uaaClient, err := shared.NewV3BasedClients(config, ui, true)
if err != nil {
return err
}
cmd.Actor = v3action.NewActor(ccClient, config, nil, nil)
cmd.NOAAClient = shared.NewNOAAClient(ccClient.Info.Logging(), config, uaaClient, ui)
return nil
}
func (cmd V3StageCommand) Execute(args []string) error {
cmd.UI.DisplayWarning(command.ExperimentalWarning)
err := cmd.SharedActor.CheckTarget(true, true)
if err != nil {
return err
}
user, err := cmd.Config.CurrentUser()
if err != nil {
return err
}
cmd.UI.DisplayTextWithFlavor("Staging package for {{.AppName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.Username}}...", map[string]interface{}{
"AppName": cmd.RequiredArgs.AppName,
"OrgName": cmd.Config.TargetedOrganization().Name,
"SpaceName": cmd.Config.TargetedSpace().Name,
"Username": user.Name,
})
logStream, logErrStream, logWarnings, logErr := cmd.Actor.GetStreamingLogsForApplicationByNameAndSpace(cmd.RequiredArgs.AppName, cmd.Config.TargetedSpace().GUID, cmd.NOAAClient)
cmd.UI.DisplayWarnings(logWarnings)
if logErr != nil {
return logErr
}
dropletStream, warningsStream, errStream := cmd.Actor.StagePackage(cmd.PackageGUID, cmd.RequiredArgs.AppName)
var droplet v3action.Droplet
droplet, err = shared.PollStage(dropletStream, warningsStream, errStream, logStream, logErrStream, cmd.UI)
if err != nil {
return err
}
cmd.UI.DisplayNewline()
cmd.UI.DisplayText("Package staged")
t, err := time.Parse(time.RFC3339, droplet.CreatedAt)
if err != nil {
return err
}
table := [][]string{
{cmd.UI.TranslateText("droplet guid:"), droplet.GUID},
{cmd.UI.TranslateText("state:"), strings.ToLower(string(droplet.State))},
{cmd.UI.TranslateText("created:"), cmd.UI.UserFriendlyDate(t)},
}
cmd.UI.DisplayKeyValueTable("", table, 3)
return nil
}