diff --git a/pySim/commands.py b/pySim/commands.py index 96571625..eb8217d5 100644 --- a/pySim/commands.py +++ b/pySim/commands.py @@ -441,3 +441,9 @@ class SimCardCommands(object): def envelope(self, payload:str): """Send one ENVELOPE command to the SIM""" return self._tp.send_apdu_checksw('80c20000%02x%s' % (len(payload)//2, payload)) + + def terminal_profile(self, payload:str): + """Send TERMINAL PROFILE to card""" + data_length = len(payload) // 2 + data, sw = self._tp.send_apdu(('80100000%02x' % data_length) + payload) + return (data, sw) diff --git a/pySim/transport/__init__.py b/pySim/transport/__init__.py index 72a80a96..cb781b0b 100644 --- a/pySim/transport/__init__.py +++ b/pySim/transport/__init__.py @@ -136,6 +136,10 @@ class LinkBase(abc.ABC): """ rv = self.send_apdu(pdu) + if sw == '9000' and sw_match(rv[1], '91xx'): + # proactive sim as per TS 102 221 Setion 7.4.2 + rv = self.send_apdu_checksw('80120000' + rv[1][2:], sw) + print("FETCH: %s", rv[0]) if not sw_match(rv[1], sw): raise SwMatchError(rv[1], sw.lower(), self.sw_interpreter) return rv diff --git a/pySim/ts_31_102.py b/pySim/ts_31_102.py index f3628ad4..f347f67a 100644 --- a/pySim/ts_31_102.py +++ b/pySim/ts_31_102.py @@ -1084,6 +1084,10 @@ class ADF_USIM(CardADF): (data, sw) = self._cmd.card._scc.authenticate(opts.rand, opts.autn) self._cmd.poutput_json(data) + def do_terminal_profile(self, arg): + """Send a TERMINAL PROFILE command to the card.""" + (data, sw) = self._cmd.card._scc.terminal_profile(arg) + self._cmd.poutput('SW: %s, data: %s' % (sw, data)) # TS 31.102 Section 7.3