PoDoFo 1.2.0
Loading...
Searching...
No Matches
PdfSignerCms.h
1// SPDX-FileCopyrightText: 2023 Francesco Pretto <ceztko@gmail.com>
2// SPDX-License-Identifier: LGPL-2.0-or-later OR MPL-2.0
3
4#ifndef PDF_SIGNER_CMS_H
5#define PDF_SIGNER_CMS_H
6
7#include <chrono>
8#include "PdfSigner.h"
9
10extern "C"
11{
12 // OpenSSL forward declaration
13 struct evp_pkey_st;
14 // libxml2 forward declaration
15 typedef struct _xmlNode xmlNode;
16 typedef xmlNode* xmlNodePtr;
17}
18
19namespace PoDoFo
20{
21 class CmsContext;
22
23 using PdfSigningService = std::function<void(bufferview hashToSign, bool dryrun, charbuff& signedHash)>;
24 using PdfSignedHashHandler = std::function<void(bufferview signedhHash, bool dryrun)>;
25
27 {
28 None = 0,
37 ServiceDoDryRun = 2,
38 };
39
40 struct PODOFO_API PdfSignerCmsParams final
41 {
42 PdfSignatureType SignatureType = PdfSignatureType::PAdES_B;
43 [[deprecated("Encryption should be automatically detected from the public key in the certificate")]]
44 PdfSignatureEncryption Encryption = PdfSignatureEncryption::RSA;
45 PdfHashingAlgorithm Hashing = PdfHashingAlgorithm::SHA256;
46 PdfSigningService SigningService;
47 nullable<std::chrono::seconds> SigningTimeUTC;
48 PdfSignedHashHandler SignedHashHandler;
49 PdfSignerCmsFlags Flags = PdfSignerCmsFlags::None;
50 };
51
53 {
54 None = 0,
58 AsOctetString = 2,
59 };
60
62 class PODOFO_API PdfSignerCms : public PdfSigner
63 {
64 friend class PdfSigningContext;
65 public:
72 const PdfSignerCmsParams& parameters = { });
73
77 PdfSignerCms(const bufferview& cert, const PdfSignerCmsParams& parameters = { });
78
80
81 private:
84
85 public:
86 void AppendData(const bufferview& data) override;
87 void ComputeSignature(charbuff& buffer, bool dryrun) override;
88 void FetchIntermediateResult(charbuff& result) override;
89 void ComputeSignatureDeferred(const bufferview& processedResult, charbuff& contents, bool dryrun) override;
90 void Reset() override;
91 std::string GetSignatureFilter() const override;
92 std::string GetSignatureSubFilter() const override;
93 std::string GetSignatureType() const override;
94 bool SkipBufferClear() const override;
95
99 void AddAttribute(const std::string_view& nid, const bufferview& attr, PdfSignatureAttributeFlags flags = PdfSignatureAttributeFlags::None);
100
103 void ReserveAttributeSize(unsigned attrSize);
104
105 public:
106 unsigned GetSignedHashSize() const;
107
108 const PdfSignerCmsParams& GetParameters() const { return m_parameters; }
109
110 private:
111 // Called by PdfSigningContext
112 void Dump(xmlNodePtr signerElem, std::string& temp);
113 void Restore(xmlNodePtr signerElem, charbuff& temp);
114 private:
115 void ensureEventBasedSigning();
116 void ensureDeferredSigning();
117 void checkContextInitialized();
118 void ensureContextInitialized();
119 void resetContext();
120 void doSign(const bufferview& input, charbuff& output);
121 void tryEnlargeSignatureContents(charbuff& contents);
122 private:
123 nullable<bool> m_deferredSigning;
124 charbuff m_certificate;
125 std::unique_ptr<CmsContext> m_cmsContext;
126 struct evp_pkey_st* m_privKey;
127 PdfSignerCmsParams m_parameters;
128 unsigned m_reservedSize;
129
130 // Temporary buffer variables
131 // NOTE: Don't clear it in Reset() override
132 charbuff m_encryptedHash;
133 };
134}
135
136ENABLE_BITMASK_OPERATORS(PoDoFo::PdfSignerCmsFlags);
137ENABLE_BITMASK_OPERATORS(PoDoFo::PdfSignatureAttributeFlags);
138
139#endif // PDF_SIGNER_CMS_H
This class computes a CMS signature according to RFC 5652.
Definition PdfSignerCms.h:63
A context that can be used to customize the signing process.
Definition PdfSigningContext.h:64
Convenient type for char array storage and/or buffer with std::string compatibility.
Definition basetypes.h:30
All classes, functions, types and enums of PoDoFo are members of these namespace.
Definition basetypes.h:13
PdfSignatureAttributeFlags
Definition PdfSignerCms.h:53
@ SignedAttribute
The input is interpreted as a raw octet string.
@ None
Do not add a default appearance.
cspan< char > bufferview
Convenient read-only char buffer span.
Definition basetypes.h:15
PdfSignerCmsFlags
Definition PdfSignerCms.h:27
@ ServiceDoWrapDigest
When supplying an external PdfSigningService, specify if the service should be called for a dry run.