bettercap/session/session_core_handlers.go
evilsocket 9909cc877f balls
2018-01-14 14:05:11 +01:00

255 lines
5.7 KiB
Go

package session
import (
"fmt"
"path/filepath"
"strconv"
"strings"
"time"
"github.com/evilsocket/bettercap-ng/core"
"github.com/chzyer/readline"
)
func (s *Session) helpHandler(args []string, sess *Session) error {
filter := ""
if len(args) == 2 {
filter = strings.Trim(args[1], "\r\n\t ")
}
if filter == "" {
fmt.Println()
fmt.Printf(core.Bold("MAIN COMMANDS\n\n"))
for _, h := range s.CoreHandlers {
fmt.Printf(" "+core.Yellow("%"+strconv.Itoa(s.HelpPadding)+"s")+" : %s\n", h.Name, h.Description)
}
fmt.Printf(core.Bold("\nMODULES\n"))
for _, m := range s.Modules {
status := ""
if m.Running() {
status = core.Green("running")
} else {
status = core.Red("not running")
}
fmt.Printf(" "+core.Yellow("%"+strconv.Itoa(s.HelpPadding)+"s")+" > %s\n", m.Name(), status)
}
fmt.Println()
} else {
err, m := s.Module(filter)
if err != nil {
return err
}
fmt.Println()
status := ""
if m.Running() {
status = core.Green("running")
} else {
status = core.Red("not running")
}
fmt.Printf("%s (%s): %s\n\n", core.Yellow(m.Name()), status, core.Dim(m.Description()))
for _, h := range m.Handlers() {
fmt.Printf(h.Help(s.HelpPadding))
}
params := m.Parameters()
if len(params) > 0 {
fmt.Printf("\n Parameters\n\n")
for _, p := range params {
fmt.Printf(p.Help(s.HelpPadding))
}
fmt.Println()
}
}
return nil
}
func (s *Session) activeHandler(args []string, sess *Session) error {
for _, m := range s.Modules {
if m.Running() == false {
continue
}
fmt.Printf("%s (%s)\n", core.Bold(m.Name()), core.Dim(m.Description()))
params := m.Parameters()
if len(params) > 0 {
fmt.Println()
for _, p := range params {
fmt.Printf(p.Dump(s.HelpPadding))
}
}
fmt.Println()
}
return nil
}
func (s *Session) exitHandler(args []string, sess *Session) error {
for _, mod := range s.Modules {
mod.Stop()
}
s.Active = false
s.Input.Close()
return nil
}
func (s *Session) sleepHandler(args []string, sess *Session) error {
if secs, err := strconv.Atoi(args[0]); err == nil {
time.Sleep(time.Duration(secs) * time.Second)
return nil
} else {
return err
}
}
func (s *Session) getHandler(args []string, sess *Session) error {
key := args[0]
if key == "*" {
prev_ns := ""
fmt.Println()
for _, k := range s.Env.Sorted() {
ns := ""
toks := strings.Split(k, ".")
if len(toks) > 0 {
ns = toks[0]
}
if ns != prev_ns {
fmt.Println()
prev_ns = ns
}
fmt.Printf(" %"+strconv.Itoa(s.Env.Padding)+"s: '%s'\n", k, s.Env.Storage[k])
}
fmt.Println()
} else if found, value := s.Env.Get(key); found == true {
fmt.Println()
fmt.Printf(" %s: '%s'\n", key, value)
fmt.Println()
} else {
return fmt.Errorf("%s not found", key)
}
return nil
}
func (s *Session) setHandler(args []string, sess *Session) error {
key := args[0]
value := args[1]
if value == "\"\"" {
value = ""
}
s.Env.Set(key, value)
return nil
}
func (s *Session) clsHandler(args []string, sess *Session) error {
readline.ClearScreen(s.Input.Stdout())
return nil
}
func (s *Session) includeHandler(args []string, sess *Session) error {
return s.RunCaplet(args[0])
}
func (s *Session) addHandler(h CommandHandler, c *readline.PrefixCompleter) {
h.Completer = c
s.CoreHandlers = append(s.CoreHandlers, h)
}
func (s *Session) registerCoreHandlers() {
s.addHandler(NewCommandHandler("help MODULE",
"^(help|\\?)(.*)$",
"List available commands or show module specific help if no module name is provided.",
s.helpHandler),
readline.PcItem("help", readline.PcItemDynamic(func(prefix string) []string {
prefix = strings.Trim(prefix[4:], "\t\r\n ")
modNames := []string{""}
for _, m := range s.Modules {
if prefix == "" || strings.HasPrefix(m.Name(), prefix) == true {
modNames = append(modNames, m.Name())
}
}
return modNames
})))
s.addHandler(NewCommandHandler("active",
"^active$",
"Show information about active modules.",
s.activeHandler),
readline.PcItem("active"))
s.addHandler(NewCommandHandler("quit",
"^(q|quit|e|exit)$",
"Close the session and exit.",
s.exitHandler),
readline.PcItem("quit"))
s.addHandler(NewCommandHandler("sleep SECONDS",
"^sleep\\s+(\\d+)$",
"Sleep for the given amount of seconds.",
s.sleepHandler),
readline.PcItem("sleep"))
s.addHandler(NewCommandHandler("get NAME",
"^get\\s+(.+)",
"Get the value of variable NAME, use * for all.",
s.getHandler),
readline.PcItem("get", readline.PcItemDynamic(func(prefix string) []string {
prefix = strings.Trim(prefix[3:], "\t\r\n ")
varNames := []string{""}
for key := range s.Env.Storage {
if prefix == "" || strings.HasPrefix(key, prefix) == true {
varNames = append(varNames, key)
}
}
return varNames
})))
s.addHandler(NewCommandHandler("set NAME VALUE",
"^set\\s+([^\\s]+)\\s+(.+)",
"Set the VALUE of variable NAME.",
s.setHandler),
readline.PcItem("set", readline.PcItemDynamic(func(prefix string) []string {
prefix = strings.Trim(prefix[3:], "\t\r\n ")
varNames := []string{""}
for key, _ := range s.Env.Storage {
if prefix == "" || strings.HasPrefix(key, prefix) == true {
varNames = append(varNames, key)
}
}
return varNames
})))
s.addHandler(NewCommandHandler("clear",
"^(clear|cls)$",
"Clear the screen.",
s.clsHandler),
readline.PcItem("clear"))
s.addHandler(NewCommandHandler("include CAPLET",
"^include\\s+(.+)",
"Load and run this caplet in the current session.",
s.includeHandler),
readline.PcItem("include", readline.PcItemDynamic(func(prefix string) []string {
prefix = strings.Trim(prefix[8:], "\t\r\n ")
if prefix == "" {
prefix = "."
}
files := []string{}
files, _ = filepath.Glob(prefix + "*")
return files
})))
}