mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-03 22:56:33 +02:00
card: Run factory-reset in locked stated.
* scd/command.c (reset_notify): Add option --keep-lock. (do_reset): Add arg keep_lock. (cmd_lock): Send progress status. * g10/call-agent.c (agent_scd_apdu): Add more pseudo APDUs. * g10/card-util.c (send_apdu): Ditto. (factory_reset): Use lock commands. -- This is required so that for example Kleopatra does not detect the RESET and issues a SERIALNO of its own, thus conflicting with our SERIALNO undefined. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
e08e1d62d0
commit
8fb0d5e3c7
4 changed files with 58 additions and 17 deletions
|
@ -975,8 +975,14 @@ agent_scd_keypairinfo (ctrl_t ctrl, const char *keyref, keypair_info_t *r_list)
|
|||
|
||||
/* Send an APDU to the current card. On success the status word is
|
||||
* stored at R_SW. With HEXAPDU being NULL only a RESET command is
|
||||
* send to scd. With HEXAPDU being the string "undefined" the command
|
||||
* "SERIALNO undefined" is send to scd.
|
||||
* send to scd. HEXAPDU may also be one of these special strings:
|
||||
*
|
||||
* "undefined" :: Send the command "SCD SERIALNO undefined"
|
||||
* "lock" :: Send the command "SCD LOCK --wait"
|
||||
* "trylock" :: Send the command "SCD LOCK"
|
||||
* "unlock" :: Send the command "SCD UNLOCK"
|
||||
* "reset-keep-lock" :: Send the command "SCD RESET --keep-lock"
|
||||
*
|
||||
* Used by:
|
||||
* card-util.c
|
||||
*/
|
||||
|
@ -997,6 +1003,26 @@ agent_scd_apdu (const char *hexapdu, unsigned int *r_sw)
|
|||
NULL, NULL, NULL, NULL, NULL, NULL);
|
||||
|
||||
}
|
||||
else if (!strcmp (hexapdu, "reset-keep-lock"))
|
||||
{
|
||||
err = assuan_transact (agent_ctx, "SCD RESET --keep-lock",
|
||||
NULL, NULL, NULL, NULL, NULL, NULL);
|
||||
}
|
||||
else if (!strcmp (hexapdu, "lock"))
|
||||
{
|
||||
err = assuan_transact (agent_ctx, "SCD LOCK --wait",
|
||||
NULL, NULL, NULL, NULL, NULL, NULL);
|
||||
}
|
||||
else if (!strcmp (hexapdu, "trylock"))
|
||||
{
|
||||
err = assuan_transact (agent_ctx, "SCD LOCK",
|
||||
NULL, NULL, NULL, NULL, NULL, NULL);
|
||||
}
|
||||
else if (!strcmp (hexapdu, "unlock"))
|
||||
{
|
||||
err = assuan_transact (agent_ctx, "SCD UNLOCK",
|
||||
NULL, NULL, NULL, NULL, NULL, NULL);
|
||||
}
|
||||
else if (!strcmp (hexapdu, "undefined"))
|
||||
{
|
||||
err = assuan_transact (agent_ctx, "SCD SERIALNO undefined",
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue