From f764f5ea6d19c3f26cbc00f1096b1dfcb77f359c Mon Sep 17 00:00:00 2001 From: Derek Kozel Date: Wed, 24 Jan 2018 12:54:55 +0000 Subject: mpm: Changed mpm_shell to support scripted use --- mpm/tools/mpm_shell.py | 30 ++++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) (limited to 'mpm/tools/mpm_shell.py') diff --git a/mpm/tools/mpm_shell.py b/mpm/tools/mpm_shell.py index 405cb3710..d17fb5c61 100755 --- a/mpm/tools/mpm_shell.py +++ b/mpm/tools/mpm_shell.py @@ -122,22 +122,21 @@ class MPMShell(cmd.Cmd): """ RPC Shell class. See cmd module. """ - def __init__(self): + def __init__(self, host, port, claim, hijack): cmd.Cmd.__init__(self) self.prompt = "> " self.client = None self.remote_methods = [] self._claimer = None - self._host = None - self._port = None + self._host = host + self._port = port self._device_info = None - args = parse_args() - if args.host is not None: - self.connect(args.host, args.port) - if args.claim: + if host is not None: + self.connect(host, port) + if claim: self.claim() - elif args.hijack: - self.hijack(args.hijack) + elif hijack: + self.hijack(hijack) self.update_prompt() def _add_command(self, command, docs, requires_token=False): @@ -180,10 +179,11 @@ class MPMShell(cmd.Cmd): if isinstance(response, bool): if response: print("Command executed successfully!") - return - print("Command failed!") - return - print("==> " + str(response)) + else: + print("Command failed!") + else: + print("==> " + str(response)) + return response def get_names(self): " We need this for tab completion. " @@ -384,7 +384,9 @@ class MPMShell(cmd.Cmd): def main(): " Go, go, go! " - my_shell = MPMShell() + args = parse_args() + my_shell = MPMShell(args.host, args.port, args.claim, args.hijack) + try: return my_shell.run() except KeyboardInterrupt: -- cgit v1.2.3