mirror of
https://github.com/foomo/posh-providers.git
synced 2025-10-16 12:35:41 +00:00
fix(arbitrary/task): allow sudo
This commit is contained in:
parent
e5323e5351
commit
8c4a62c7d5
@ -2,12 +2,14 @@ package task
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"github.com/foomo/posh/pkg/command/tree"
|
"github.com/foomo/posh/pkg/command/tree"
|
||||||
"github.com/foomo/posh/pkg/log"
|
"github.com/foomo/posh/pkg/log"
|
||||||
"github.com/foomo/posh/pkg/prompt/goprompt"
|
"github.com/foomo/posh/pkg/prompt/goprompt"
|
||||||
"github.com/foomo/posh/pkg/readline"
|
"github.com/foomo/posh/pkg/readline"
|
||||||
"github.com/foomo/posh/pkg/shell"
|
|
||||||
"github.com/foomo/posh/pkg/util/suggests"
|
"github.com/foomo/posh/pkg/util/suggests"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/pterm/pterm"
|
"github.com/pterm/pterm"
|
||||||
@ -106,31 +108,59 @@ func (c *Command) Help(ctx context.Context, r *readline.Readline) string {
|
|||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
func (c *Command) execute(ctx context.Context, r *readline.Readline) error {
|
func (c *Command) execute(ctx context.Context, r *readline.Readline) error {
|
||||||
return c.executeTask(ctx, r.Args().At(0))
|
if err := c.executeTask(ctx, r.Args().At(0)); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
c.l.Info("🖖done")
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Command) executeTask(ctx context.Context, taskID string) error {
|
func (c *Command) executeTask(ctx context.Context, taskID string) error {
|
||||||
|
ctx, cancel := context.WithCancel(ctx)
|
||||||
|
defer cancel()
|
||||||
|
|
||||||
task, ok := c.cfg[taskID]
|
task, ok := c.cfg[taskID]
|
||||||
if !ok {
|
if !ok {
|
||||||
return errors.Errorf("task not found: %s", taskID)
|
return errors.Errorf("task not found: %s", taskID)
|
||||||
}
|
}
|
||||||
|
|
||||||
if task.Prompt != "" {
|
if task.Prompt != "" {
|
||||||
if result, err := pterm.DefaultInteractiveConfirm.Show(task.Prompt); err != nil {
|
if result, err := pterm.DefaultInteractiveConfirm.WithOnInterruptFunc(func() {
|
||||||
|
cancel()
|
||||||
|
}).Show(task.Prompt); err != nil {
|
||||||
return err
|
return err
|
||||||
|
} else if ctx.Err() != nil {
|
||||||
|
return ctx.Err()
|
||||||
} else if !result {
|
} else if !result {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, dep := range task.Deps {
|
for _, dep := range task.Deps {
|
||||||
|
if ctx.Err() != nil {
|
||||||
|
return ctx.Err()
|
||||||
|
}
|
||||||
if err := c.executeTask(ctx, dep); err != nil {
|
if err := c.executeTask(ctx, dep); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, cmd := range task.Cmds {
|
for i, cmd := range task.Cmds {
|
||||||
if err := shell.New(ctx, c.l, cmd).Debug().Run(); err != nil {
|
if ctx.Err() != nil {
|
||||||
|
return ctx.Err()
|
||||||
|
}
|
||||||
|
var sh *exec.Cmd
|
||||||
|
if strings.HasPrefix(cmd, "sudo ") {
|
||||||
|
sh = exec.CommandContext(ctx, "sudo", "sh", "-c", strings.TrimPrefix(cmd, "sudo "))
|
||||||
|
} else {
|
||||||
|
sh = exec.CommandContext(ctx, "sh", "-c", cmd)
|
||||||
|
}
|
||||||
|
sh.Stdin = os.Stdin
|
||||||
|
sh.Stdout = os.Stdout
|
||||||
|
sh.Stderr = os.Stderr
|
||||||
|
sh.Env = os.Environ()
|
||||||
|
c.l.Infof("[%d|%d] %s: %s", i+1, len(task.Cmds), taskID, cmd)
|
||||||
|
if err := sh.Run(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user