github.com/LukasHeimann/cloudfoundrycli/v8@v8.4.4/command/v7/run_task_command.go (about) 1 package v7 2 3 import ( 4 "fmt" 5 6 "github.com/LukasHeimann/cloudfoundrycli/v8/command/flag" 7 "github.com/LukasHeimann/cloudfoundrycli/v8/resources" 8 ) 9 10 type RunTaskCommand struct { 11 BaseCommand 12 13 RequiredArgs flag.RunTaskArgsV7 `positional-args:"yes"` 14 Command string `long:"command" short:"c" description:"The command to execute"` 15 Disk flag.Megabytes `short:"k" description:"Disk limit (e.g. 256M, 1024M, 1G)"` 16 Memory flag.Megabytes `short:"m" description:"Memory limit (e.g. 256M, 1024M, 1G)"` 17 Name string `long:"name" description:"Name to give the task (generated if omitted)"` 18 Process string `long:"process" description:"Process type to use as a template for command, memory, and disk for the created task."` 19 usage interface{} `usage:"CF_NAME run-task APP_NAME [--command COMMAND] [-k DISK] [-m MEMORY] [--name TASK_NAME] [--process PROCESS_TYPE]\n\nTIP:\n Use 'cf logs' to display the logs of the app and all its tasks. If your task name is unique, grep this command's output for the task name to view task-specific logs.\n\nEXAMPLES:\n CF_NAME run-task my-app --command \"bundle exec rake db:migrate\" --name migrate\n\n CF_NAME run-task my-app --process batch_job\n\n CF_NAME run-task my-app"` 20 relatedCommands interface{} `related_commands:"logs, tasks, terminate-task"` 21 } 22 23 func (cmd RunTaskCommand) Execute(args []string) error { 24 err := cmd.SharedActor.CheckTarget(true, true) 25 if err != nil { 26 return err 27 } 28 29 space := cmd.Config.TargetedSpace() 30 31 user, err := cmd.Actor.GetCurrentUser() 32 if err != nil { 33 return err 34 } 35 36 application, warnings, err := cmd.Actor.GetApplicationByNameAndSpace(cmd.RequiredArgs.AppName, space.GUID) 37 cmd.UI.DisplayWarnings(warnings) 38 if err != nil { 39 return err 40 } 41 42 cmd.UI.DisplayTextWithFlavor("Creating task for app {{.AppName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.CurrentUser}}...", map[string]interface{}{ 43 "AppName": cmd.RequiredArgs.AppName, 44 "OrgName": cmd.Config.TargetedOrganization().Name, 45 "SpaceName": space.Name, 46 "CurrentUser": user.Name, 47 }) 48 49 inputTask := resources.Task{ 50 Command: cmd.Command, 51 } 52 53 if cmd.Name != "" { 54 inputTask.Name = cmd.Name 55 } 56 if cmd.Disk.IsSet { 57 inputTask.DiskInMB = cmd.Disk.Value 58 } 59 if cmd.Memory.IsSet { 60 inputTask.MemoryInMB = cmd.Memory.Value 61 } 62 if cmd.Command == "" && cmd.Process == "" { 63 cmd.Process = "task" 64 } 65 if cmd.Process != "" { 66 process, warnings, err := cmd.Actor.GetProcessByTypeAndApplication(cmd.Process, application.GUID) 67 cmd.UI.DisplayWarnings(warnings) 68 if err != nil { 69 return err 70 } 71 72 inputTask.Template = &resources.TaskTemplate{ 73 Process: resources.TaskProcessTemplate{ 74 Guid: process.GUID, 75 }, 76 } 77 } 78 79 task, warnings, err := cmd.Actor.RunTask(application.GUID, inputTask) 80 cmd.UI.DisplayWarnings(warnings) 81 if err != nil { 82 return err 83 } 84 85 cmd.UI.DisplayText("Task has been submitted successfully for execution.") 86 cmd.UI.DisplayOK() 87 88 cmd.UI.DisplayKeyValueTable("", [][]string{ 89 {cmd.UI.TranslateText("task name:"), task.Name}, 90 {cmd.UI.TranslateText("task id:"), fmt.Sprint(task.SequenceID)}, 91 }, 3) 92 93 return nil 94 }