Blame SOURCES/qpdf-relax.patch

b2b716
diff --git a/libqpdf/QPDF.cc b/libqpdf/QPDF.cc
b2b716
index 3475afe..f93ba0d 100644
b2b716
--- a/libqpdf/QPDF.cc
b2b716
+++ b/libqpdf/QPDF.cc
b2b716
@@ -19,6 +19,10 @@
b2b716
 #include <qpdf/QPDF_Null.hh>
b2b716
 #include <qpdf/QPDF_Dictionary.hh>
b2b716
 
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+# include <gnutls/crypto.h>
b2b716
+#endif
b2b716
+
b2b716
 std::string QPDF::qpdf_version = "7.1.1";
b2b716
 
b2b716
 static char const* EMPTY_PDF =
b2b716
@@ -139,7 +143,13 @@ QPDF::processFile(char const* filename, char const* password)
b2b716
 {
b2b716
     FileInputSource* fi = new FileInputSource();
b2b716
     fi->setFilename(filename);
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    GNUTLS_FIPS140_SET_LAX_MODE();
b2b716
+#endif
b2b716
     processInputSource(fi, password);
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    GNUTLS_FIPS140_SET_STRICT_MODE();
b2b716
+#endif
b2b716
 }
b2b716
 
b2b716
 void
b2b716
@@ -148,7 +158,13 @@ QPDF::processFile(char const* description, FILE* filep,
b2b716
 {
b2b716
     FileInputSource* fi = new FileInputSource();
b2b716
     fi->setFile(description, filep, close_file);
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    GNUTLS_FIPS140_SET_LAX_MODE();
b2b716
+#endif
b2b716
     processInputSource(fi, password);
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    GNUTLS_FIPS140_SET_STRICT_MODE();
b2b716
+#endif
b2b716
 }
b2b716
 
b2b716
 void
b2b716
diff --git a/libqpdf/QPDFWriter.cc b/libqpdf/QPDFWriter.cc
b2b716
index 0544640..48fe50d 100644
b2b716
--- a/libqpdf/QPDFWriter.cc
b2b716
+++ b/libqpdf/QPDFWriter.cc
b2b716
@@ -23,6 +23,10 @@
b2b716
 #include <algorithm>
b2b716
 #include <stdlib.h>
b2b716
 
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+#include <gnutls/crypto.h>
b2b716
+#endif
b2b716
+
b2b716
 QPDFWriter::Members::Members(QPDF& pdf) :
b2b716
     pdf(pdf),
b2b716
     filename(0),
b2b716
@@ -323,6 +327,13 @@ void
b2b716
 QPDFWriter::setDeterministicID(bool val)
b2b716
 {
b2b716
     this->m->deterministic_id = val;
b2b716
+
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    if (val)
b2b716
+	GNUTLS_FIPS140_SET_LAX_MODE();
b2b716
+    else
b2b716
+	GNUTLS_FIPS140_SET_STRICT_MODE();
b2b716
+#endif
b2b716
 }
b2b716
 
b2b716
 void
b2b716
@@ -344,6 +355,13 @@ void
b2b716
 QPDFWriter::setPreserveEncryption(bool val)
b2b716
 {
b2b716
     this->m->preserve_encryption = val;
b2b716
+
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    if (val)
b2b716
+	GNUTLS_FIPS140_SET_STRICT_MODE();
b2b716
+    else
b2b716
+	GNUTLS_FIPS140_SET_LAX_MODE();
b2b716
+#endif
b2b716
 }
b2b716
 
b2b716
 void
b2b716
diff --git a/libqpdf/QPDF_encryption.cc b/libqpdf/QPDF_encryption.cc
b2b716
index fd717c3..9b38914 100644
b2b716
--- a/libqpdf/QPDF_encryption.cc
b2b716
+++ b/libqpdf/QPDF_encryption.cc
b2b716
@@ -1,6 +1,8 @@
b2b716
 // This file implements methods from the QPDF class that involve
b2b716
 // encryption.
b2b716
 
b2b716
+#include <qpdf/qpdf-config.h>
b2b716
+
b2b716
 #include <qpdf/QPDF.hh>
b2b716
 
b2b716
 #include <qpdf/QPDFExc.hh>
b2b716
@@ -18,6 +20,10 @@
b2b716
 #include <assert.h>
b2b716
 #include <string.h>
b2b716
 
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+# include <gnutls/crypto.h>
b2b716
+#endif
b2b716
+
b2b716
 static unsigned char const padding_string[] = {
b2b716
     0x28, 0xbf, 0x4e, 0x5e, 0x4e, 0x75, 0x8a, 0x41,
b2b716
     0x64, 0x00, 0x4e, 0x56, 0xff, 0xfa, 0x01, 0x08,
b2b716
@@ -1084,6 +1090,12 @@ QPDF::getKeyForObject(int objid, int generation, bool use_aes)
b2b716
 void
b2b716
 QPDF::decryptString(std::string& str, int objid, int generation)
b2b716
 {
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    unsigned oldmode = gnutls_fips140_mode_enabled();
b2b716
+
b2b716
+    gnutls_fips140_set_mode(GNUTLS_FIPS140_LAX, GNUTLS_FIPS140_SET_MODE_THREAD);
b2b716
+#endif
b2b716
+
b2b716
     if (objid == 0)
b2b716
     {
b2b716
 	return;
b2b716
@@ -1162,6 +1174,10 @@ QPDF::decryptString(std::string& str, int objid, int generation)
b2b716
 		      QUtil::int_to_string(objid) + " " +
b2b716
 		      QUtil::int_to_string(generation) + ": " + e.what());
b2b716
     }
b2b716
+
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    gnutls_fips140_set_mode(static_cast<gnutls_fips_mode_t>(oldmode), GNUTLS_FIPS140_SET_MODE_THREAD);
b2b716
+#endif
b2b716
 }
b2b716
 
b2b716
 void
b2b716
@@ -1169,6 +1185,12 @@ QPDF::decryptStream(Pipeline*& pipeline, int objid, int generation,
b2b716
 		    QPDFObjectHandle& stream_dict,
b2b716
 		    std::vector<PointerHolder<Pipeline> >& heap)
b2b716
 {
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    unsigned oldmode = gnutls_fips140_mode_enabled();
b2b716
+
b2b716
+    gnutls_fips140_set_mode(GNUTLS_FIPS140_LAX, GNUTLS_FIPS140_SET_MODE_THREAD);
b2b716
+#endif
b2b716
+
b2b716
     std::string type;
b2b716
     if (stream_dict.getKey("/Type").isName())
b2b716
     {
b2b716
@@ -1297,6 +1319,10 @@ QPDF::decryptStream(Pipeline*& pipeline, int objid, int generation,
b2b716
                               key.length());
b2b716
     }
b2b716
     heap.push_back(pipeline);
b2b716
+
b2b716
+#ifdef HAVE_GNUTLS
b2b716
+    gnutls_fips140_set_mode(static_cast<gnutls_fips_mode_t>(oldmode), GNUTLS_FIPS140_SET_MODE_THREAD);
b2b716
+#endif
b2b716
 }
b2b716
 
b2b716
 void