summaryrefslogtreecommitdiff
path: root/starmath/source
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2018-01-21 17:51:14 +0000
committerCaolán McNamara <caolanm@redhat.com>2018-01-22 00:45:57 +0100
commitf1d1eb2c647af7b751b024faef09e01d849aacbb (patch)
treefcdb2e4e5929c5a514a11d75fc0ffbec6fb9a927 /starmath/source
parent6763c0ce90825b23a839fac2cd7aede5772c8993 (diff)
ofz#5526 restrict mml parsing depth
Change-Id: Ib74787137112fb8402a2f6400ab4313d43c103dc Reviewed-on: https://gerrit.libreoffice.org/48277 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Caolán McNamara <caolanm@redhat.com> Tested-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'starmath/source')
-rw-r--r--starmath/source/mathmlimport.cxx24
-rw-r--r--starmath/source/mathmlimport.hxx5
2 files changed, 25 insertions, 4 deletions
diff --git a/starmath/source/mathmlimport.cxx b/starmath/source/mathmlimport.cxx
index 032feb61a260..62a705cae930 100644
--- a/starmath/source/mathmlimport.cxx
+++ b/starmath/source/mathmlimport.cxx
@@ -410,7 +410,8 @@ SmXMLImport::SmXMLImport(
const css::uno::Reference< css::uno::XComponentContext >& rContext,
OUString const & implementationName, SvXMLImportFlags nImportFlags)
: SvXMLImport(rContext, implementationName, nImportFlags),
- bSuccess(false)
+ bSuccess(false),
+ nParseDepth(0)
{
}
@@ -536,7 +537,15 @@ class SmXMLImportContext: public SvXMLImportContext
public:
SmXMLImportContext( SmXMLImport &rImport, sal_uInt16 nPrfx,
const OUString& rLName)
- : SvXMLImportContext(rImport, nPrfx, rLName) {}
+ : SvXMLImportContext(rImport, nPrfx, rLName)
+ {
+ GetSmImport().IncParseDepth();
+ }
+
+ virtual ~SmXMLImportContext() override
+ {
+ GetSmImport().DecParseDepth();
+ }
SmXMLImport& GetSmImport()
{
@@ -546,6 +555,12 @@ public:
virtual void TCharacters(const OUString & /*rChars*/);
virtual void Characters(const OUString &rChars) override;
virtual SvXMLImportContextRef CreateChildContext(sal_uInt16 /*nPrefix*/, const OUString& /*rLocalName*/, const uno::Reference< xml::sax::XAttributeList > & /*xAttrList*/) override;
+ virtual void StartElement(const css::uno::Reference<css::xml::sax::XAttributeList>& rAttrList) override
+ {
+ if (GetSmImport().TooDeep())
+ throw std::range_error("too deep");
+ SvXMLImportContext::StartElement(rAttrList);
+ }
};
void SmXMLImportContext::TCharacters(const OUString & /*rChars*/)
@@ -906,7 +921,9 @@ public:
SmXMLRowContext_Impl(SmXMLImport &rImport,sal_uInt16 nPrefix,
const OUString& rLName)
: SmXMLDocContext_Impl(rImport,nPrefix,rLName)
- { nElementCount = GetSmImport().GetNodeStack().size(); }
+ , nElementCount(GetSmImport().GetNodeStack().size())
+ {
+ }
virtual SvXMLImportContextRef CreateChildContext(sal_uInt16 nPrefix, const OUString& rLocalName, const uno::Reference< xml::sax::XAttributeList > &xAttrList) override;
@@ -916,7 +933,6 @@ public:
void EndElement() override;
};
-
class SmXMLEncloseContext_Impl : public SmXMLRowContext_Impl
{
public:
diff --git a/starmath/source/mathmlimport.hxx b/starmath/source/mathmlimport.hxx
index 3d017c1a25a7..a0d2c6254f0c 100644
--- a/starmath/source/mathmlimport.hxx
+++ b/starmath/source/mathmlimport.hxx
@@ -80,6 +80,7 @@ class SmXMLImport : public SvXMLImport
SmNodeStack aNodeStack;
bool bSuccess;
+ int nParseDepth;
OUString aText;
public:
@@ -181,6 +182,10 @@ public:
virtual void SetViewSettings(const css::uno::Sequence<css::beans::PropertyValue>& aViewProps) override;
virtual void SetConfigurationSettings(const css::uno::Sequence<css::beans::PropertyValue>& aViewProps) override;
+
+ void IncParseDepth() { ++nParseDepth; }
+ bool TooDeep() const { return nParseDepth >= 2048; }
+ void DecParseDepth() { --nParseDepth; }
};