aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHarald Welte <laforge@osmocom.org>2021-01-21 14:10:43 +0100
committerHarald Welte <laforge@osmocom.org>2021-03-02 08:06:13 +0100
commite79cc8069aa73aefe26e8862b126920c9532c1a2 (patch)
tree2b2e5ae2f204a21dc4b5eb8f53d5f4d9046e26f0
parent79b5ba4bdfb65346dc4ac9b04db5aa39593bca9a (diff)
introduce SwMatchError exception
This allows callers further up the stack to catch the exception and interpret it in some way (like decoding the number of remaining tries in case of authentication errors) Change-Id: Ia59962978745aef7038f750fa23f8dfc820645f4
-rw-r--r--pySim/exceptions.py10
-rw-r--r--pySim/transport/__init__.py4
2 files changed, 13 insertions, 1 deletions
diff --git a/pySim/exceptions.py b/pySim/exceptions.py
index c0cf1e7..5d30f76 100644
--- a/pySim/exceptions.py
+++ b/pySim/exceptions.py
@@ -5,6 +5,7 @@
#
# Copyright (C) 2009-2010 Sylvain Munaut <tnt@246tNt.com>
+# Copyright (C) 2021 Harald Welte <laforge@osmocom.org>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@@ -36,3 +37,12 @@ class ProtocolError(Exception):
class ReaderError(Exception):
pass
+
+class SwMatchError(Exception):
+ """Raised when an operation specifies an expected SW but the actual SW from
+ the card doesn't match."""
+ def __init__(self, sw_actual, sw_expected):
+ self.sw_actual = sw_actual
+ self.sw_expected = sw_expected
+ def __str__(self):
+ return "SW match failed! Expected %s and got %s." % (self.sw_expected, self.sw_actual)
diff --git a/pySim/transport/__init__.py b/pySim/transport/__init__.py
index 8e009ee..00c7bd9 100644
--- a/pySim/transport/__init__.py
+++ b/pySim/transport/__init__.py
@@ -3,6 +3,8 @@
""" pySim: PCSC reader transport link base
"""
+from pySim.exceptions import *
+
#
# Copyright (C) 2009-2010 Sylvain Munaut <tnt@246tNt.com>
#
@@ -100,5 +102,5 @@ class LinkBase(object):
sw_masked = sw_masked + rv[1][i].lower()
if sw.lower() != sw_masked:
- raise RuntimeError("SW match failed! Expected %s and got %s." % (sw.lower(), rv[1]))
+ raise SwMatchError(rv[1], sw.lower())
return rv