summaryrefslogtreecommitdiffstats
path: root/src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs
diff options
context:
space:
mode:
authorAndrew Arnott <andrewarnott@gmail.com>2013-03-04 16:00:02 -0800
committerAndrew Arnott <andrewarnott@gmail.com>2013-03-04 16:00:02 -0800
commitdf5e13809af0400a99c2a4e48c61f73043296119 (patch)
treeacabeab122bf1f5abe973bca2252301ba6f315fa /src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs
parentbbb0214b9f41ad8bcd44eba3714b463eee29fe86 (diff)
downloadDotNetOpenAuth-df5e13809af0400a99c2a4e48c61f73043296119.zip
DotNetOpenAuth-df5e13809af0400a99c2a4e48c61f73043296119.tar.gz
DotNetOpenAuth-df5e13809af0400a99c2a4e48c61f73043296119.tar.bz2
OpenIdOfflineProvider and RP now work together.
Diffstat (limited to 'src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs')
-rw-r--r--src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs b/src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs
index 941187b..f561012 100644
--- a/src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs
+++ b/src/DotNetOpenAuth.Core/Messaging/MessagingUtilities.cs
@@ -1210,9 +1210,14 @@ namespace DotNetOpenAuth.Messaging {
// even when set to their "original" values.
foreach (string headerName in request.Headers) {
switch (headerName) {
- case "Accept": message.Headers.Accept.AddRange(request.AcceptTypes.Select(at => new MediaTypeWithQualityHeaderValue(at))); break;
+ case "Accept": message.Headers.Accept.AddRange(request.AcceptTypes.Select(at => new MediaTypeWithQualityHeaderValue(at.Trim()))); break;
case "Connection": break; // Keep-Alive controls this
- case "Content-Length": message.Content.Headers.ContentLength = request.ContentLength; break;
+ case "Content-Length":
+ if (!message.Content.Headers.ContentLength.HasValue) {
+ message.Content.Headers.ContentLength = request.ContentLength;
+ }
+
+ break;
case "Content-Type": message.Content.Headers.ContentType = new MediaTypeHeaderValue(request.ContentType); break;
case "Expect": message.Headers.Expect.Add(new NameValueWithParametersHeaderValue(request.Headers[headerName])); break;
case "Host": break; // implicitly copied as part of the RequestUri