summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlbert Astals Cid <aacid@kde.org>2021-03-09 17:53:00 +0100
committerAlbert Astals Cid <aacid@kde.org>2021-03-09 17:53:00 +0100
commit59d5036451cc55f57e15e4ae1538024c62452978 (patch)
tree5f49988be252d108427e57111a943a8d4ca5031d
parentce1fcd4352f920a59d965310440be18ff48acb8f (diff)
qt: Fix crash in files with malformed signatures
For signatures we need the formwidget, so even if they don't have the Subtype Widget create one when asked for signatures in the document Fixes KDE bug #433909
-rw-r--r--poppler/Form.cc12
-rw-r--r--poppler/Form.h2
-rw-r--r--qt5/src/poppler-document.cc2
-rw-r--r--qt6/src/poppler-document.cc2
4 files changed, 16 insertions, 2 deletions
diff --git a/poppler/Form.cc b/poppler/Form.cc
index 9937eefd..4d42aedf 100644
--- a/poppler/Form.cc
+++ b/poppler/Form.cc
@@ -1975,6 +1975,18 @@ void FormFieldSignature::setCertificateInfo(std::unique_ptr<X509CertificateInfo>
certificate_info.swap(certInfo);
}
+FormWidget *FormFieldSignature::getCreateWidget()
+{
+ ::FormWidget *fw = getWidget(0);
+ if (!fw) {
+ error(errSyntaxError, 0, "FormFieldSignature: was asked for widget and didn't had one, creating it");
+ _createWidget(&obj, ref);
+ fw = getWidget(0);
+ fw->createWidgetAnnotation();
+ }
+ return fw;
+}
+
void FormFieldSignature::parseInfo()
{
if (!obj.isDict())
diff --git a/poppler/Form.h b/poppler/Form.h
index dcf89760..247fc141 100644
--- a/poppler/Form.h
+++ b/poppler/Form.h
@@ -617,6 +617,8 @@ public:
void setCertificateInfo(std::unique_ptr<X509CertificateInfo> &);
+ FormWidget *getCreateWidget();
+
private:
void parseInfo();
void hashSignedDataBlock(SignatureHandler *handler, Goffset block_len);
diff --git a/qt5/src/poppler-document.cc b/qt5/src/poppler-document.cc
index 0a2a6ce4..c7d38be2 100644
--- a/qt5/src/poppler-document.cc
+++ b/qt5/src/poppler-document.cc
@@ -825,7 +825,7 @@ QVector<FormFieldSignature *> Document::signatures() const
const std::vector<::FormFieldSignature *> pSignatures = m_doc->doc->getSignatureFields();
for (::FormFieldSignature *pSignature : pSignatures) {
- ::FormWidget *fw = pSignature->getWidget(0);
+ ::FormWidget *fw = pSignature->getCreateWidget();
::Page *p = m_doc->doc->getPage(fw->getWidgetAnnotation()->getPageNum());
result.append(new FormFieldSignature(m_doc, p, static_cast<FormWidgetSignature *>(fw)));
}
diff --git a/qt6/src/poppler-document.cc b/qt6/src/poppler-document.cc
index 1a13d46d..150cca0a 100644
--- a/qt6/src/poppler-document.cc
+++ b/qt6/src/poppler-document.cc
@@ -807,7 +807,7 @@ QVector<FormFieldSignature *> Document::signatures() const
const std::vector<::FormFieldSignature *> pSignatures = m_doc->doc->getSignatureFields();
for (::FormFieldSignature *pSignature : pSignatures) {
- ::FormWidget *fw = pSignature->getWidget(0);
+ ::FormWidget *fw = pSignature->getCreateWidget();
::Page *p = m_doc->doc->getPage(fw->getWidgetAnnotation()->getPageNum());
result.append(new FormFieldSignature(m_doc, p, static_cast<FormWidgetSignature *>(fw)));
}