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  }