Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(86)

Unified Diff: nss/lib/pk11wrap/pk11pk12.c

Issue 205343004: Add PK11_ExportDERPrivateKeyInfo and PK11_ExportPrivKeyInfo. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/deps/third_party/nss/
Patch Set: Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: nss/lib/pk11wrap/pk11pk12.c
===================================================================
--- nss/lib/pk11wrap/pk11pk12.c (revision 257452)
+++ nss/lib/pk11wrap/pk11pk12.c (working copy)
@@ -18,6 +18,7 @@
#include "secoid.h"
#include "secasn1.h"
#include "secerr.h"
+#include "prerror.h"
eroman 2014/03/20 00:12:04 is there an expected ordering to headers?
wtc 2014/03/22 01:08:00 No. Some NSS headers, like the Unix system headers
@@ -516,3 +517,79 @@
}
+SECItem *
+PK11_ExportDERPrivateKeyInfo(SECKEYPrivateKey *pk, void *wincx)
+{
+ SECKEYPrivateKeyInfo *pki = PK11_ExportPrivKeyInfo(pk, wincx);
+ SECItem *derPKI;
+ derPKI = SEC_ASN1EncodeItem(NULL, NULL, pki,
+ SECKEY_PrivateKeyInfoTemplate);
+ SECKEY_DestroyPrivateKeyInfo(pki, PR_TRUE);
+ return derPKI;
+}
+
+static PRBool
+ReadAttribute(SECKEYPrivateKey* key, CK_ATTRIBUTE_TYPE type,
+ PLArenaPool* arena, SECItem* output)
+{
+ SECStatus rv = PK11_ReadAttribute(key->pkcs11Slot, key->pkcs11ID, type,
+ arena, output);
+ return rv == SECSuccess;
+}
+
+SECKEYPrivateKeyInfo *
+PK11_ExportPrivKeyInfo(SECKEYPrivateKey *pk, void *wincx)
+{
+ /* PrivateKeyInfo version (always zero) */
+ static const unsigned char pkiVersion = 0;
+ /* RSAPrivateKey version (always zero) */
+ static const unsigned char rsaVersion = 0;
+ PLArenaPool *arena;
+ SECKEYRawPrivateKey *rawKey;
+ SECKEYPrivateKeyInfo *pki;
+ SECItem *encoded;
+ SECStatus rv;
+
+ if (pk->keyType != rsaKey) {
+ PORT_SetError(PR_NOT_IMPLEMENTED_ERROR);
+ return NULL;
+ }
+
+ arena = PORT_NewArena(DER_DEFAULT_CHUNKSIZE);
+ rawKey = PORT_ArenaZNew(arena, SECKEYRawPrivateKey);
eroman 2014/03/20 00:12:04 why allocate rawKey using arena rather than stack?
Ryan Sleevi 2014/03/20 01:24:27 More importantly, this strikes me as a bit inconsi
wtc 2014/03/22 01:08:00 I may have copied this code from some other functi
+ rawKey->keyType = pk->keyType;
+ rawKey->u.rsa.version.type = siUnsignedInteger;
+ rawKey->u.rsa.version.data = &rsaVersion;
+ rawKey->u.rsa.version.len = 1;
+
+ /* Read the component attributes of the private key */
+ prepare_rsa_priv_key_export_for_asn1(rawKey);
eroman 2014/03/20 00:12:04 What guarantees does PK11_ReadAttribute give? I wo
wtc 2014/03/22 01:08:00 PK11_ReadAttribute doesn't modify the SECItem's ty
+ if (!ReadAttribute(pk, CKA_MODULUS, arena, &rawKey->u.rsa.modulus) ||
+ !ReadAttribute(pk, CKA_PUBLIC_EXPONENT, arena,
+ &rawKey->u.rsa.publicExponent) ||
+ !ReadAttribute(pk, CKA_PRIVATE_EXPONENT, arena,
+ &rawKey->u.rsa.privateExponent) ||
+ !ReadAttribute(pk, CKA_PRIME_1, arena, &rawKey->u.rsa.prime1) ||
+ !ReadAttribute(pk, CKA_PRIME_2, arena, &rawKey->u.rsa.prime2) ||
+ !ReadAttribute(pk, CKA_EXPONENT_1, arena,
+ &rawKey->u.rsa.exponent1) ||
+ !ReadAttribute(pk, CKA_EXPONENT_2, arena,
+ &rawKey->u.rsa.exponent2) ||
+ !ReadAttribute(pk, CKA_COEFFICIENT, arena,
+ &rawKey->u.rsa.coefficient)) {
+ PORT_FreeArena(arena, PR_TRUE);
+ return NULL;
+ }
eroman 2014/03/20 00:12:04 Is it worth calling out that the PrivateKeyInfo's
Ryan Sleevi 2014/03/20 01:24:27 nah
+
+ pki = PORT_ArenaZNew(arena, SECKEYPrivateKeyInfo);
+ encoded = SEC_ASN1EncodeItem(arena, &pki->privateKey, rawKey,
eroman 2014/03/20 00:12:04 Should you check the return value for success?
Ryan Sleevi 2014/03/20 01:24:27 +1
wtc 2014/03/22 01:08:00 Done.
+ SECKEY_RSAPrivateKeyExportTemplate);
+ rv = SECOID_SetAlgorithmID(arena, &pki->algorithm,
+ SEC_OID_PKCS1_RSA_ENCRYPTION, NULL);
+ pki->version.type = siUnsignedInteger;
+ pki->version.data = &pkiVersion;
eroman 2014/03/20 00:23:35 I found this a bit subtle, but maybe it is in line
Ryan Sleevi 2014/03/20 01:24:27 I have to agree with Eric, that this strikes me as
wtc 2014/03/22 01:08:00 Done.
+ pki->version.len = 1;
+ pki->arena = arena;
eroman 2014/03/20 00:12:04 Apologies for lack of NSS foo: does this mean the
Ryan Sleevi 2014/03/20 01:24:27 Not directly, but through using SECKEY_DestroyPriv
+
+ return pki;
+}

Powered by Google App Engine
This is Rietveld 408576698