Skip to content

Commit

Permalink
pySim-read.py: Added a common card detection function for both pySim-…
Browse files Browse the repository at this point in the history
…prog.py and pySim-read.py

This function is used to detect the card type and return Card class/Card subclasses object
if its a know card or else None. Also, an initial step towards refactoring of code.

Change-Id: I71f57c6403dc933bd9d54f90df3d3fe105b4f66f
  • Loading branch information
herlesupreeth committed Mar 22, 2020
1 parent e4e9831 commit 4c306ab
Show file tree
Hide file tree
Showing 9 changed files with 44 additions and 36 deletions.
34 changes: 2 additions & 32 deletions pySim-prog.py
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@
import simplejson as json

from pySim.commands import SimCardCommands
from pySim.cards import _cards_classes
from pySim.cards import _cards_classes, card_detect
from pySim.utils import h2b, swap_nibbles, rpad, derive_milenage_opc, calculate_luhn, dec_iccid
from pySim.ts_51_011 import EF
from pySim.card_handler import *
Expand Down Expand Up @@ -609,36 +609,6 @@ def save_batch(opts):
fh.close()


def card_detect(opts, scc):

# Detect type if needed
card = None
ctypes = dict([(kls.name, kls) for kls in _cards_classes])

if opts.type in ("auto", "auto_once"):
for kls in _cards_classes:
card = kls.autodetect(scc)
if card:
print("Autodetected card type: %s" % card.name)
card.reset()
break

if card is None:
print("Autodetection failed")
return

if opts.type == "auto_once":
opts.type = card.name

elif opts.type in ctypes:
card = ctypes[opts.type](scc)

else:
raise ValueError("Unknown card type: %s" % opts.type)

return card


def process_card(opts, first, card_handler):

if opts.dry_run is False:
Expand All @@ -647,7 +617,7 @@ def process_card(opts, first, card_handler):

if opts.dry_run is False:
# Get card
card = card_detect(opts, scc)
card = card_detect(opts.type, scc)
if card is None:
print("No card detected!")
return -1
Expand Down
4 changes: 4 additions & 0 deletions pySim-read.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
from pySim.ts_51_011 import EF, DF

from pySim.commands import SimCardCommands
from pySim.cards import card_detect, Card
from pySim.utils import h2b, swap_nibbles, rpad, dec_imsi, dec_iccid, dec_msisdn, format_xplmn_w_act, dec_spn


Expand Down Expand Up @@ -94,6 +95,9 @@ def parse_options():
# Program the card
print("Reading ...")

# Initialize Card object by auto detecting the card
card = card_detect("auto", scc) or Card(scc)

# EF.ICCID
(res, sw) = scc.read_binary(EF['ICCID'])
if sw == '9000':
Expand Down
28 changes: 28 additions & 0 deletions pySim/cards.py
Original file line number Diff line number Diff line change
Expand Up @@ -1104,3 +1104,31 @@ def card_autodetect(scc):
card.reset()
return card
return None

def card_detect(ctype, scc):
# Detect type if needed
card = None
ctypes = dict([(kls.name, kls) for kls in _cards_classes])

if ctype in ("auto", "auto_once"):
for kls in _cards_classes:
card = kls.autodetect(scc)
if card:
print("Autodetected card type: %s" % card.name)
card.reset()
break

if card is None:
print("Autodetection failed")
return None

if ctype == "auto_once":
ctype = card.name

elif ctype in ctypes:
card = ctypes[ctype](scc)

else:
raise ValueError("Unknown card type: %s" % ctype)

return card
1 change: 1 addition & 0 deletions pysim-testdata/Fairwaves-SIM.ok
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
Using PC/SC reader (dev=0) interface
Reading ...
Autodetected card type: Fairwaves-SIM
ICCID: 8988219000000117833
IMSI: 001010000000111
GID1: ffffffffffffffff
Expand Down
9 changes: 5 additions & 4 deletions pysim-testdata/Wavemobile-SIM.ok
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
Using PC/SC reader (dev=4) interface
Using PC/SC reader (dev=3) interface
Reading ...
Autodetected card type: Wavemobile-SIM
ICCID: 89445310150011013678
IMSI: 001010000000102
GID1: Can't read file -- SW match failed! Expected 9000 and got 9404.
GID2: Can't read file -- SW match failed! Expected 9000 and got 9404.
GID1: Can't read file -- SW match failed! Expected 9000 and got 6a82.
GID2: Can't read file -- SW match failed! Expected 9000 and got 6a82.
SMSP: e1ffffffffffffffffffffffff0581005155f5ffffffffffff000000ffffffffffffffffffffffffffff
SPN: wavemobile
Display HPLMN: False
Expand Down Expand Up @@ -45,7 +46,7 @@ OPLMNwAcT:
ffffff0000 # unused
ffffff0000 # unused

HPLMNAcT: Can't read file -- SW match failed! Expected 9000 and got 9404.
HPLMNAcT: Can't read file -- SW match failed! Expected 9000 and got 6a82.
ACC: abce
MSISDN: Not available
AD: 00ffff02
Expand Down
1 change: 1 addition & 0 deletions pysim-testdata/fakemagicsim.ok
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
Using PC/SC reader (dev=2) interface
Reading ...
Autodetected card type: fakemagicsim
ICCID: 1122334455667788990
IMSI: 001010000000102
GID1: Can't read file -- SW match failed! Expected 9000 and got 9404.
Expand Down
1 change: 1 addition & 0 deletions pysim-testdata/sysmoISIM-SJA2.ok
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
Using PC/SC reader (dev=0) interface
Reading ...
Autodetected card type: sysmoISIM-SJA2
ICCID: 8988211900000000004
IMSI: 001010000000102
GID1: ffffffffffffffffffff
Expand Down
1 change: 1 addition & 0 deletions pysim-testdata/sysmoUSIM-SJS1.ok
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
Using PC/SC reader (dev=1) interface
Reading ...
Autodetected card type: sysmoUSIM-SJS1
ICCID: 1122334455667788990
IMSI: 001010000000102
GID1: ffffffffffffffffffff
Expand Down
1 change: 1 addition & 0 deletions pysim-testdata/sysmosim-gr1.ok
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
Using PC/SC reader (dev=3) interface
Reading ...
Autodetected card type: sysmosim-gr1
ICCID: 1122334455667788990
IMSI: 001010000000102
GID1: Can't read file -- SW match failed! Expected 9000 and got 9404.
Expand Down

0 comments on commit 4c306ab

Please sign in to comment.