X-Git-Url: http://www.average.org/gitweb/?p=YkNeoCR.git;a=blobdiff_plain;f=src%2Forg%2Faverage%2Fnfcauthcr%2FYkNeo.java;h=1537459ba7e7c6ef4513370a844fc8b234194e07;hp=a291eabe1a4f4131a2764bb880916bba31e05b9f;hb=28b4d52dc728ff9016890ff3630d1237f1f2650b;hpb=a0d60dab1717e69b6d853eb91d0065fe378e3c28 diff --git a/src/org/average/nfcauthcr/YkNeo.java b/src/org/average/nfcauthcr/YkNeo.java index a291eab..1537459 100644 --- a/src/org/average/nfcauthcr/YkNeo.java +++ b/src/org/average/nfcauthcr/YkNeo.java @@ -7,7 +7,8 @@ import android.nfc.NfcAdapter; import android.nfc.Tag; import android.nfc.TagLostException; import android.nfc.tech.IsoDep; -//import android.util.Log; + +import org.average.nfcauthcr.CRException; public class YkNeo { @@ -23,18 +24,16 @@ public class YkNeo { private static final byte SLOT_CHAL_HMAC2 = 0x38; public static final byte[] doChallengeYubiKey(IsoDep isoTag, int slot, - byte[] challenge) { + byte[] challenge) + throws CRException { try { isoTag.connect(); byte[] resp = isoTag.transceive(selectApdu); int length = resp.length; - //Log.v(TAG, "response to select length is " + length); if (resp[length - 2] != (byte)0x90 || resp[length - 1] != 0x00) { - //Log.v(TAG, "Wrong response to select"); - //Toast.makeText(this, R.string.tag_error, - // Toast.LENGTH_LONG).show(); - return null; + throw new CRException( + "NFC Error code in the response to select"); } byte[] crApdu = new byte[69]; crApdu[0] = 0x00; // CLA @@ -52,24 +51,14 @@ public class YkNeo { length = resp.length; if (resp[length - 2] != (byte)0x90 || resp[length - 1] != 0x00) { - //Log.v(TAG, "Wrong response to challenge"); - //Toast.makeText(this, R.string.tag_error, - // Toast.LENGTH_LONG).show(); - return null; + throw new CRException( + "NFC Error code in the response to CR"); } - //Log.v(TAG, "response to challenge length is " + length); return Arrays.copyOf(resp, length-2); } catch (TagLostException e) { - //Log.v(TAG, e.getMessage()); - //Toast.makeText(this, - // R.string.tag_lost, Toast.LENGTH_LONG).show(); + throw new CRException("NFC connection lost", e); } catch (IOException e) { - //Log.v(TAG, e.getMessage()); - //Toast.makeText(this, - // getText(R.string.tag_error) + - // e.getMessage(), - // Toast.LENGTH_LONG).show(); + throw new CRException("NFC I/O error", e); } - return null; } }