github.com/franc20/ayesa_sap@v7.0.0-beta.28.0.20200124003224-302d4d52fa6c+incompatible/command/v7/events_command.go (about) 1 package v7 2 3 import ( 4 "code.cloudfoundry.org/cli/actor/sharedaction" 5 "code.cloudfoundry.org/cli/actor/v7action" 6 "code.cloudfoundry.org/cli/command" 7 "code.cloudfoundry.org/cli/command/flag" 8 "code.cloudfoundry.org/cli/command/v7/shared" 9 "code.cloudfoundry.org/cli/util/ui" 10 "code.cloudfoundry.org/clock" 11 ) 12 13 //go:generate counterfeiter . EventsActor 14 15 type EventsActor interface { 16 GetRecentEventsByApplicationNameAndSpace(appName string, spaceGUID string) ([]v7action.Event, v7action.Warnings, error) 17 } 18 19 type EventsCommand struct { 20 RequiredArgs flag.AppName `positional-args:"yes"` 21 usage interface{} `usage:"CF_NAME events APP_NAME"` 22 relatedCommands interface{} `related_commands:"app, logs, map-route, unmap-route"` 23 24 UI command.UI 25 Config command.Config 26 SharedActor command.SharedActor 27 Actor EventsActor 28 } 29 30 func (cmd *EventsCommand) Setup(config command.Config, ui command.UI) error { 31 cmd.UI = ui 32 cmd.Config = config 33 cmd.SharedActor = sharedaction.NewActor(config) 34 35 ccClient, _, err := shared.GetNewClientsAndConnectToCF(config, ui, "") 36 if err != nil { 37 return err 38 } 39 cmd.Actor = v7action.NewActor(ccClient, config, nil, nil, clock.NewClock()) 40 41 return nil 42 } 43 44 func (cmd EventsCommand) Execute(_ []string) error { 45 err := cmd.SharedActor.CheckTarget(true, true) 46 if err != nil { 47 return err 48 } 49 50 user, err := cmd.Config.CurrentUser() 51 if err != nil { 52 return err 53 } 54 55 appName := cmd.RequiredArgs.AppName 56 cmd.UI.DisplayTextWithFlavor("Getting events for app {{.AppName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.Username}}...", map[string]interface{}{ 57 "AppName": appName, 58 "OrgName": cmd.Config.TargetedOrganization().Name, 59 "SpaceName": cmd.Config.TargetedSpace().Name, 60 "Username": user.Name, 61 }) 62 63 events, warnings, err := cmd.Actor.GetRecentEventsByApplicationNameAndSpace( 64 appName, 65 cmd.Config.TargetedSpace().GUID, 66 ) 67 cmd.UI.DisplayWarnings(warnings) 68 if err != nil { 69 return err 70 } 71 72 if len(events) == 0 { 73 cmd.UI.DisplayText("No events found.") 74 } 75 76 table := [][]string{ 77 { 78 cmd.UI.TranslateText("time"), 79 cmd.UI.TranslateText("event"), 80 cmd.UI.TranslateText("actor"), 81 cmd.UI.TranslateText("description"), 82 }, 83 } 84 85 for _, event := range events { 86 table = append(table, []string{ 87 event.Time.Local().Format("2006-01-02T15:04:05.00-0700"), 88 event.Type, 89 event.ActorName, 90 event.Description, 91 }) 92 } 93 94 cmd.UI.DisplayTableWithHeader("", table, ui.DefaultTableSpacePadding) 95 96 return nil 97 }