From 2c9f4c6a5e1a9ce5ef501c8f5a7f5cd421bf86f7 Mon Sep 17 00:00:00 2001 From: Miklos Vajna Date: Tue, 24 Nov 2020 21:03:59 +0100 Subject: pdfium: add sig getters: ByteRange, DocMDPPermission, Contents and SubFilter Change-Id: Ieab577de92898568e27a879af1ca1bda170a307d Reviewed-on: https://gerrit.libreoffice.org/c/core/+/106554 Tested-by: Jenkins Reviewed-by: Miklos Vajna --- xmlsecurity/source/helper/pdfsignaturehelper.cxx | 27 ++++++------------------ 1 file changed, 7 insertions(+), 20 deletions(-) (limited to 'xmlsecurity') diff --git a/xmlsecurity/source/helper/pdfsignaturehelper.cxx b/xmlsecurity/source/helper/pdfsignaturehelper.cxx index a9ab7a84546c..062dba819adf 100644 --- a/xmlsecurity/source/helper/pdfsignaturehelper.cxx +++ b/xmlsecurity/source/helper/pdfsignaturehelper.cxx @@ -132,16 +132,13 @@ struct Signature void GetByteRangesFromPDF(std::unique_ptr& pSignature, std::vector>& rByteRanges) { - int nByteRangeLen = FPDFSignatureObj_GetByteRange(pSignature->getPointer(), nullptr, 0); - if (nByteRangeLen <= 0) + std::vector aByteRange = pSignature->getByteRange(); + if (aByteRange.empty()) { SAL_WARN("xmlsecurity.helper", "GetByteRangesFromPDF: no byte ranges"); return; } - std::vector aByteRange(nByteRangeLen); - FPDFSignatureObj_GetByteRange(pSignature->getPointer(), aByteRange.data(), aByteRange.size()); - size_t nByteRangeOffset = 0; for (size_t i = 0; i < aByteRange.size(); ++i) { @@ -183,7 +180,7 @@ int GetMDPPerm(const std::vector& rSignatures) for (const auto& rSignature : rSignatures) { - int nPerm = FPDFSignatureObj_GetDocMDPPermission(rSignature.m_pSignature->getPointer()); + int nPerm = rSignature.m_pSignature->getDocMDPPermission(); if (nPerm != 0) { return nPerm; @@ -346,24 +343,14 @@ bool ValidateSignature(SvStream& rStream, const Signature& rSignature, const std::set& rSignatureEOFs, const std::vector& rTrailerEnds) { - int nContentsLen - = FPDFSignatureObj_GetContents(rSignature.m_pSignature->getPointer(), nullptr, 0); - if (nContentsLen <= 0) + std::vector aContents = rSignature.m_pSignature->getContents(); + if (aContents.empty()) { SAL_WARN("xmlsecurity.helper", "ValidateSignature: no contents"); return false; } - std::vector aContents(nContentsLen); - FPDFSignatureObj_GetContents(rSignature.m_pSignature->getPointer(), aContents.data(), - aContents.size()); - - int nSubFilterLen - = FPDFSignatureObj_GetSubFilter(rSignature.m_pSignature->getPointer(), nullptr, 0); - std::vector aSubFilterBuf(nSubFilterLen); - FPDFSignatureObj_GetSubFilter(rSignature.m_pSignature->getPointer(), aSubFilterBuf.data(), - aSubFilterBuf.size()); - // Buffer is NUL-terminated. - OString aSubFilter(aSubFilterBuf.data(), aSubFilterBuf.size() - 1); + + OString aSubFilter = rSignature.m_pSignature->getSubFilter(); const bool bNonDetached = aSubFilter == "adbe.pkcs7.sha1"; if (aSubFilter.isEmpty() -- cgit