diff options
Diffstat (limited to 'OpenSim')
-rw-r--r-- | OpenSim/Framework/LLSDxmlEncode.cs | 44 | ||||
-rw-r--r-- | OpenSim/Region/ClientStack/Linden/Caps/BunchOfCaps/BunchOfCaps.cs | 130 |
2 files changed, 111 insertions, 63 deletions
diff --git a/OpenSim/Framework/LLSDxmlEncode.cs b/OpenSim/Framework/LLSDxmlEncode.cs index afa0214..e095363 100644 --- a/OpenSim/Framework/LLSDxmlEncode.cs +++ b/OpenSim/Framework/LLSDxmlEncode.cs | |||
@@ -40,7 +40,7 @@ namespace OpenSim.Framework | |||
40 | { | 40 | { |
41 | static readonly DateTime depoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc); | 41 | static readonly DateTime depoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc); |
42 | 42 | ||
43 | public static void AddStartHeader(StringBuilder sb, bool addxmlversion = false) | 43 | public static void AddStart(StringBuilder sb, bool addxmlversion = false) |
44 | { | 44 | { |
45 | if(addxmlversion) | 45 | if(addxmlversion) |
46 | sb.Append("<?xml version=\"1.0\" encoding=\"UTF-8\"?><llsd>"); // legacy llsd xml name still valid | 46 | sb.Append("<?xml version=\"1.0\" encoding=\"UTF-8\"?><llsd>"); // legacy llsd xml name still valid |
@@ -48,13 +48,13 @@ namespace OpenSim.Framework | |||
48 | sb.Append("<llsd>"); | 48 | sb.Append("<llsd>"); |
49 | } | 49 | } |
50 | 50 | ||
51 | public static void AddEndHeader(StringBuilder sb) | 51 | public static void AddEnd(StringBuilder sb) |
52 | { | 52 | { |
53 | sb.Append("</llsd>"); | 53 | sb.Append("</llsd>"); |
54 | } | 54 | } |
55 | 55 | ||
56 | // map == a list of key value pairs | 56 | // map == a list of key value pairs |
57 | public static void AddStartMap(StringBuilder sb) | 57 | public static void AddMap(StringBuilder sb) |
58 | { | 58 | { |
59 | sb.Append("<map>"); | 59 | sb.Append("<map>"); |
60 | } | 60 | } |
@@ -70,7 +70,7 @@ namespace OpenSim.Framework | |||
70 | } | 70 | } |
71 | 71 | ||
72 | // array == a list values | 72 | // array == a list values |
73 | public static void AddStartArray(StringBuilder sb) | 73 | public static void AddArray(StringBuilder sb) |
74 | { | 74 | { |
75 | sb.Append("<array>"); | 75 | sb.Append("<array>"); |
76 | } | 76 | } |
@@ -99,6 +99,18 @@ namespace OpenSim.Framework | |||
99 | sb.Append("<boolean />"); | 99 | sb.Append("<boolean />"); |
100 | } | 100 | } |
101 | 101 | ||
102 | public static void AddElem(byte e, StringBuilder sb) | ||
103 | { | ||
104 | if(e == 0) | ||
105 | sb.Append("<integer />"); | ||
106 | else | ||
107 | { | ||
108 | sb.Append("<integer>"); | ||
109 | sb.Append(e.ToString()); | ||
110 | sb.Append("</integer>"); | ||
111 | } | ||
112 | } | ||
113 | |||
102 | public static void AddElem(int e, StringBuilder sb) | 114 | public static void AddElem(int e, StringBuilder sb) |
103 | { | 115 | { |
104 | if(e == 0) | 116 | if(e == 0) |
@@ -171,7 +183,7 @@ namespace OpenSim.Framework | |||
171 | } | 183 | } |
172 | } | 184 | } |
173 | 185 | ||
174 | public static void AddURIElem(Uri e, StringBuilder sb) | 186 | public static void AddElem(Uri e, StringBuilder sb) |
175 | { | 187 | { |
176 | if(e == null) | 188 | if(e == null) |
177 | { | 189 | { |
@@ -218,7 +230,7 @@ namespace OpenSim.Framework | |||
218 | //************ key value ******************* | 230 | //************ key value ******************* |
219 | // assumes name is a valid llsd key | 231 | // assumes name is a valid llsd key |
220 | 232 | ||
221 | public static void AddStartMap(string name, StringBuilder sb) | 233 | public static void AddMap(string name, StringBuilder sb) |
222 | { | 234 | { |
223 | sb.Append("<key>"); | 235 | sb.Append("<key>"); |
224 | sb.Append(name); | 236 | sb.Append(name); |
@@ -233,7 +245,7 @@ namespace OpenSim.Framework | |||
233 | } | 245 | } |
234 | 246 | ||
235 | // array == a list values | 247 | // array == a list values |
236 | public static void AddStartArray(string name, StringBuilder sb) | 248 | public static void AddArray(string name, StringBuilder sb) |
237 | { | 249 | { |
238 | sb.Append("<key>"); | 250 | sb.Append("<key>"); |
239 | sb.Append(name); | 251 | sb.Append(name); |
@@ -267,6 +279,22 @@ namespace OpenSim.Framework | |||
267 | sb.Append("<boolean />"); | 279 | sb.Append("<boolean />"); |
268 | } | 280 | } |
269 | 281 | ||
282 | public static void AddElem(string name, byte e, StringBuilder sb) | ||
283 | { | ||
284 | sb.Append("<key>"); | ||
285 | sb.Append(name); | ||
286 | sb.Append("</key>"); | ||
287 | |||
288 | if(e == 0) | ||
289 | sb.Append("<integer />"); | ||
290 | else | ||
291 | { | ||
292 | sb.Append("<integer>"); | ||
293 | sb.Append(e.ToString()); | ||
294 | sb.Append("</integer>"); | ||
295 | } | ||
296 | } | ||
297 | |||
270 | public static void AddElem(string name, int e, StringBuilder sb) | 298 | public static void AddElem(string name, int e, StringBuilder sb) |
271 | { | 299 | { |
272 | sb.Append("<key>"); | 300 | sb.Append("<key>"); |
@@ -363,7 +391,7 @@ namespace OpenSim.Framework | |||
363 | } | 391 | } |
364 | } | 392 | } |
365 | 393 | ||
366 | public static void AddURIElem(string name, Uri e, StringBuilder sb) | 394 | public static void AddElem(string name, Uri e, StringBuilder sb) |
367 | { | 395 | { |
368 | sb.Append("<key>"); | 396 | sb.Append("<key>"); |
369 | sb.Append(name); | 397 | sb.Append(name); |
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/BunchOfCaps/BunchOfCaps.cs b/OpenSim/Region/ClientStack/Linden/Caps/BunchOfCaps/BunchOfCaps.cs index 85e5ec3..5c5d2b9 100644 --- a/OpenSim/Region/ClientStack/Linden/Caps/BunchOfCaps/BunchOfCaps.cs +++ b/OpenSim/Region/ClientStack/Linden/Caps/BunchOfCaps/BunchOfCaps.cs | |||
@@ -1376,30 +1376,37 @@ namespace OpenSim.Region.ClientStack.Linden | |||
1376 | IOSHttpResponse httpResponse) | 1376 | IOSHttpResponse httpResponse) |
1377 | { | 1377 | { |
1378 | OSDMap req = (OSDMap)OSDParser.DeserializeLLSDXml(request); | 1378 | OSDMap req = (OSDMap)OSDParser.DeserializeLLSDXml(request); |
1379 | OSDMap resp = new OSDMap(); | ||
1380 | OSDArray object_ids = (OSDArray)req["object_ids"]; | 1379 | OSDArray object_ids = (OSDArray)req["object_ids"]; |
1381 | 1380 | ||
1382 | for (int i = 0 ; i < object_ids.Count ; i++) | 1381 | StringBuilder lsl = new StringBuilder(256); |
1382 | LLSDxmlEncode.AddStart(lsl); | ||
1383 | if(object_ids.Count == 0) | ||
1384 | LLSDxmlEncode.AddEmpyMap(lsl); | ||
1385 | else | ||
1383 | { | 1386 | { |
1384 | UUID uuid = object_ids[i].AsUUID(); | 1387 | LLSDxmlEncode.AddMap(lsl); |
1385 | 1388 | for (int i = 0 ; i < object_ids.Count ; i++) | |
1386 | SceneObjectPart obj = m_Scene.GetSceneObjectPart(uuid); | ||
1387 | if (obj != null) | ||
1388 | { | 1389 | { |
1389 | OSDMap object_data = new OSDMap(); | 1390 | UUID uuid = object_ids[i].AsUUID(); |
1391 | |||
1392 | SceneObjectPart obj = m_Scene.GetSceneObjectPart(uuid); | ||
1393 | if (obj != null) | ||
1394 | { | ||
1395 | LLSDxmlEncode.AddMap(uuid.ToString(),lsl); | ||
1390 | 1396 | ||
1391 | object_data["PhysicsShapeType"] = obj.PhysicsShapeType; | 1397 | LLSDxmlEncode.AddElem("PhysicsShapeType", obj.PhysicsShapeType, lsl); |
1392 | object_data["Density"] = obj.Density; | 1398 | LLSDxmlEncode.AddElem("Density", obj.Density, lsl); |
1393 | object_data["Friction"] = obj.Friction; | 1399 | LLSDxmlEncode.AddElem("Friction", obj.Friction, lsl); |
1394 | object_data["Restitution"] = obj.Restitution; | 1400 | LLSDxmlEncode.AddElem("Restitution", obj.Restitution, lsl); |
1395 | object_data["GravityMultiplier"] = obj.GravityModifier; | 1401 | LLSDxmlEncode.AddElem("GravityMultiplier", obj.GravityModifier, lsl); |
1396 | 1402 | ||
1397 | resp[uuid.ToString()] = object_data; | 1403 | LLSDxmlEncode.AddEndMap(lsl); |
1404 | } | ||
1405 | LLSDxmlEncode.AddEndMap(lsl); | ||
1398 | } | 1406 | } |
1399 | } | 1407 | } |
1400 | 1408 | LLSDxmlEncode.AddEnd(lsl); | |
1401 | string response = OSDParser.SerializeLLSDXmlString(resp); | 1409 | return lsl.ToString(); |
1402 | return response; | ||
1403 | } | 1410 | } |
1404 | 1411 | ||
1405 | public string GetObjectCost(string request, string path, | 1412 | public string GetObjectCost(string request, string path, |
@@ -1407,47 +1414,60 @@ namespace OpenSim.Region.ClientStack.Linden | |||
1407 | IOSHttpResponse httpResponse) | 1414 | IOSHttpResponse httpResponse) |
1408 | { | 1415 | { |
1409 | OSDMap req = (OSDMap)OSDParser.DeserializeLLSDXml(request); | 1416 | OSDMap req = (OSDMap)OSDParser.DeserializeLLSDXml(request); |
1410 | OSDMap resp = new OSDMap(); | ||
1411 | |||
1412 | OSDArray object_ids = (OSDArray)req["object_ids"]; | 1417 | OSDArray object_ids = (OSDArray)req["object_ids"]; |
1413 | 1418 | ||
1414 | for (int i = 0; i < object_ids.Count; i++) | 1419 | StringBuilder lsl = new StringBuilder(512); |
1420 | LLSDxmlEncode.AddStart(lsl); | ||
1421 | if(object_ids.Count == 0) | ||
1422 | LLSDxmlEncode.AddEmpyMap(lsl); | ||
1423 | else | ||
1415 | { | 1424 | { |
1416 | UUID uuid = object_ids[i].AsUUID(); | 1425 | bool haveone = false; |
1426 | LLSDxmlEncode.AddMap(lsl); | ||
1427 | for (int i = 0; i < object_ids.Count; i++) | ||
1428 | { | ||
1429 | UUID uuid = object_ids[i].AsUUID(); | ||
1430 | |||
1431 | SceneObjectPart part = m_Scene.GetSceneObjectPart(uuid); | ||
1432 | SceneObjectGroup grp = null; | ||
1433 | if (part != null) | ||
1434 | grp = part.ParentGroup; | ||
1435 | if (grp != null) | ||
1436 | { | ||
1437 | haveone = true; | ||
1438 | float linksetCost; | ||
1439 | float linksetPhysCost; | ||
1440 | float partCost; | ||
1441 | float partPhysCost; | ||
1417 | 1442 | ||
1418 | SceneObjectPart part = m_Scene.GetSceneObjectPart(uuid); | 1443 | grp.GetResourcesCosts(part,out linksetCost,out linksetPhysCost,out partCost,out partPhysCost); |
1419 | SceneObjectGroup grp = null; | 1444 | |
1420 | if (part != null) | 1445 | LLSDxmlEncode.AddMap(uuid.ToString(), lsl); |
1421 | grp = part.ParentGroup; | 1446 | |
1422 | if (grp != null) | 1447 | LLSDxmlEncode.AddElem("linked_set_resource_cost", linksetCost, lsl); |
1448 | LLSDxmlEncode.AddElem("resource_cost", partCost, lsl); | ||
1449 | LLSDxmlEncode.AddElem("physics_cost", partPhysCost, lsl); | ||
1450 | LLSDxmlEncode.AddElem("linked_set_physics_cost", linksetPhysCost, lsl); | ||
1451 | LLSDxmlEncode.AddElem("resource_limiting_type", "legacy", lsl); | ||
1452 | |||
1453 | LLSDxmlEncode.AddEndMap(lsl); | ||
1454 | } | ||
1455 | } | ||
1456 | if(!haveone) | ||
1423 | { | 1457 | { |
1424 | float linksetCost; | 1458 | LLSDxmlEncode.AddMap(UUID.Zero.ToString(), lsl); |
1425 | float linksetPhysCost; | 1459 | LLSDxmlEncode.AddElem("linked_set_resource_cost", 0, lsl); |
1426 | float partCost; | 1460 | LLSDxmlEncode.AddElem("resource_cost", 0, lsl); |
1427 | float partPhysCost; | 1461 | LLSDxmlEncode.AddElem("physics_cost", 0, lsl); |
1428 | 1462 | LLSDxmlEncode.AddElem("linked_set_physics_cost", 0, lsl); | |
1429 | grp.GetResourcesCosts(part,out linksetCost,out linksetPhysCost,out partCost,out partPhysCost); | 1463 | LLSDxmlEncode.AddElem("resource_limiting_type", "legacy", lsl); |
1430 | 1464 | LLSDxmlEncode.AddEndMap(lsl); | |
1431 | OSDMap object_data = new OSDMap(); | ||
1432 | object_data["linked_set_resource_cost"] = linksetCost; | ||
1433 | object_data["resource_cost"] = partCost; | ||
1434 | object_data["physics_cost"] = partPhysCost; | ||
1435 | object_data["linked_set_physics_cost"] = linksetPhysCost; | ||
1436 | object_data["resource_limiting_type"] = "legacy"; | ||
1437 | resp[uuid.ToString()] = object_data; | ||
1438 | } | 1465 | } |
1466 | LLSDxmlEncode.AddEndMap(lsl); | ||
1439 | } | 1467 | } |
1440 | if(resp.Count == 0) | 1468 | |
1441 | { | 1469 | LLSDxmlEncode.AddEnd(lsl); |
1442 | OSDMap object_data = new OSDMap(); | 1470 | return lsl.ToString(); |
1443 | object_data["linked_set_resource_cost"] = 0; | ||
1444 | object_data["resource_cost"] = 0; | ||
1445 | object_data["physics_cost"] = 0; | ||
1446 | object_data["linked_set_physics_cost"] = 0; | ||
1447 | resp[UUID.Zero.ToString()] = object_data; | ||
1448 | } | ||
1449 | string response = OSDParser.SerializeLLSDXmlString(resp); | ||
1450 | return response; | ||
1451 | } | 1471 | } |
1452 | 1472 | ||
1453 | public string ResourceCostSelected(string request, string path, | 1473 | public string ResourceCostSelected(string request, string path, |
@@ -1825,13 +1845,13 @@ namespace OpenSim.Region.ClientStack.Linden | |||
1825 | Dictionary<UUID,string> names = m_UserManager.GetUsersNames(ids); | 1845 | Dictionary<UUID,string> names = m_UserManager.GetUsersNames(ids); |
1826 | 1846 | ||
1827 | StringBuilder lsl = new StringBuilder(names.Count * 256 + 256); | 1847 | StringBuilder lsl = new StringBuilder(names.Count * 256 + 256); |
1828 | LLSDxmlEncode.AddStartHeader(lsl); | 1848 | LLSDxmlEncode.AddStart(lsl); |
1829 | LLSDxmlEncode.AddStartMap(lsl); | 1849 | LLSDxmlEncode.AddMap(lsl); |
1830 | if(names.Count == 0) | 1850 | if(names.Count == 0) |
1831 | LLSDxmlEncode.AddEmpyArray("agents", lsl); | 1851 | LLSDxmlEncode.AddEmpyArray("agents", lsl); |
1832 | else | 1852 | else |
1833 | { | 1853 | { |
1834 | LLSDxmlEncode.AddStartArray("agents", lsl); | 1854 | LLSDxmlEncode.AddArray("agents", lsl); |
1835 | 1855 | ||
1836 | foreach (KeyValuePair<UUID,string> kvp in names) | 1856 | foreach (KeyValuePair<UUID,string> kvp in names) |
1837 | { | 1857 | { |
@@ -1846,7 +1866,7 @@ namespace OpenSim.Region.ClientStack.Linden | |||
1846 | if(parts[0] == "Unknown") | 1866 | if(parts[0] == "Unknown") |
1847 | continue; | 1867 | continue; |
1848 | 1868 | ||
1849 | LLSDxmlEncode.AddStartMap(lsl); | 1869 | LLSDxmlEncode.AddMap(lsl); |
1850 | LLSDxmlEncode.AddElem("display_name_next_update", DateTime.UtcNow.AddDays(8), lsl); | 1870 | LLSDxmlEncode.AddElem("display_name_next_update", DateTime.UtcNow.AddDays(8), lsl); |
1851 | LLSDxmlEncode.AddElem("display_name_expires", DateTime.UtcNow.AddMonths(1), lsl); | 1871 | LLSDxmlEncode.AddElem("display_name_expires", DateTime.UtcNow.AddMonths(1), lsl); |
1852 | LLSDxmlEncode.AddElem("display_name", kvp.Value, lsl); | 1872 | LLSDxmlEncode.AddElem("display_name", kvp.Value, lsl); |
@@ -1861,7 +1881,7 @@ namespace OpenSim.Region.ClientStack.Linden | |||
1861 | } | 1881 | } |
1862 | 1882 | ||
1863 | LLSDxmlEncode.AddEndMap(lsl); | 1883 | LLSDxmlEncode.AddEndMap(lsl); |
1864 | LLSDxmlEncode.AddEndHeader(lsl); | 1884 | LLSDxmlEncode.AddEnd(lsl); |
1865 | 1885 | ||
1866 | // Full content request | 1886 | // Full content request |
1867 | httpResponse.StatusCode = (int)System.Net.HttpStatusCode.OK; | 1887 | httpResponse.StatusCode = (int)System.Net.HttpStatusCode.OK; |