Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qtlskey_base.cpp
Go to the documentation of this file.
1// Copyright (C) 2021 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#include "qtlskey_base_p.h"
5#include "qasn1element_p.h"
6
8
9namespace QTlsPrivate {
10
11QByteArray TlsKeyBase::pemFromDer(const QByteArray &der, const QMap<QByteArray, QByteArray> &headers) const
12{
13 QByteArray pem(der.toBase64());
14
15 const int lineWidth = 64; // RFC 1421
16 const int newLines = pem.size() / lineWidth;
17 const bool rem = pem.size() % lineWidth;
18
19 for (int i = 0; i < newLines; ++i)
20 pem.insert((i + 1) * lineWidth + i, '\n');
21 if (rem)
22 pem.append('\n');
23
24 QByteArray extra;
25 if (!headers.isEmpty()) {
27 do {
28 --it;
29 extra += it.key() + ": " + it.value() + '\n';
30 } while (it != headers.constBegin());
31 extra += '\n';
32 }
33
34 if (isEncryptedPkcs8(der)) {
35 pem.prepend(pkcs8Header(true) + '\n' + extra);
36 pem.append(pkcs8Footer(true) + '\n');
37 } else if (isPkcs8()) {
38 pem.prepend(pkcs8Header(false) + '\n' + extra);
39 pem.append(pkcs8Footer(false) + '\n');
40 } else {
41 pem.prepend(pemHeader() + '\n' + extra);
42 pem.append(pemFooter() + '\n');
43 }
44
45 return pem;
46}
47
49{
50 return encrypted
51 ? QByteArrayLiteral("-----BEGIN ENCRYPTED PRIVATE KEY-----")
52 : QByteArrayLiteral("-----BEGIN PRIVATE KEY-----");
53}
54
56{
57 return encrypted
58 ? QByteArrayLiteral("-----END ENCRYPTED PRIVATE KEY-----")
59 : QByteArrayLiteral("-----END PRIVATE KEY-----");
60}
61
63{
64 static const QList<QByteArray> pbes1OIds {
65 // PKCS5
68 };
69 QAsn1Element elem;
70 if (!elem.read(der) || elem.type() != QAsn1Element::SequenceType)
71 return false;
72
73 const auto items = elem.toList();
74 if (items.size() != 2
75 || items[0].type() != QAsn1Element::SequenceType
76 || items[1].type() != QAsn1Element::OctetStringType) {
77 return false;
78 }
79
80 const auto encryptionSchemeContainer = items[0].toList();
81 if (encryptionSchemeContainer.size() != 2
82 || encryptionSchemeContainer[0].type() != QAsn1Element::ObjectIdentifierType
83 || encryptionSchemeContainer[1].type() != QAsn1Element::SequenceType) {
84 return false;
85 }
86
87 const QByteArray encryptionScheme = encryptionSchemeContainer[0].toObjectId();
88 return encryptionScheme == PKCS5_PBES2_ENCRYPTION_OID
89 || pbes1OIds.contains(encryptionScheme)
90 || encryptionScheme.startsWith(PKCS12_OID);
91}
92
93} // namespace QTlsPrivate
94
96
97
\inmodule QtCore
Definition qbytearray.h:57
QByteArray & prepend(char c)
This is an overloaded member function, provided for convenience. It differs from the above function o...
Definition qbytearray.h:280
QByteArray & append(char c)
This is an overloaded member function, provided for convenience. It differs from the above function o...
qsizetype size() const noexcept
Definition qlist.h:397
QList< T > toList() const noexcept
Definition qlist.h:723
bool isPkcs8() const override
QByteArray pemFromDer(const QByteArray &der, const QMap< QByteArray, QByteArray > &headers) const override
static bool isEncryptedPkcs8(const QByteArray &der)
static QByteArray pkcs8Footer(bool encrypted)
static QByteArray pkcs8Header(bool encrypted)
QByteArray pemHeader() const
QByteArray pemFooter() const
QSet< QString >::iterator it
Combined button and popup list for selecting options.
Namespace containing onternal types that TLS backends implement.
#define PKCS5_MD2_DES_CBC_OID
#define PKCS5_MD5_DES_CBC_OID
#define PKCS12_OID
#define PKCS5_PBES2_ENCRYPTION_OID
#define PKCS5_SHA1_RC2_CBC_OID
#define PKCS5_MD2_RC2_CBC_OID
#define PKCS5_MD5_RC2_CBC_OID
#define PKCS5_SHA1_DES_CBC_OID
#define QByteArrayLiteral(str)
Definition qbytearray.h:52
QList< QTreeWidgetItem * > items