You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.3 KiB
69 lines
2.3 KiB
6 years ago
|
From a4b6b9630eb2ee684bbf1560a93b3075c7eb58ab Mon Sep 17 00:00:00 2001
|
||
|
From: Jakub Jelen <jjelen@redhat.com>
|
||
|
Date: Tue, 4 Jul 2017 14:25:50 +0200
|
||
|
Subject: [PATCH] [coolkey] Copy labels from certificate objects to the keys
|
||
|
|
||
|
---
|
||
|
src/libopensc/pkcs15-coolkey.c | 33 ++++++++++++++++++++++++++++++++-
|
||
|
1 file changed, 32 insertions(+), 1 deletion(-)
|
||
|
|
||
|
diff --git a/src/libopensc/pkcs15-coolkey.c b/src/libopensc/pkcs15-coolkey.c
|
||
|
index 5064a0f4f..a5f457acd 100644
|
||
|
--- a/src/libopensc/pkcs15-coolkey.c
|
||
|
+++ b/src/libopensc/pkcs15-coolkey.c
|
||
|
@@ -484,7 +484,7 @@ static int sc_pkcs15emu_coolkey_init(sc_pkcs15_card_t *p15card)
|
||
|
sc_card_t *card = p15card->card;
|
||
|
sc_serial_number_t serial;
|
||
|
int count;
|
||
|
-
|
||
|
+ struct sc_pkcs15_object *obj;
|
||
|
|
||
|
SC_FUNC_CALLED(card->ctx, SC_LOG_DEBUG_VERBOSE);
|
||
|
|
||
|
@@ -558,6 +558,8 @@ static int sc_pkcs15emu_coolkey_init(sc_pkcs15_card_t *p15card)
|
||
|
|
||
|
|
||
|
memset(&obj_obj, 0, sizeof(obj_obj));
|
||
|
+ /* coolkey applets have label only on the certificates,
|
||
|
+ * but we should copy it also to the keys maching the same ID */
|
||
|
coolkey_get_attribute_bytes(card, &coolkey_obj, CKA_LABEL, (u8 *)obj_obj.label, &len, sizeof(obj_obj.label));
|
||
|
coolkey_get_flags(card, &coolkey_obj, &obj_obj.flags);
|
||
|
if (obj_obj.flags & SC_PKCS15_CO_FLAG_PRIVATE) {
|
||
|
@@ -677,6 +679,35 @@ static int sc_pkcs15emu_coolkey_init(sc_pkcs15_card_t *p15card)
|
||
|
}
|
||
|
r = (card->ops->card_ctl)(card, SC_CARDCTL_COOLKEY_FINAL_GET_OBJECTS, &count);
|
||
|
|
||
|
+ /* Iterate over all the created objects and fill missing labels */
|
||
|
+ for (obj = p15card->obj_list; obj != NULL; obj = obj->next) {
|
||
|
+ struct sc_pkcs15_id *id = NULL;
|
||
|
+ struct sc_pkcs15_object *cert_object;
|
||
|
+
|
||
|
+ /* label non-empty -- do not overwrite */
|
||
|
+ if (obj->label[0] != '\0')
|
||
|
+ continue;
|
||
|
+
|
||
|
+ switch (obj->type & SC_PKCS15_TYPE_CLASS_MASK) {
|
||
|
+ case SC_PKCS15_TYPE_PUBKEY:
|
||
|
+ id = &((struct sc_pkcs15_pubkey_info *)obj->data)->id;
|
||
|
+ break;
|
||
|
+ case SC_PKCS15_TYPE_PRKEY:
|
||
|
+ id = &((struct sc_pkcs15_prkey_info *)obj->data)->id;
|
||
|
+ break;
|
||
|
+ default:
|
||
|
+ /* We do not care about other objects */
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+ r = sc_pkcs15_find_cert_by_id(p15card, id, &cert_object);
|
||
|
+ if (r != 0)
|
||
|
+ continue;
|
||
|
+
|
||
|
+ sc_log(card->ctx, "Copy label \"%s\" from cert to key object",
|
||
|
+ cert_object->label);
|
||
|
+ memcpy(obj->label, cert_object->label, SC_PKCS15_MAX_LABEL_SIZE);
|
||
|
+ }
|
||
|
+
|
||
|
LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
|
||
|
}
|
||
|
|
||
|
|