AusweisApp2
CVCertificateBody.h
gehe zur Dokumentation dieser Datei
1 
5 #pragma once
6 
7 #include "ASN1TemplateUtil.h"
8 #include "ASN1Util.h"
9 #include "Chat.h"
10 #include "EcdsaPublicKey.h"
11 
12 #include <QCryptographicHash>
13 #include <QDate>
14 #include <QMap>
15 #include <QSharedPointer>
16 #include <QString>
17 
18 #include <openssl/ec.h>
19 
20 
21 namespace governikus
22 {
23 
24 using CERTIFICATEEXTENSION = struct CERTIFICATEEXTENSION_st
25 {
26  ASN1_OBJECT* mOid;
27  ASN1_OCTET_STRING* mObject1;
28  ASN1_OCTET_STRING* mObject2;
29  ASN1_OCTET_STRING* mObject3;
30  ASN1_OCTET_STRING* mObject4;
31  ASN1_OCTET_STRING* mObject5;
32  ASN1_OCTET_STRING* mObject6;
33  ASN1_OCTET_STRING* mObject7;
34  ASN1_OCTET_STRING* mObject8;
35 };
36 DECLARE_ASN1_FUNCTIONS(CERTIFICATEEXTENSION)
37 
38 #if OPENSSL_VERSION_NUMBER < 0x10100000L || defined(LIBRESSL_VERSION_NUMBER)
39 DECLARE_STACK_OF(CERTIFICATEEXTENSION)
40 #else
41 DEFINE_STACK_OF(CERTIFICATEEXTENSION)
42 #endif
43 
44 using CVCertificateBody = struct certificateprofilebody_st
45 {
46  ASN1_OCTET_STRING* mCertificateProfileIdentifier;
51  ASN1_OCTET_STRING* mEffectiveDate;
52  ASN1_OCTET_STRING* mExpirationDate;
53  STACK_OF(CERTIFICATEEXTENSION) * mExtensions;
54 
55  static QSharedPointer<certificateprofilebody_st> fromHex(const QString& pHexValue);
56  static QSharedPointer<certificateprofilebody_st> decode(const QByteArray& pBytes);
57  QByteArray encode();
58 
59  QByteArray getCertificateProfileIdentifier() const;
60  QByteArray getCertificationAuthorityReference() const;
61 
62  const EcdsaPublicKey& getPublicKey() const;
63  QByteArray getCertificateHolderReference() const;
64 
65  const CHAT& getCHAT() const;
66 
67  void setCertificateExpirationDate(QDate date);
68  QDate getCertificateExpirationDate() const;
69 
70  void setCertificateEffectiveDate(QDate date);
71  QDate getCertificateEffectiveDate() const;
72 
73  QCryptographicHash::Algorithm getHashAlgorithm() const;
74  QMap<QByteArray, QByteArray> getExtensions() const;
75 };
76 
77 DECLARE_ASN1_FUNCTIONS(CVCertificateBody)
79 
80 } // namespace governikus
struct chat_st { ASN1_OBJECT *mType CHAT
According to.
Definition: Chat.h:67
ASN1_STRING * mCertificationAuthorityReference
Definition: CVCertificateBody.h:47
EcdsaPublicKey * mPublicKey
Definition: CVCertificateBody.h:48
ASN1_OCTET_STRING * mObject5
Definition: CVCertificateBody.h:31
ASN1_STRING * mCertificateHolderReference
Definition: CVCertificateBody.h:49
QByteArray getCertificateHolderReference() const
Definition: CVCertificateBody.cpp:177
const CHAT & getCHAT() const
Definition: CVCertificateBody.cpp:144
QDate getCertificateEffectiveDate() const
Definition: CVCertificateBody.cpp:171
QByteArray getCertificateProfileIdentifier() const
Definition: CVCertificateBody.cpp:125
QByteArray getCertificationAuthorityReference() const
Definition: CVCertificateBody.cpp:131
ASN1_OCTET_STRING * mObject6
Definition: CVCertificateBody.h:32
const EcdsaPublicKey & getPublicKey() const
Definition: CVCertificateBody.cpp:137
CHAT * mChat
Definition: CVCertificateBody.h:50
ASN1_OCTET_STRING * mObject2
Definition: CVCertificateBody.h:28
ASN1_OCTET_STRING * mObject8
Definition: CVCertificateBody.h:34
Implementation of ActivationContext for Intent based activation on Android systems.
Definition: ActivationContext.h:14
QCryptographicHash::Algorithm getHashAlgorithm() const
Definition: CVCertificateBody.cpp:183
ASN1_OCTET_STRING * mEffectiveDate
Definition: CVCertificateBody.h:51
ASN1_OCTET_STRING * mObject4
Definition: CVCertificateBody.h:30
ASN1_OCTET_STRING * mObject1
Definition: CVCertificateBody.h:27
void setCertificateExpirationDate(QDate date)
Definition: CVCertificateBody.cpp:151
void setCertificateEffectiveDate(QDate date)
Definition: CVCertificateBody.cpp:164
#define DECLARE_ASN1_OBJECT(name)
Definition: ASN1TemplateUtil.h:169
STACK_OF(CERTIFICATEEXTENSION) *mExtensions
ASN1_OCTET_STRING * mObject3
Definition: CVCertificateBody.h:29
ASN1_OCTET_STRING * mObject7
Definition: CVCertificateBody.h:33
struct ecdsapublickey_st { ASN1_OBJECT *mObjectIdentifier EcdsaPublicKey
According to TR-03110-3 chapter D elliptic curve public keys are defined as follows:
Definition: EcdsaPublicKey.h:41
struct CERTIFICATEEXTENSION_st { ASN1_OBJECT *mOid CERTIFICATEEXTENSION
Definition: CVCertificateBody.h:26
QByteArray encode() const
QMap< QByteArray, QByteArray > getExtensions() const
Definition: CVCertificateBody.cpp:212
QDate getCertificateExpirationDate() const
Definition: CVCertificateBody.cpp:158
ASN1_OCTET_STRING * mExpirationDate
Definition: CVCertificateBody.h:52
struct certificateprofilebody_st { ASN1_OCTET_STRING *mCertificateProfileIdentifier CVCertificateBody
Definition: CVCertificateBody.h:46