Blame SOURCES/qpdf-relax.patch

68374e
diff -up qpdf-10.2.0/libqpdf/QPDF.cc.relax qpdf-10.2.0/libqpdf/QPDF.cc
68374e
--- qpdf-10.2.0/libqpdf/QPDF.cc.relax	2021-02-23 16:41:58.000000000 +0100
68374e
+++ qpdf-10.2.0/libqpdf/QPDF.cc	2021-02-24 12:35:50.715329461 +0100
68374e
@@ -11,6 +11,10 @@
68374e
 #include <string.h>
68374e
 #include <memory.h>
68374e
 
68374e
+#ifdef HAVE_GNUTLS
68374e
+# include <gnutls/crypto.h>
68374e
+#endif
68374e
+
68374e
 #include <qpdf/QTC.hh>
68374e
 #include <qpdf/QUtil.hh>
68374e
 #include <qpdf/Pipeline.hh>
68374e
@@ -261,7 +265,13 @@ QPDF::processFile(char const* filename,
68374e
 {
68374e
     FileInputSource* fi = new FileInputSource();
68374e
     fi->setFilename(filename);
68374e
+#ifdef HAVE_GNUTLS
68374e
+    GNUTLS_FIPS140_SET_LAX_MODE();
68374e
+#endif
68374e
     processInputSource(fi, password);
68374e
+#ifdef HAVE_GNUTLS
68374e
+    GNUTLS_FIPS140_SET_STRICT_MODE();
68374e
+#endif
68374e
 }
68374e
 
68374e
 void
68374e
@@ -270,7 +280,13 @@ QPDF::processFile(char const* descriptio
68374e
 {
68374e
     FileInputSource* fi = new FileInputSource();
68374e
     fi->setFile(description, filep, close_file);
68374e
+#ifdef HAVE_GNUTLS
68374e
+    GNUTLS_FIPS140_SET_LAX_MODE();
68374e
+#endif
68374e
     processInputSource(fi, password);
68374e
+#ifdef HAVE_GNUTLS
68374e
+    GNUTLS_FIPS140_SET_STRICT_MODE();
68374e
+#endif
68374e
 }
68374e
 
68374e
 void
68374e
diff -up qpdf-10.2.0/libqpdf/QPDF_encryption.cc.relax qpdf-10.2.0/libqpdf/QPDF_encryption.cc
68374e
--- qpdf-10.2.0/libqpdf/QPDF_encryption.cc.relax	2021-02-23 16:41:58.000000000 +0100
68374e
+++ qpdf-10.2.0/libqpdf/QPDF_encryption.cc	2021-02-24 12:37:17.267561185 +0100
68374e
@@ -1,6 +1,8 @@
68374e
 // This file implements methods from the QPDF class that involve
68374e
 // encryption.
68374e
 
68374e
+#include <qpdf/qpdf-config.h>
68374e
+
68374e
 #include <qpdf/QPDF.hh>
68374e
 
68374e
 #include <qpdf/QPDFExc.hh>
68374e
@@ -18,6 +20,10 @@
68374e
 #include <assert.h>
68374e
 #include <string.h>
68374e
 
68374e
+#ifdef HAVE_GNUTLS
68374e
+# include <gnutls/crypto.h>
68374e
+#endif
68374e
+
68374e
 static unsigned char const padding_string[] = {
68374e
     0x28, 0xbf, 0x4e, 0x5e, 0x4e, 0x75, 0x8a, 0x41,
68374e
     0x64, 0x00, 0x4e, 0x56, 0xff, 0xfa, 0x01, 0x08,
68374e
@@ -1150,6 +1156,12 @@ QPDF::getKeyForObject(
68374e
 void
68374e
 QPDF::decryptString(std::string& str, int objid, int generation)
68374e
 {
68374e
+#ifdef HAVE_GNUTLS
68374e
+    unsigned oldmode = gnutls_fips140_mode_enabled();
68374e
+
68374e
+    gnutls_fips140_set_mode(GNUTLS_FIPS140_LAX, GNUTLS_FIPS140_SET_MODE_THREAD);
68374e
+#endif
68374e
+
68374e
     if (objid == 0)
68374e
     {
68374e
 	return;
68374e
@@ -1230,6 +1242,10 @@ QPDF::decryptString(std::string& str, in
68374e
 		      QUtil::int_to_string(objid) + " " +
68374e
 		      QUtil::int_to_string(generation) + ": " + e.what());
68374e
     }
68374e
+
68374e
+#ifdef HAVE_GNUTLS
68374e
+    gnutls_fips140_set_mode(static_cast<gnutls_fips_mode_t>(oldmode), GNUTLS_FIPS140_SET_MODE_THREAD);
68374e
+#endif
68374e
 }
68374e
 
68374e
 void
68374e
@@ -1240,6 +1256,12 @@ QPDF::decryptStream(PointerHolder
68374e
 		    QPDFObjectHandle& stream_dict,
68374e
 		    std::vector<PointerHolder<Pipeline> >& heap)
68374e
 {
68374e
+#ifdef HAVE_GNUTLS
68374e
+    unsigned oldmode = gnutls_fips140_mode_enabled();
68374e
+
68374e
+    gnutls_fips140_set_mode(GNUTLS_FIPS140_LAX, GNUTLS_FIPS140_SET_MODE_THREAD);
68374e
+#endif
68374e
+
68374e
     std::string type;
68374e
     if (stream_dict.getKey("/Type").isName())
68374e
     {
68374e
@@ -1361,6 +1383,10 @@ QPDF::decryptStream(PointerHolder
68374e
                               toI(key.length()));
68374e
     }
68374e
     heap.push_back(pipeline);
68374e
+
68374e
+#ifdef HAVE_GNUTLS
68374e
+    gnutls_fips140_set_mode(static_cast<gnutls_fips_mode_t>(oldmode), GNUTLS_FIPS140_SET_MODE_THREAD);
68374e
+#endif
68374e
 }
68374e
 
68374e
 void
68374e
diff -up qpdf-10.2.0/libqpdf/QPDFWriter.cc.relax qpdf-10.2.0/libqpdf/QPDFWriter.cc
68374e
--- qpdf-10.2.0/libqpdf/QPDFWriter.cc.relax	2021-02-23 16:41:58.000000000 +0100
68374e
+++ qpdf-10.2.0/libqpdf/QPDFWriter.cc	2021-02-24 12:35:50.716329452 +0100
68374e
@@ -24,6 +24,10 @@
68374e
 #include <algorithm>
68374e
 #include <stdlib.h>
68374e
 
68374e
+#ifdef HAVE_GNUTLS
68374e
+#include <gnutls/crypto.h>
68374e
+#endif
68374e
+
68374e
 QPDFWriter::Members::Members(QPDF& pdf) :
68374e
     pdf(pdf),
68374e
     filename("unspecified"),
68374e
@@ -321,6 +325,13 @@ void
68374e
 QPDFWriter::setDeterministicID(bool val)
68374e
 {
68374e
     this->m->deterministic_id = val;
68374e
+
68374e
+#ifdef HAVE_GNUTLS
68374e
+    if (val)
68374e
+	GNUTLS_FIPS140_SET_LAX_MODE();
68374e
+    else
68374e
+	GNUTLS_FIPS140_SET_STRICT_MODE();
68374e
+#endif
68374e
 }
68374e
 
68374e
 void
68374e
@@ -342,6 +353,13 @@ void
68374e
 QPDFWriter::setPreserveEncryption(bool val)
68374e
 {
68374e
     this->m->preserve_encryption = val;
68374e
+
68374e
+#ifdef HAVE_GNUTLS
68374e
+    if (val)
68374e
+	GNUTLS_FIPS140_SET_STRICT_MODE();
68374e
+    else
68374e
+	GNUTLS_FIPS140_SET_LAX_MODE();
68374e
+#endif
68374e
 }
68374e
 
68374e
 void