David Haukeness
5 years ago
1 changed files with 56 additions and 0 deletions
@ -0,0 +1,56 @@
@@ -0,0 +1,56 @@
|
||||
// +build !rm_basic_commands allcommands execcmd
|
||||
|
||||
package main |
||||
|
||||
import ( |
||||
"fmt" |
||||
"os/exec" |
||||
"strings" |
||||
) |
||||
|
||||
func init() { |
||||
command := Command{ |
||||
Cmd: []string{"exec", "ex"}, |
||||
Description: "$keybase args - executes keybase $args and returns the output", |
||||
Help: "", |
||||
Exec: cmdExec, |
||||
} |
||||
RegisterCommand(command) |
||||
} |
||||
|
||||
func cmdExec(cmd []string) { |
||||
l := len(cmd) |
||||
switch { |
||||
case l >= 2: |
||||
if cmd[1] == "keybase" { |
||||
// if the user types /exec keybase wallet list
|
||||
// only send ["wallet", "list"]
|
||||
runKeybaseExec(cmd[2:]) |
||||
} else { |
||||
// send everything except the command
|
||||
runKeybaseExec(cmd[1:]) |
||||
} |
||||
case l == 1: |
||||
fallthrough |
||||
default: |
||||
printExecHelp() |
||||
} |
||||
} |
||||
|
||||
func runKeybaseExec(args []string) { |
||||
cmd := exec.Command("keybase", args...) |
||||
output, err := cmd.CombinedOutput() |
||||
if err != nil { |
||||
printToView("Feed", fmt.Sprintf("Exec error: %+v", err)) |
||||
} else { |
||||
channel.Name = "" |
||||
// unjoin the chat
|
||||
clearView("Chat") |
||||
setViewTitle("Input", fmt.Sprintf(" /exec %s ", strings.Join(args, " "))) |
||||
printToView("Chat", fmt.Sprintf("%s", output)) |
||||
} |
||||
} |
||||
|
||||
func printExecHelp() { |
||||
printInfo(fmt.Sprintf("To execute a keybase command use %sexec <keybase args>", config.Basics.CmdPrefix)) |
||||
} |
Loading…
Reference in new issue