parent
68b750cb87
commit
24f9c388ba
File diff suppressed because it is too large
Load Diff
@ -1,55 +0,0 @@
|
|||||||
From 264824628f58a1668b54252babb1add4d3c7eb79 Mon Sep 17 00:00:00 2001
|
|
||||||
From: David Tardon <dtardon@redhat.com>
|
|
||||||
Date: Mon, 8 Apr 2013 14:07:23 +0200
|
|
||||||
Subject: [PATCH 1/3] rhbz#918079 always return 40 hexa digits (cherry picked
|
|
||||||
from commit 8e66145d204f7d053549b7cc28aef6863cfd38c8)
|
|
||||||
|
|
||||||
---
|
|
||||||
src/libcmis/test-xmlutils.cxx | 12 ++++++++++--
|
|
||||||
src/libcmis/xml-utils.cxx | 6 +++++-
|
|
||||||
2 files changed, 15 insertions(+), 3 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/libcmis/test-xmlutils.cxx b/src/libcmis/test-xmlutils.cxx
|
|
||||||
index dd5082f..0e527ad 100644
|
|
||||||
--- a/src/libcmis/test-xmlutils.cxx
|
|
||||||
+++ b/src/libcmis/test-xmlutils.cxx
|
|
||||||
@@ -431,8 +431,16 @@ void XmlTest::propertyIntegerAsXmlTest( )
|
|
||||||
|
|
||||||
void XmlTest::sha1Test( )
|
|
||||||
{
|
|
||||||
- string actual = libcmis::sha1( "Hello" );
|
|
||||||
- CPPUNIT_ASSERT_EQUAL( string( "f7ff9e8b7bb2e09b70935a5d785e0cc5d9d0abf0" ), actual );
|
|
||||||
+ {
|
|
||||||
+ string actual = libcmis::sha1( "Hello" );
|
|
||||||
+ CPPUNIT_ASSERT_EQUAL( string( "f7ff9e8b7bb2e09b70935a5d785e0cc5d9d0abf0" ), actual );
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ {
|
|
||||||
+ // check correct width
|
|
||||||
+ string actual = libcmis::sha1( "35969137" );
|
|
||||||
+ CPPUNIT_ASSERT_EQUAL( string( "0d93546909cfeb5c00089202104df3980000ec9f" ), actual );
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
|
|
||||||
CPPUNIT_TEST_SUITE_REGISTRATION( XmlTest );
|
|
||||||
diff --git a/src/libcmis/xml-utils.cxx b/src/libcmis/xml-utils.cxx
|
|
||||||
index dddfafa..645fbcf 100644
|
|
||||||
--- a/src/libcmis/xml-utils.cxx
|
|
||||||
+++ b/src/libcmis/xml-utils.cxx
|
|
||||||
@@ -498,8 +498,12 @@ namespace libcmis
|
|
||||||
sha1.get_digest( digest );
|
|
||||||
|
|
||||||
stringstream out;
|
|
||||||
+ // Setup writing mode. Every number must produce eight
|
|
||||||
+ // hexadecimal digits, including possible leading 0s, or we get
|
|
||||||
+ // less than 40 digits as result.
|
|
||||||
+ out << hex << setfill('0') << right;
|
|
||||||
for ( int i = 0; i < 5; ++i )
|
|
||||||
- out << hex << digest[i];
|
|
||||||
+ out << setw(8) << digest[i];
|
|
||||||
return out.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
--
|
|
||||||
1.8.1.4
|
|
||||||
|
|
@ -1,68 +0,0 @@
|
|||||||
From 3c34544890e6fba5df3ddffd11a0533c96426cc6 Mon Sep 17 00:00:00 2001
|
|
||||||
From: David Tardon <dtardon@redhat.com>
|
|
||||||
Date: Mon, 8 Apr 2013 20:18:19 +0200
|
|
||||||
Subject: [PATCH 2/3] rhbz#918080 restrict the set of protocols for curl
|
|
||||||
(cherry picked from commit 6401443248d7ce9fad1b42bad291418d59f4a623)
|
|
||||||
|
|
||||||
Conflicts:
|
|
||||||
src/libcmis/base-session.cxx
|
|
||||||
src/libcmis/base-session.hxx
|
|
||||||
---
|
|
||||||
src/libcmis/base-session.cxx | 10 ++++++++++
|
|
||||||
src/libcmis/base-session.hxx | 1 +
|
|
||||||
2 files changed, 11 insertions(+)
|
|
||||||
|
|
||||||
diff --git a/src/libcmis/base-session.cxx b/src/libcmis/base-session.cxx
|
|
||||||
index b007a9d..9d08edc 100644
|
|
||||||
--- a/src/libcmis/base-session.cxx
|
|
||||||
+++ b/src/libcmis/base-session.cxx
|
|
||||||
@@ -123,6 +123,7 @@ BaseSession::BaseSession( string atomPubUrl, string repositoryId, string usernam
|
|
||||||
{
|
|
||||||
curl_global_init( CURL_GLOBAL_ALL );
|
|
||||||
m_curlHandle = curl_easy_init( );
|
|
||||||
+ initProtocols();
|
|
||||||
}
|
|
||||||
|
|
||||||
BaseSession::BaseSession( const BaseSession& copy ) :
|
|
||||||
@@ -142,6 +143,7 @@ BaseSession::BaseSession( const BaseSession& copy ) :
|
|
||||||
// Not sure how sharing curl handles is safe.
|
|
||||||
curl_global_init( CURL_GLOBAL_ALL );
|
|
||||||
m_curlHandle = curl_easy_init( );
|
|
||||||
+ initProtocols();
|
|
||||||
}
|
|
||||||
|
|
||||||
BaseSession& BaseSession::operator=( const BaseSession& copy )
|
|
||||||
@@ -161,6 +163,7 @@ BaseSession& BaseSession::operator=( const BaseSession& copy )
|
|
||||||
// Not sure how sharing curl handles is safe.
|
|
||||||
curl_global_init( CURL_GLOBAL_ALL );
|
|
||||||
m_curlHandle = curl_easy_init( );
|
|
||||||
+ initProtocols();
|
|
||||||
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
@@ -535,3 +538,10 @@ libcmis::Exception CurlException::getCmisException( ) const
|
|
||||||
|
|
||||||
return libcmis::Exception( msg, type );
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+void BaseSession::initProtocols( )
|
|
||||||
+{
|
|
||||||
+ const unsigned long protocols = CURLPROTO_HTTP | CURLPROTO_HTTPS;
|
|
||||||
+ curl_easy_setopt(m_curlHandle, CURLOPT_PROTOCOLS, protocols);
|
|
||||||
+ curl_easy_setopt(m_curlHandle, CURLOPT_REDIR_PROTOCOLS, protocols);
|
|
||||||
+}
|
|
||||||
diff --git a/src/libcmis/base-session.hxx b/src/libcmis/base-session.hxx
|
|
||||||
index 0b90c1f..6446a41 100644
|
|
||||||
--- a/src/libcmis/base-session.hxx
|
|
||||||
+++ b/src/libcmis/base-session.hxx
|
|
||||||
@@ -149,6 +149,7 @@ class BaseSession : public libcmis::Session
|
|
||||||
virtual void setAuthenticationProvider( libcmis::AuthProviderPtr provider ) { m_authProvider = provider; }
|
|
||||||
private:
|
|
||||||
void httpRunRequest( std::string url ) throw ( CurlException );
|
|
||||||
+ void initProtocols( );
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
||||||
--
|
|
||||||
1.8.1.4
|
|
||||||
|
|
@ -1,75 +0,0 @@
|
|||||||
From 3ea92e49821638be039be7085659af160a6d4ebf Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?C=C3=A9dric=20Bosdonnat?= <cbosdo@users.sourceforge.net>
|
|
||||||
Date: Mon, 22 Apr 2013 15:45:26 +0200
|
|
||||||
Subject: [PATCH 3/3] Init protocols should be done right after resetting curl
|
|
||||||
handle (cherry picked from commit e75bd2548101b8681edf13ea085d62634b7668cf)
|
|
||||||
|
|
||||||
Conflicts:
|
|
||||||
src/libcmis/base-session.cxx
|
|
||||||
---
|
|
||||||
src/libcmis/base-session.cxx | 7 ++++---
|
|
||||||
1 file changed, 4 insertions(+), 3 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/libcmis/base-session.cxx b/src/libcmis/base-session.cxx
|
|
||||||
index 9d08edc..478d0de 100644
|
|
||||||
--- a/src/libcmis/base-session.cxx
|
|
||||||
+++ b/src/libcmis/base-session.cxx
|
|
||||||
@@ -123,7 +123,6 @@ BaseSession::BaseSession( string atomPubUrl, string repositoryId, string usernam
|
|
||||||
{
|
|
||||||
curl_global_init( CURL_GLOBAL_ALL );
|
|
||||||
m_curlHandle = curl_easy_init( );
|
|
||||||
- initProtocols();
|
|
||||||
}
|
|
||||||
|
|
||||||
BaseSession::BaseSession( const BaseSession& copy ) :
|
|
||||||
@@ -143,7 +142,6 @@ BaseSession::BaseSession( const BaseSession& copy ) :
|
|
||||||
// Not sure how sharing curl handles is safe.
|
|
||||||
curl_global_init( CURL_GLOBAL_ALL );
|
|
||||||
m_curlHandle = curl_easy_init( );
|
|
||||||
- initProtocols();
|
|
||||||
}
|
|
||||||
|
|
||||||
BaseSession& BaseSession::operator=( const BaseSession& copy )
|
|
||||||
@@ -163,7 +161,6 @@ BaseSession& BaseSession::operator=( const BaseSession& copy )
|
|
||||||
// Not sure how sharing curl handles is safe.
|
|
||||||
curl_global_init( CURL_GLOBAL_ALL );
|
|
||||||
m_curlHandle = curl_easy_init( );
|
|
||||||
- initProtocols();
|
|
||||||
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
@@ -223,6 +220,7 @@ libcmis::HttpResponsePtr BaseSession::httpGetRequest( string url ) throw ( CurlE
|
|
||||||
{
|
|
||||||
// Reset the handle for the request
|
|
||||||
curl_easy_reset( m_curlHandle );
|
|
||||||
+ initProtocols( );
|
|
||||||
|
|
||||||
libcmis::HttpResponsePtr response( new libcmis::HttpResponse( ) );
|
|
||||||
|
|
||||||
@@ -255,6 +253,7 @@ libcmis::HttpResponsePtr BaseSession::httpPutRequest( string url, istream& is, v
|
|
||||||
{
|
|
||||||
// Reset the handle for the request
|
|
||||||
curl_easy_reset( m_curlHandle );
|
|
||||||
+ initProtocols( );
|
|
||||||
|
|
||||||
libcmis::HttpResponsePtr response( new libcmis::HttpResponse( ) );
|
|
||||||
|
|
||||||
@@ -320,6 +319,7 @@ libcmis::HttpResponsePtr BaseSession::httpPostRequest( string url, istringstream
|
|
||||||
{
|
|
||||||
// Reset the handle for the request
|
|
||||||
curl_easy_reset( m_curlHandle );
|
|
||||||
+ initProtocols( );
|
|
||||||
|
|
||||||
libcmis::HttpResponsePtr response( new libcmis::HttpResponse( ) );
|
|
||||||
|
|
||||||
@@ -385,6 +385,7 @@ void BaseSession::httpDeleteRequest( string url ) throw ( CurlException )
|
|
||||||
{
|
|
||||||
// Reset the handle for the request
|
|
||||||
curl_easy_reset( m_curlHandle );
|
|
||||||
+ initProtocols( );
|
|
||||||
|
|
||||||
curl_easy_setopt( m_curlHandle, CURLOPT_CUSTOMREQUEST, "DELETE" );
|
|
||||||
httpRunRequest( url );
|
|
||||||
--
|
|
||||||
1.8.1.4
|
|
||||||
|
|
Loading…
Reference in new issue