aboutsummaryrefslogtreecommitdiff
path: root/src/applets
Commit message (Collapse)AuthorAgeFilesLines
* major changes, ECTester rewrite, moved to valid packageJ08nY2017-01-174-3499/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | reader: ECTester, mostly rewritten SimpleAPDU - communication with applet now done through simpler instructions: allocate, set, generate, ecdh, ecdsa - moved to a valid Java package dir cz.crcs.ectester - SimpleAPDU: renamed to ECTester - CardMngr: seamlessly supports simulation vs real card - DirtyLogger: takes a nullable String and creates file - ECTester: currently only supports key generation, curve testing under way - supports external curve setting, example files in data package - tests can be done through files, to achieve a more modular approach - Util: static utility class - ParamReader: reads curve domain parameters and keys from simple csv-like human-readable files with hex strings applet: ECTesterApplet, rewrite of SimpleECCApplet - more granularity in instructions - moved complexity over to the reader side - ECKeyGenerator: now a class that takes KeyPair as param - ECKeyTester: now a class that takes KeyPair as param - EC_Consts: removed ecsp curves(now done externally), removed unused methods - ECTesterApplet: currently only tested instructions are: allocate, set, generate data: contains several curve and pubkey files in format supported by ParamReader - Prime field curves: p,a,b,gx,gy,r,k - Binary field curves: e1,a,b,gx,gy,r,k or e1,e2,e3,a,b,gx,gy,r,k - Public key: wx,wy - Private key: s - Key: wx,wy,s - all values are hex strings
* Fixed some issues with errors in key generation, and their propagationJ08nY2016-12-112-35/+36
|
* Added CLI options, Apache commons-cli lib, anomalous curve key exportJ08nY2016-12-102-8/+20
| | | | | | | | - Added CLI options, see SimpleAPDU.jar -h - Added Apache commons-cli for CLI options, it uses Apache license - Added support for anomalous curve export both reader/applet side: `java -jar SimpleAPDU.jar -g 10 -b 256 -fp -s` generates 10 curves over ECSP256 an anomalous 256bit curve.
* Changed ECSP curves, 192b and 521b, to ones that have a prime pubkey order.J08nY2016-11-302-184/+185
|
* Fixed small-pub degree test, still crashes most cards.J08nY2016-11-302-14/+20
|
* fixed small pubkey order test, this times out on some ↵J08nY2016-11-282-36/+46
| | | | | | cards(SCARD_E_NOT_TRANSACTED) yet some cards run fine and report illegal value.
* Added test for small public key degree in ECDHJ08nY2016-11-283-28/+117
|
* EC_Consts: addded anomalous curves, with ordinady base points and small ↵J08nY2016-11-281-16/+780
| | | | order pubkeys
* Added tests for non-prime p, ECDSA into the main test suite.J08nY2016-11-262-14/+61
| | | | Also fixed ECDSA test.
* Merge branch 'devel' of github.com:petrs/ECTester into develJ08nY2016-11-212-38/+75
|\
| * Added support for multiple readerspetrs2016-11-182-25/+66
| | | | | | | | Added support for mass gathering of ECC keys (refactoring needed)
* | ECKeyGenerator: fixes to key genertion,J08nY2016-11-214-77/+101
| | | | | | | | | | | | | | | | ECKeyTester: fixed ECDH/ECDHC pubkey length issue. EC_Consts: fixed decompressG and getCurveParameter array copy mismatch SimpleECCApplet: fixed B parameter test All tests now pass as before.
* | EC_Consts: added sect233r1, sect283r1, sect409r1, sect571r1J08nY2016-11-211-2/+396
| |
* | Implemented External curve setting on applet sideJ08nY2016-11-212-8/+194
| | | | | | | | | | | | | | | | SimpleECCApplet: added TestEC_SupportExternal which receives an FP or F2M elliptic curve parameters in an APDU, sets it and tries ECDH, ECDSA. ECKeyGenerator: added setExternalCurve, which reads and sets external parameters from one buffer, with data order: field | a | b | g | r | k
* | EC_Consts: made parameters maskableJ08nY2016-11-214-41/+35
| | | | | | | | | | | | ECKeyGenerator: since parameters are maskable, one can now setCustomInvalidCurve(curve, PARAMETER_A | PARAMETER_B,...) and the resulting curve will have both A and B invalid.
* | EC_Consts: added F2M curve support, + F2M curve sect163r1 to startJ08nY2016-11-214-1032/+1045
| |
* | refactoring ECTester: created ECKeyGenerator, ECKeyTesterJ08nY2016-11-213-3/+363
|/
* fixed incorrect curve parameter P for secp384r1 curvepetrs2016-10-041-1/+1
|
* EC curve testing in separate apdu due to weird behavior of some cards after ↵v0.0.3petrs2016-10-041-1/+21
| | | | multiple errors within single apdu
* corruption of parameter B addedpetrs2016-10-031-22/+143
|
* valid/invalid B set also into private keypetrs2016-09-291-0/+2
|
* added test which repeatedly tries to set invalid B parameter and generate ↵petrs2016-09-271-3/+155
| | | | new keypair with it (shoudl fail)
* more options for corruptions of B argument addedpetrs2016-09-271-15/+45
|
* more systematic was how to skip tests which are stictly dependent on ↵petrs2016-09-091-99/+144
| | | | previous test which must succedd
* removal of leftover codev0.0.1v0petrs2016-09-092-137/+101
|
* testing of EC F2M curves added (no predefined curves yet, just default ones)petrs2016-09-091-5/+22
|
* parameters for secp521r1 addedpetrs2016-09-091-1/+132
|
* - added curve secp384r1petrs2016-09-082-6/+168
| | | | | - added test for ECDH secret generation: valid and invalid point - output beautification
* added support for curves secp128r1, secp160r1, secp224r1petrs2016-09-081-1/+180
|
* - added testing of EC_FP 128-521bits (KeyPair allocation, gen key with def. ↵petrs2016-09-082-153/+356
| | | | | | curve, set custom curve, gen keypair with custom curve, set invalid curve, gen keypair with invalid curve) - parsing code with formating and printing
* initial commitpetrs2016-09-082-0/+535