From 275b81c341cd072467cfb47cb50821f46f6193ae Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Mon, 20 Nov 2017 22:27:54 -0800 Subject: mpm: Add 'hijack' mode to mpm_shell --- mpm/tools/mpm_shell.py | 43 ++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 42 insertions(+), 1 deletion(-) (limited to 'mpm/tools/mpm_shell.py') diff --git a/mpm/tools/mpm_shell.py b/mpm/tools/mpm_shell.py index bf44ff49a..a2000addc 100755 --- a/mpm/tools/mpm_shell.py +++ b/mpm/tools/mpm_shell.py @@ -60,6 +60,10 @@ def parse_args(): action='store_true', help="Claim device after connecting." ) + parser.add_argument( + '-j', '--hijack', type=str, + help="Hijack running session (excludes --claim)." + ) return parser.parse_args() @@ -111,6 +115,19 @@ class MPMClaimer(object): self._exit_loop = True self._claim_loop.join() +class MPMHijacker(object): + """ + Looks like a claimer object, but doesn't actually claim. + """ + def __init__(self, token): + self.token = token + + def unclaim(self): + """ + Unclaim device and exit claim loop. + """ + pass + class MPMShell(cmd.Cmd): """ @@ -130,6 +147,8 @@ class MPMShell(cmd.Cmd): self.connect(args.host, args.port) if args.claim: self.claim() + elif args.hijack: + self.hijack(args.hijack) self.update_prompt() def _add_command(self, command, docs, requires_token=False): @@ -257,6 +276,16 @@ class MPMShell(cmd.Cmd): self._claimer = MPMClaimer(self._host, self._port, self.unclaim_hook) return True + def hijack(self, token): + " Hijack running session " + assert self.client is not None + if self._claimer is not None: + print("Claimer already active. Can't hijack.") + return False + print("Hijacking device...") + self._claimer = MPMHijacker(token) + return True + def unclaim(self): """ unclaim @@ -278,11 +307,17 @@ class MPMShell(cmd.Cmd): if self._device_info is None: self.prompt = '> ' else: + if self._claimer is None: + claim_status = '' + elif isinstance(self._claimer, MPMClaimer): + claim_status = ' [C]' + elif isinstance(self._claimer, MPMHijacker): + claim_status = ' [H]' self.prompt = '{dev_id}{claim_status}> '.format( dev_id=self._device_info.get( 'name', self._device_info.get('serial', '?') ), - claim_status=' [C]' if self._claimer is not None else '' + claim_status=claim_status, ) def expand_args(self, args): @@ -330,6 +365,12 @@ class MPMShell(cmd.Cmd): """ self.claim() + def do_hijack(self, token): + """ + Hijack a running session + """ + self.hijack(token) + def do_unclaim(self, _): """ unclaim -- cgit v1.2.3