1 //-----------------------------------------------------------------------------
2 // Copyright (C) 2012 Frederik Möllers
4 // This code is licensed to you under the terms of the GNU GPL, version 2 or,
5 // at your option, any later version. See the LICENSE.txt file for the text of
7 //-----------------------------------------------------------------------------
8 // Commands related to the German electronic Identification Card
9 //-----------------------------------------------------------------------------
14 #include "cmdparser.h"
20 static int CmdHelp(const char *Cmd
);
22 // Perform (part of) the PACE protocol
23 int CmdHFEPACollectPACENonces(const char *Cmd
)
25 // requested nonce size
27 // requested number of Nonces
29 // delay between requests
32 sscanf(Cmd
, "%hhu %u %u", &m
, &n
, &d
);
34 // values are expected to be > 0
38 PrintAndLog("Collecting %u %hhu-byte nonces", n
, m
);
39 PrintAndLog("Start: %u", time(NULL
));
41 for (unsigned int i
= 0; i
< n
; i
++) {
43 UsbCommand c
= {CMD_EPA_PACE_COLLECT_NONCE
, {(int)m
, 0, 0}};
45 UsbCommand
*resp
= WaitForResponse(CMD_ACK
);
47 // check if command failed
48 if (resp
->arg
[0] != 0) {
49 PrintAndLog("Error in step %d, Return code: %d",
53 size_t nonce_length
= resp
->arg
[1];
54 char *nonce
= (char *) malloc(2 * nonce_length
+ 1);
55 for(int j
= 0; j
< nonce_length
; j
++) {
56 snprintf(nonce
+ (2 * j
), 3, "%02X", resp
->d
.asBytes
[j
]);
59 PrintAndLog("Length: %d, Nonce: %s",
66 PrintAndLog("End: %u", time(NULL
));
73 static const command_t CommandTable
[] =
75 {"help", CmdHelp
, 1, "This help"},
76 {"cnonces", CmdHFEPACollectPACENonces
, 0,
77 "<m> <n> <d> Acquire n>0 encrypted PACE nonces of size m>0 with d sec pauses"},
81 int CmdHelp(const char *Cmd
)
83 CmdsHelp(CommandTable
);
87 int CmdHFEPA(const char *Cmd
)
90 while (WaitForResponseTimeout(CMD_ACK
, 500) != NULL
) ;
93 CmdsParse(CommandTable
, Cmd
);