aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Server
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Server')
-rw-r--r--OpenSim/Server/Base/ServerUtils.cs124
1 files changed, 80 insertions, 44 deletions
diff --git a/OpenSim/Server/Base/ServerUtils.cs b/OpenSim/Server/Base/ServerUtils.cs
index aff6b4f..d0043ba 100644
--- a/OpenSim/Server/Base/ServerUtils.cs
+++ b/OpenSim/Server/Base/ServerUtils.cs
@@ -39,7 +39,7 @@ using OpenMetaverse;
39using Mono.Addins; 39using Mono.Addins;
40using OpenSim.Framework.Servers.HttpServer; 40using OpenSim.Framework.Servers.HttpServer;
41using OpenSim.Framework.Servers; 41using OpenSim.Framework.Servers;
42 42using OpenMetaverse.StructuredData; // LitJson is hidden on this
43 43
44[assembly:AddinRoot("Robust", OpenSim.VersionInfo.VersionNumber)] 44[assembly:AddinRoot("Robust", OpenSim.VersionInfo.VersionNumber)]
45namespace OpenSim.Server.Base 45namespace OpenSim.Server.Base
@@ -327,49 +327,62 @@ namespace OpenSim.Server.Base
327 327
328 public static Dictionary<string, object> ParseQueryString(string query) 328 public static Dictionary<string, object> ParseQueryString(string query)
329 { 329 {
330 Dictionary<string, object> result = new Dictionary<string, object>();
331 string[] terms = query.Split(new char[] {'&'}); 330 string[] terms = query.Split(new char[] {'&'});
332 331
333 if (terms.Length == 0) 332 int nterms = terms.Length;
334 return result; 333 if (nterms == 0)
334 return new Dictionary<string, object>();
335
336 Dictionary<string, object> result = new Dictionary<string, object>(nterms);
337 string name;
335 338
336 foreach (string t in terms) 339 for(int i = 0; i < nterms; ++i)
337 { 340 {
338 string[] elems = t.Split(new char[] {'='}); 341 string[] elems = terms[i].Split(new char[] {'='});
342
339 if (elems.Length == 0) 343 if (elems.Length == 0)
340 continue; 344 continue;
341 345
342 string name = System.Web.HttpUtility.UrlDecode(elems[0]); 346 if(String.IsNullOrWhiteSpace(elems[0]))
343 string value = String.Empty; 347 continue;
344 348
345 if (elems.Length > 1) 349 name = System.Web.HttpUtility.UrlDecode(elems[0]);
346 value = System.Web.HttpUtility.UrlDecode(elems[1]);
347 350
348 if (name.EndsWith("[]")) 351 if (name.EndsWith("[]"))
349 { 352 {
350 string cleanName = name.Substring(0, name.Length - 2); 353 name = name.Substring(0, name.Length - 2);
351 if (result.ContainsKey(cleanName)) 354 if(String.IsNullOrWhiteSpace(name))
355 continue;
356 if (result.ContainsKey(name))
352 { 357 {
353 if (!(result[cleanName] is List<string>)) 358 if (!(result[name] is List<string>))
354 continue; 359 continue;
355 360
356 List<string> l = (List<string>)result[cleanName]; 361 List<string> l = (List<string>)result[name];
357 362 if (elems.Length > 1 && !String.IsNullOrWhiteSpace(elems[1]))
358 l.Add(value); 363 l.Add(System.Web.HttpUtility.UrlDecode(elems[1]));
364 else
365 l.Add(String.Empty);
359 } 366 }
360 else 367 else
361 { 368 {
362 List<string> newList = new List<string>(); 369 List<string> newList = new List<string>();
363 370 if (elems.Length > 1 && !String.IsNullOrWhiteSpace(elems[1]))
364 newList.Add(value); 371 newList.Add(System.Web.HttpUtility.UrlDecode(elems[1]));
365 372 else
366 result[cleanName] = newList; 373 newList.Add(String.Empty);
374 result[name] = newList;
367 } 375 }
368 } 376 }
369 else 377 else
370 { 378 {
371 if (!result.ContainsKey(name)) 379 if (!result.ContainsKey(name))
372 result[name] = value; 380 {
381 if (elems.Length > 1 && !String.IsNullOrWhiteSpace(elems[1]))
382 result[name] = System.Web.HttpUtility.UrlDecode(elems[1]);
383 else
384 result[name] = String.Empty;
385 }
373 } 386 }
374 } 387 }
375 388
@@ -378,47 +391,70 @@ namespace OpenSim.Server.Base
378 391
379 public static string BuildQueryString(Dictionary<string, object> data) 392 public static string BuildQueryString(Dictionary<string, object> data)
380 { 393 {
381 string qstring = String.Empty; 394 // this is not conform to html url encoding
395 // can only be used on Body of POST or PUT
396 StringBuilder sb = new StringBuilder(4096);
382 397
383 string part; 398 string pvalue;
384 399
385 foreach (KeyValuePair<string, object> kvp in data) 400 foreach (KeyValuePair<string, object> kvp in data)
386 { 401 {
387 if (kvp.Value is List<string>) 402 if (kvp.Value is List<string>)
388 { 403 {
389 List<string> l = (List<String>)kvp.Value; 404 List<string> l = (List<String>)kvp.Value;
390 405 int llen = l.Count;
391 foreach (string s in l) 406 string nkey = System.Web.HttpUtility.UrlEncode(kvp.Key);
407 for(int i = 0; i < llen; ++i)
392 { 408 {
393 part = System.Web.HttpUtility.UrlEncode(kvp.Key) + 409 if (sb.Length != 0)
394 "[]=" + System.Web.HttpUtility.UrlEncode(s); 410 sb.Append("&");
395 411 sb.Append(nkey);
396 if (qstring != String.Empty) 412 sb.Append("[]=");
397 qstring += "&"; 413 sb.Append(System.Web.HttpUtility.UrlEncode(l[i]));
398
399 qstring += part;
400 } 414 }
401 } 415 }
402 else 416 else if(kvp.Value is Dictionary<string, object>)
403 { 417 {
404 if (kvp.Value.ToString() != String.Empty) 418 // encode complex structures as JSON
419 // needed for estate bans with the encoding used on xml
420 // encode can be here because object does contain the structure information
421 // but decode needs to be on estateSettings (or other user)
422 string js;
423 try
405 { 424 {
406 part = System.Web.HttpUtility.UrlEncode(kvp.Key) + 425 // bypass libovm, we dont need even more useless high level maps
407 "=" + System.Web.HttpUtility.UrlEncode(kvp.Value.ToString()); 426 // this should only be called once.. but no problem, i hope
427 // (other uses may need more..)
428 LitJson.JsonMapper.RegisterExporter<UUID>((uuid, writer) => writer.Write(uuid.ToString()) );
429 js = LitJson.JsonMapper.ToJson(kvp.Value);
408 } 430 }
409 else 431 // catch(Exception e)
432 catch
410 { 433 {
411 part = System.Web.HttpUtility.UrlEncode(kvp.Key); 434 continue;
435 }
436 if (sb.Length != 0)
437 sb.Append("&");
438 sb.Append(System.Web.HttpUtility.UrlEncode(kvp.Key));
439 sb.Append("=");
440 sb.Append(System.Web.HttpUtility.UrlEncode(js));
441 }
442 else
443 {
444 if (sb.Length != 0)
445 sb.Append("&");
446 sb.Append(System.Web.HttpUtility.UrlEncode(kvp.Key));
447
448 pvalue = kvp.Value.ToString();
449 if (!String.IsNullOrEmpty(pvalue))
450 {
451 sb.Append("=");
452 sb.Append(System.Web.HttpUtility.UrlEncode(pvalue));
412 } 453 }
413
414 if (qstring != String.Empty)
415 qstring += "&";
416
417 qstring += part;
418 } 454 }
419 } 455 }
420 456
421 return qstring; 457 return sb.ToString();
422 } 458 }
423 459
424 public static string BuildXmlResponse(Dictionary<string, object> data) 460 public static string BuildXmlResponse(Dictionary<string, object> data)