diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Capabilities/Handlers/GetMesh/GetMeshHandler.cs | 28 | ||||
-rw-r--r-- | OpenSim/Capabilities/Handlers/GetTexture/GetTextureHandler.cs | 46 | ||||
-rw-r--r-- | OpenSim/Framework/Util.cs | 32 |
3 files changed, 38 insertions, 68 deletions
diff --git a/OpenSim/Capabilities/Handlers/GetMesh/GetMeshHandler.cs b/OpenSim/Capabilities/Handlers/GetMesh/GetMeshHandler.cs index ed42efe..a76112f 100644 --- a/OpenSim/Capabilities/Handlers/GetMesh/GetMeshHandler.cs +++ b/OpenSim/Capabilities/Handlers/GetMesh/GetMeshHandler.cs | |||
@@ -101,9 +101,6 @@ namespace OpenSim.Capabilities.Handlers | |||
101 | return responsedata; | 101 | return responsedata; |
102 | } | 102 | } |
103 | 103 | ||
104 | Hashtable headers = new Hashtable(); | ||
105 | responsedata["headers"] = headers; | ||
106 | |||
107 | string range = String.Empty; | 104 | string range = String.Empty; |
108 | 105 | ||
109 | if (((Hashtable)request["headers"])["range"] != null) | 106 | if (((Hashtable)request["headers"])["range"] != null) |
@@ -111,18 +108,18 @@ namespace OpenSim.Capabilities.Handlers | |||
111 | else if (((Hashtable)request["headers"])["Range"] != null) | 108 | else if (((Hashtable)request["headers"])["Range"] != null) |
112 | range = (string)((Hashtable)request["headers"])["Range"]; | 109 | range = (string)((Hashtable)request["headers"])["Range"]; |
113 | 110 | ||
111 | responsedata["content_type"] = "application/vnd.ll.mesh"; | ||
114 | if (String.IsNullOrEmpty(range)) | 112 | if (String.IsNullOrEmpty(range)) |
115 | { | 113 | { |
116 | // full mesh | 114 | // full mesh |
117 | responsedata["str_response_string"] = Convert.ToBase64String(mesh.Data); | 115 | responsedata["str_response_string"] = Convert.ToBase64String(mesh.Data); |
118 | responsedata["content_type"] = "application/vnd.ll.mesh"; | ||
119 | responsedata["int_response_code"] = (int)System.Net.HttpStatusCode.OK; | 116 | responsedata["int_response_code"] = (int)System.Net.HttpStatusCode.OK; |
120 | return responsedata; | 117 | return responsedata; |
121 | } | 118 | } |
122 | 119 | ||
123 | // range request | 120 | // range request |
124 | int start, end; | 121 | int start, end; |
125 | if (TryParseRange(range, out start, out end)) | 122 | if (Util.TryParseHttpRange(range, out start, out end)) |
126 | { | 123 | { |
127 | // Before clamping start make sure we can satisfy it in order to avoid | 124 | // Before clamping start make sure we can satisfy it in order to avoid |
128 | // sending back the last byte instead of an error status | 125 | // sending back the last byte instead of an error status |
@@ -137,8 +134,10 @@ namespace OpenSim.Capabilities.Handlers | |||
137 | int len = end - start + 1; | 134 | int len = end - start + 1; |
138 | 135 | ||
139 | //m_log.Debug("Serving " + start + " to " + end + " of " + texture.Data.Length + " bytes for texture " + texture.ID); | 136 | //m_log.Debug("Serving " + start + " to " + end + " of " + texture.Data.Length + " bytes for texture " + texture.ID); |
140 | responsedata["int_response_code"] = (int)System.Net.HttpStatusCode.PartialContent; | 137 | Hashtable headers = new Hashtable(); |
141 | headers["Content-Range"] = String.Format("bytes {0}-{1}/{2}", start, end, mesh.Data.Length); | 138 | headers["Content-Range"] = String.Format("bytes {0}-{1}/{2}", start, end, mesh.Data.Length); |
139 | responsedata["headers"] = headers; | ||
140 | responsedata["int_response_code"] = (int)System.Net.HttpStatusCode.PartialContent; | ||
142 | 141 | ||
143 | byte[] d = new byte[len]; | 142 | byte[] d = new byte[len]; |
144 | Array.Copy(mesh.Data, start, d, 0, len); | 143 | Array.Copy(mesh.Data, start, d, 0, len); |
@@ -149,25 +148,8 @@ namespace OpenSim.Capabilities.Handlers | |||
149 | 148 | ||
150 | m_log.Warn("[GETMESH]: Failed to parse a range from GetMesh request, sending full asset: " + (string)request["uri"]); | 149 | m_log.Warn("[GETMESH]: Failed to parse a range from GetMesh request, sending full asset: " + (string)request["uri"]); |
151 | responsedata["str_response_string"] = Convert.ToBase64String(mesh.Data); | 150 | responsedata["str_response_string"] = Convert.ToBase64String(mesh.Data); |
152 | responsedata["content_type"] = "application/vnd.ll.mesh"; | ||
153 | responsedata["int_response_code"] = (int)System.Net.HttpStatusCode.OK; | 151 | responsedata["int_response_code"] = (int)System.Net.HttpStatusCode.OK; |
154 | return responsedata; | 152 | return responsedata; |
155 | } | 153 | } |
156 | |||
157 | private bool TryParseRange(string header, out int start, out int end) | ||
158 | { | ||
159 | if (header.StartsWith("bytes=")) | ||
160 | { | ||
161 | string[] rangeValues = header.Substring(6).Split('-'); | ||
162 | if (rangeValues.Length == 2) | ||
163 | { | ||
164 | if (Int32.TryParse(rangeValues[0], out start) && Int32.TryParse(rangeValues[1], out end)) | ||
165 | return true; | ||
166 | } | ||
167 | } | ||
168 | |||
169 | start = end = 0; | ||
170 | return false; | ||
171 | } | ||
172 | } | 154 | } |
173 | } \ No newline at end of file | 155 | } \ No newline at end of file |
diff --git a/OpenSim/Capabilities/Handlers/GetTexture/GetTextureHandler.cs b/OpenSim/Capabilities/Handlers/GetTexture/GetTextureHandler.cs index 57ec2f5..51332bc 100644 --- a/OpenSim/Capabilities/Handlers/GetTexture/GetTextureHandler.cs +++ b/OpenSim/Capabilities/Handlers/GetTexture/GetTextureHandler.cs | |||
@@ -210,7 +210,7 @@ namespace OpenSim.Capabilities.Handlers | |||
210 | { | 210 | { |
211 | // Range request | 211 | // Range request |
212 | int start, end; | 212 | int start, end; |
213 | if (TryParseRange(range, out start, out end)) | 213 | if (Util.TryParseHttpRange(range, out start, out end)) |
214 | { | 214 | { |
215 | // Before clamping start make sure we can satisfy it in order to avoid | 215 | // Before clamping start make sure we can satisfy it in order to avoid |
216 | // sending back the last byte instead of an error status | 216 | // sending back the last byte instead of an error status |
@@ -289,50 +289,6 @@ namespace OpenSim.Capabilities.Handlers | |||
289 | // texture.FullID, range, response.StatusCode, response.ContentLength, texture.Data.Length); | 289 | // texture.FullID, range, response.StatusCode, response.ContentLength, texture.Data.Length); |
290 | } | 290 | } |
291 | 291 | ||
292 | /// <summary> | ||
293 | /// Parse a range header. | ||
294 | /// </summary> | ||
295 | /// <remarks> | ||
296 | /// As per http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html, | ||
297 | /// this obeys range headers with two values (e.g. 533-4165) and no second value (e.g. 533-). | ||
298 | /// Where there is no value, -1 is returned. | ||
299 | /// FIXME: Need to cover the case where only a second value is specified (e.g. -4165), probably by returning -1 | ||
300 | /// for start.</remarks> | ||
301 | /// <returns></returns> | ||
302 | /// <param name='header'></param> | ||
303 | /// <param name='start'>Start of the range. Undefined if this was not a number.</param> | ||
304 | /// <param name='end'>End of the range. Will be -1 if no end specified. Undefined if there was a raw string but this was not a number.</param> | ||
305 | private bool TryParseRange(string header, out int start, out int end) | ||
306 | { | ||
307 | start = end = 0; | ||
308 | |||
309 | if (header.StartsWith("bytes=")) | ||
310 | { | ||
311 | string[] rangeValues = header.Substring(6).Split('-'); | ||
312 | |||
313 | if (rangeValues.Length == 2) | ||
314 | { | ||
315 | if (!Int32.TryParse(rangeValues[0], out start)) | ||
316 | return false; | ||
317 | |||
318 | string rawEnd = rangeValues[1]; | ||
319 | |||
320 | if (rawEnd == "") | ||
321 | { | ||
322 | end = -1; | ||
323 | return true; | ||
324 | } | ||
325 | else if (Int32.TryParse(rawEnd, out end)) | ||
326 | { | ||
327 | return true; | ||
328 | } | ||
329 | } | ||
330 | } | ||
331 | |||
332 | start = end = 0; | ||
333 | return false; | ||
334 | } | ||
335 | |||
336 | private byte[] ConvertTextureData(AssetBase texture, string format) | 292 | private byte[] ConvertTextureData(AssetBase texture, string format) |
337 | { | 293 | { |
338 | m_log.DebugFormat("[GETTEXTURE]: Converting texture {0} to {1}", texture.ID, format); | 294 | m_log.DebugFormat("[GETTEXTURE]: Converting texture {0} to {1}", texture.ID, format); |
diff --git a/OpenSim/Framework/Util.cs b/OpenSim/Framework/Util.cs index f8469b6..52f9aea 100644 --- a/OpenSim/Framework/Util.cs +++ b/OpenSim/Framework/Util.cs | |||
@@ -2382,6 +2382,38 @@ namespace OpenSim.Framework | |||
2382 | return sb.ToString(); | 2382 | return sb.ToString(); |
2383 | } | 2383 | } |
2384 | 2384 | ||
2385 | public static bool TryParseHttpRange(string header, out int start, out int end) | ||
2386 | { | ||
2387 | start = end = 0; | ||
2388 | |||
2389 | if (header.StartsWith("bytes=")) | ||
2390 | { | ||
2391 | string[] rangeValues = header.Substring(6).Split('-'); | ||
2392 | |||
2393 | if (rangeValues.Length == 2) | ||
2394 | { | ||
2395 | string rawStart = rangeValues[0].Trim(); | ||
2396 | if (rawStart != "" && !Int32.TryParse(rawStart, out start)) | ||
2397 | return false; | ||
2398 | |||
2399 | if (start < 0) | ||
2400 | return false; | ||
2401 | |||
2402 | string rawEnd = rangeValues[1].Trim(); | ||
2403 | if (rawEnd == "") | ||
2404 | { | ||
2405 | end = -1; | ||
2406 | return true; | ||
2407 | } | ||
2408 | else if (Int32.TryParse(rawEnd, out end)) | ||
2409 | return end > 0; | ||
2410 | } | ||
2411 | } | ||
2412 | |||
2413 | start = end = 0; | ||
2414 | return false; | ||
2415 | } | ||
2416 | |||
2385 | /// <summary> | 2417 | /// <summary> |
2386 | /// Used to trigger an early library load on Windows systems. | 2418 | /// Used to trigger an early library load on Windows systems. |
2387 | /// </summary> | 2419 | /// </summary> |