aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Framework/Servers/HttpServer/BaseHttpServer.cs10
-rw-r--r--OpenSim/Framework/Servers/HttpServer/OSHttpResponse.cs18
-rw-r--r--OpenSim/Framework/Servers/HttpServer/PollServiceHttpRequest.cs99
3 files changed, 57 insertions, 70 deletions
diff --git a/OpenSim/Framework/Servers/HttpServer/BaseHttpServer.cs b/OpenSim/Framework/Servers/HttpServer/BaseHttpServer.cs
index fe3b8a0..5bb3fe2 100644
--- a/OpenSim/Framework/Servers/HttpServer/BaseHttpServer.cs
+++ b/OpenSim/Framework/Servers/HttpServer/BaseHttpServer.cs
@@ -604,7 +604,7 @@ namespace OpenSim.Framework.Servers.HttpServer
604 return; 604 return;
605 } 605 }
606 606
607 OSHttpResponse resp = new OSHttpResponse(new HttpResponse(context, request),context); 607 OSHttpResponse resp = new OSHttpResponse(new HttpResponse(context, request));
608 608
609 HandleRequest(req, resp); 609 HandleRequest(req, resp);
610 610
@@ -676,8 +676,6 @@ namespace OpenSim.Framework.Servers.HttpServer
676// } 676// }
677// } 677// }
678 678
679 response.SendChunked = false;
680
681 string path = request.RawUrl; 679 string path = request.RawUrl;
682 string handlerKey = GetHandlerKey(request.HttpMethod, path); 680 string handlerKey = GetHandlerKey(request.HttpMethod, path);
683 byte[] buffer = null; 681 byte[] buffer = null;
@@ -1308,7 +1306,6 @@ namespace OpenSim.Framework.Servers.HttpServer
1308 1306
1309 byte[] buffer = Encoding.UTF8.GetBytes(responseString); 1307 byte[] buffer = Encoding.UTF8.GetBytes(responseString);
1310 1308
1311 response.SendChunked = false;
1312 response.ContentLength64 = buffer.Length; 1309 response.ContentLength64 = buffer.Length;
1313 response.ContentEncoding = Encoding.UTF8; 1310 response.ContentEncoding = Encoding.UTF8;
1314 1311
@@ -1480,7 +1477,6 @@ namespace OpenSim.Framework.Servers.HttpServer
1480 buffer = BuildLLSDResponse(request, response, llsdResponse); 1477 buffer = BuildLLSDResponse(request, response, llsdResponse);
1481 } 1478 }
1482 1479
1483 response.SendChunked = false;
1484 response.ContentLength64 = buffer.Length; 1480 response.ContentLength64 = buffer.Length;
1485 response.ContentEncoding = Encoding.UTF8; 1481 response.ContentEncoding = Encoding.UTF8;
1486 response.KeepAlive = true; 1482 response.KeepAlive = true;
@@ -1988,7 +1984,6 @@ namespace OpenSim.Framework.Servers.HttpServer
1988 buffer = Convert.FromBase64String(responseString); 1984 buffer = Convert.FromBase64String(responseString);
1989 } 1985 }
1990 1986
1991 response.SendChunked = false;
1992 response.ContentLength64 = buffer.Length; 1987 response.ContentLength64 = buffer.Length;
1993 response.ContentEncoding = Encoding.UTF8; 1988 response.ContentEncoding = Encoding.UTF8;
1994 } 1989 }
@@ -2005,7 +2000,6 @@ namespace OpenSim.Framework.Servers.HttpServer
2005 string responseString = GetHTTP404(host); 2000 string responseString = GetHTTP404(host);
2006 byte[] buffer = Encoding.UTF8.GetBytes(responseString); 2001 byte[] buffer = Encoding.UTF8.GetBytes(responseString);
2007 2002
2008 response.SendChunked = false;
2009 response.ContentLength64 = buffer.Length; 2003 response.ContentLength64 = buffer.Length;
2010 response.ContentEncoding = Encoding.UTF8; 2004 response.ContentEncoding = Encoding.UTF8;
2011 2005
@@ -2021,11 +2015,9 @@ namespace OpenSim.Framework.Servers.HttpServer
2021 string responseString = GetHTTP500(); 2015 string responseString = GetHTTP500();
2022 byte[] buffer = Encoding.UTF8.GetBytes(responseString); 2016 byte[] buffer = Encoding.UTF8.GetBytes(responseString);
2023 2017
2024 response.SendChunked = false;
2025 response.ContentLength64 = buffer.Length; 2018 response.ContentLength64 = buffer.Length;
2026 response.ContentEncoding = Encoding.UTF8; 2019 response.ContentEncoding = Encoding.UTF8;
2027 2020
2028
2029 return buffer; 2021 return buffer;
2030 } 2022 }
2031 2023
diff --git a/OpenSim/Framework/Servers/HttpServer/OSHttpResponse.cs b/OpenSim/Framework/Servers/HttpServer/OSHttpResponse.cs
index 39d9b13..5a49881 100644
--- a/OpenSim/Framework/Servers/HttpServer/OSHttpResponse.cs
+++ b/OpenSim/Framework/Servers/HttpServer/OSHttpResponse.cs
@@ -251,12 +251,12 @@ namespace OpenSim.Framework.Servers.HttpServer
251 { 251 {
252 get 252 get
253 { 253 {
254 return _httpResponse.Chunked; 254 return _httpResponse.Chunked;
255 } 255 }
256 256
257 set 257 set
258 { 258 {
259 _httpResponse.Chunked = value; 259 _httpResponse.Chunked = value;
260 } 260 }
261 } 261 }
262 262
@@ -294,7 +294,6 @@ namespace OpenSim.Framework.Servers.HttpServer
294 } 294 }
295 295
296 protected IHttpResponse _httpResponse; 296 protected IHttpResponse _httpResponse;
297 private IHttpClientContext _httpClientContext;
298 297
299 public OSHttpResponse() {} 298 public OSHttpResponse() {}
300 299
@@ -312,12 +311,12 @@ namespace OpenSim.Framework.Servers.HttpServer
312 public OSHttpResponse(OSHttpRequest req) 311 public OSHttpResponse(OSHttpRequest req)
313 { 312 {
314 _httpResponse = new HttpResponse(req.IHttpClientContext, req.IHttpRequest); 313 _httpResponse = new HttpResponse(req.IHttpClientContext, req.IHttpRequest);
315 _httpClientContext = req.IHttpClientContext; 314
316 } 315 }
317 public OSHttpResponse(HttpResponse resp, IHttpClientContext clientContext) 316
317 public OSHttpResponse(HttpResponse resp)
318 { 318 {
319 _httpResponse = resp; 319 _httpResponse = resp;
320 _httpClientContext = clientContext;
321 } 320 }
322 321
323 /// <summary> 322 /// <summary>
@@ -337,13 +336,8 @@ namespace OpenSim.Framework.Servers.HttpServer
337 /// </summary> 336 /// </summary>
338 public void Send() 337 public void Send()
339 { 338 {
339 _httpResponse.Chunked = false;
340 _httpResponse.Send(); 340 _httpResponse.Send();
341 } 341 }
342
343 public void FreeContext()
344 {
345 if (_httpClientContext != null)
346 _httpClientContext.Close();
347 }
348 } 342 }
349} \ No newline at end of file 343} \ No newline at end of file
diff --git a/OpenSim/Framework/Servers/HttpServer/PollServiceHttpRequest.cs b/OpenSim/Framework/Servers/HttpServer/PollServiceHttpRequest.cs
index 47a0b9c..f83b771 100644
--- a/OpenSim/Framework/Servers/HttpServer/PollServiceHttpRequest.cs
+++ b/OpenSim/Framework/Servers/HttpServer/PollServiceHttpRequest.cs
@@ -85,7 +85,13 @@ namespace OpenSim.Framework.Servers.HttpServer
85 Request.Body.Dispose(); 85 Request.Body.Dispose();
86 86
87 OSHttpResponse response 87 OSHttpResponse response
88 = new OSHttpResponse(new HttpResponse(HttpContext, Request), HttpContext); 88 = new OSHttpResponse(new HttpResponse(HttpContext, Request));
89
90 if (responsedata == null)
91 {
92 SendNoContentError(response);
93 return;
94 }
89 95
90 int responsecode = 200; 96 int responsecode = 200;
91 string responseString = String.Empty; 97 string responseString = String.Empty;
@@ -94,61 +100,44 @@ namespace OpenSim.Framework.Servers.HttpServer
94 int rangeStart = 0; 100 int rangeStart = 0;
95 int rangeLen = -1; 101 int rangeLen = -1;
96 102
97 if (responsedata == null) 103 try
98 {
99 responsecode = 500;
100 responseString = "No response could be obtained";
101 contentType = "text/plain";
102 responsedata = new Hashtable();
103 }
104 else
105 { 104 {
106 try 105 //m_log.Info("[BASE HTTP SERVER]: Doing HTTP Grunt work with response");
107 { 106 if(responsedata["int_response_code"] != null)
108 //m_log.Info("[BASE HTTP SERVER]: Doing HTTP Grunt work with response"); 107 responsecode = (int)responsedata["int_response_code"];
109 if(responsedata["int_response_code"] != null) 108
110 responsecode = (int)responsedata["int_response_code"]; 109 if (responsedata["bin_response_data"] != null)
111
112 if (responsedata["bin_response_data"] != null)
113 {
114 buffer = (byte[])responsedata["bin_response_data"];
115 responsedata["bin_response_data"] = null;
116
117 if (responsedata["bin_start"] != null)
118 rangeStart = (int)responsedata["bin_start"];
119
120 if (responsedata["int_bytes"] != null)
121 rangeLen = (int)responsedata["int_bytes"];
122 }
123 else
124 responseString = (string)responsedata["str_response_string"];
125
126 contentType = (string)responsedata["content_type"];
127 if (responseString == null)
128 responseString = String.Empty;
129 }
130 catch
131 { 110 {
132 responsecode = 500; 111 buffer = (byte[])responsedata["bin_response_data"];
133 responseString = "No response could be obtained"; 112 responsedata["bin_response_data"] = null;
134 contentType = "text/plain"; 113
135 responsedata = new Hashtable(); 114 if (responsedata["bin_start"] != null)
115 rangeStart = (int)responsedata["bin_start"];
116
117 if (responsedata["int_bytes"] != null)
118 rangeLen = (int)responsedata["int_bytes"];
136 } 119 }
120 else
121 responseString = (string)responsedata["str_response_string"];
122
123 contentType = (string)responsedata["content_type"];
124 if (responseString == null)
125 responseString = String.Empty;
126 }
127 catch
128 {
129 SendNoContentError(response);
130 return;
137 } 131 }
138 132
139 if (responsedata.ContainsKey("error_status_text")) 133 if (responsedata.ContainsKey("error_status_text"))
140 {
141 response.StatusDescription = (string)responsedata["error_status_text"]; 134 response.StatusDescription = (string)responsedata["error_status_text"];
142 } 135
143 if (responsedata.ContainsKey("http_protocol_version")) 136 if (responsedata.ContainsKey("http_protocol_version"))
144 {
145 response.ProtocolVersion = (string)responsedata["http_protocol_version"]; 137 response.ProtocolVersion = (string)responsedata["http_protocol_version"];
146 } 138
147 if (responsedata.ContainsKey("keepalive")) 139 if (responsedata.ContainsKey("keepalive"))
148 { 140 response.KeepAlive = (bool)responsedata["keepalive"];
149 bool keepalive = (bool)responsedata["keepalive"];
150 response.KeepAlive = keepalive;
151 }
152 141
153 // Cross-Origin Resource Sharing with simple requests 142 // Cross-Origin Resource Sharing with simple requests
154 if (responsedata.ContainsKey("access_control_allow_origin")) 143 if (responsedata.ContainsKey("access_control_allow_origin"))
@@ -200,7 +189,6 @@ namespace OpenSim.Framework.Servers.HttpServer
200 else if (rangeLen + rangeStart > buffer.Length) 189 else if (rangeLen + rangeStart > buffer.Length)
201 rangeLen = buffer.Length - rangeStart; 190 rangeLen = buffer.Length - rangeStart;
202 191
203 response.SendChunked = false;
204 response.ContentLength64 = rangeLen; 192 response.ContentLength64 = rangeLen;
205 193
206 try 194 try
@@ -233,10 +221,24 @@ namespace OpenSim.Framework.Servers.HttpServer
233 PollServiceArgs.RequestsHandled++; 221 PollServiceArgs.RequestsHandled++;
234 } 222 }
235 223
224 internal void SendNoContentError(OSHttpResponse response)
225 {
226 response.ContentLength64 = 0;
227 response.ContentEncoding = Encoding.UTF8;
228 response.StatusCode = 500;
229
230 try
231 {
232 response.Send();
233 }
234 catch { }
235 return;
236 }
237
236 internal void DoHTTPstop() 238 internal void DoHTTPstop()
237 { 239 {
238 OSHttpResponse response 240 OSHttpResponse response
239 = new OSHttpResponse(new HttpResponse(HttpContext, Request), HttpContext); 241 = new OSHttpResponse(new HttpResponse(HttpContext, Request));
240 242
241 if(Request.Body.CanRead) 243 if(Request.Body.CanRead)
242 Request.Body.Dispose(); 244 Request.Body.Dispose();
@@ -244,7 +246,6 @@ namespace OpenSim.Framework.Servers.HttpServer
244 response.ContentLength64 = 0; 246 response.ContentLength64 = 0;
245 response.ContentEncoding = Encoding.UTF8; 247 response.ContentEncoding = Encoding.UTF8;
246 response.KeepAlive = false; 248 response.KeepAlive = false;
247 response.SendChunked = false;
248 response.StatusCode = 503; 249 response.StatusCode = 503;
249 250
250 try 251 try