mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-24 15:17:02 +01:00
scd:p15: Improve the PIN prompt for Genua cards.
* scd/app-p15.c (CARD_PRODUCT_GENUA): New. (cardproduct2str): Add it. (read_p15_info): Detect and set GENUA (make_pin_prompt): Take holder string from the AODF.
This commit is contained in:
parent
137e59a6a5
commit
618aa8689a
@ -86,7 +86,8 @@ typedef enum
|
|||||||
{
|
{
|
||||||
CARD_PRODUCT_UNKNOWN,
|
CARD_PRODUCT_UNKNOWN,
|
||||||
CARD_PRODUCT_RSCS, /* Rohde&Schwarz Cybersecurity */
|
CARD_PRODUCT_RSCS, /* Rohde&Schwarz Cybersecurity */
|
||||||
CARD_PRODUCT_DTRUST /* D-Trust GmbH (bundesdruckerei.de) */
|
CARD_PRODUCT_DTRUST, /* D-Trust GmbH (bundesdruckerei.de) */
|
||||||
|
CARD_PRODUCT_GENUA /* GeNUA mbH */
|
||||||
}
|
}
|
||||||
card_product_t;
|
card_product_t;
|
||||||
|
|
||||||
@ -548,6 +549,7 @@ cardproduct2str (card_product_t cardproduct)
|
|||||||
case CARD_PRODUCT_UNKNOWN: return "";
|
case CARD_PRODUCT_UNKNOWN: return "";
|
||||||
case CARD_PRODUCT_RSCS: return "R&S";
|
case CARD_PRODUCT_RSCS: return "R&S";
|
||||||
case CARD_PRODUCT_DTRUST: return "D-Trust";
|
case CARD_PRODUCT_DTRUST: return "D-Trust";
|
||||||
|
case CARD_PRODUCT_GENUA: return "GeNUA";
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
@ -3579,6 +3581,9 @@ read_p15_info (app_t app)
|
|||||||
&& !ascii_strcasecmp (app->app_local->manufacturer_id, "GeNUA mbH")
|
&& !ascii_strcasecmp (app->app_local->manufacturer_id, "GeNUA mbH")
|
||||||
&& !app->app_local->no_extended_mode)
|
&& !app->app_local->no_extended_mode)
|
||||||
{
|
{
|
||||||
|
if (!app->app_local->card_product)
|
||||||
|
app->app_local->card_product = CARD_PRODUCT_GENUA;
|
||||||
|
if (opt.verbose)
|
||||||
log_info ("p15: disabling extended mode based on TokenInfo\n");
|
log_info ("p15: disabling extended mode based on TokenInfo\n");
|
||||||
app->app_local->no_extended_mode = 1;
|
app->app_local->no_extended_mode = 1;
|
||||||
}
|
}
|
||||||
@ -5027,11 +5032,28 @@ make_pin_prompt (app_t app, int remaining, const char *firstline,
|
|||||||
prkdf_object_t prkdf)
|
prkdf_object_t prkdf)
|
||||||
{
|
{
|
||||||
char *serial, *tmpbuf, *result;
|
char *serial, *tmpbuf, *result;
|
||||||
const char *holder;
|
const char *holder = NULL;
|
||||||
|
|
||||||
serial = get_dispserialno (app, prkdf);
|
serial = get_dispserialno (app, prkdf);
|
||||||
|
|
||||||
if (prkdf && prkdf->common_name)
|
if (app->app_local->card_product == CARD_PRODUCT_GENUA)
|
||||||
|
{
|
||||||
|
/* The label of the first non SO-PIN is used for the holder. */
|
||||||
|
aodf_object_t aodf;
|
||||||
|
|
||||||
|
for (aodf = app->app_local->auth_object_info; aodf; aodf = aodf->next)
|
||||||
|
if (aodf->auth_type == AUTH_TYPE_PIN
|
||||||
|
&& !aodf->pinflags.so_pin
|
||||||
|
&& aodf->label)
|
||||||
|
{
|
||||||
|
holder = aodf->label;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (holder)
|
||||||
|
;
|
||||||
|
else if (prkdf && prkdf->common_name)
|
||||||
holder = prkdf->common_name;
|
holder = prkdf->common_name;
|
||||||
else if (app->app_local->token_label)
|
else if (app->app_local->token_label)
|
||||||
holder = app->app_local->token_label;
|
holder = app->app_local->token_label;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user