aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs400
1 files changed, 190 insertions, 210 deletions
diff --git a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
index d26a1bd..dcc88c4 100644
--- a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
+++ b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
@@ -258,17 +258,13 @@ namespace OpenSim.ApplicationPlugins.RemoteController
258 { 258 {
259 m_log.Info("[RADMIN]: Request to restart Region."); 259 m_log.Info("[RADMIN]: Request to restart Region.");
260 260
261 CheckStringParameters(requestData, responseData, new string[] {"regionID"}); 261 CheckRegionParams(requestData, responseData);
262 262
263 UUID regionID = new UUID((string) requestData["regionID"]); 263 Scene rebootedScene = null;
264 264 GetSceneFromRegionParams(requestData, responseData, out rebootedScene);
265 Scene rebootedScene;
266 265
267 responseData["success"] = false; 266 responseData["success"] = false;
268 responseData["accepted"] = true; 267 responseData["accepted"] = true;
269 if (!m_application.SceneManager.TryGetScene(regionID, out rebootedScene))
270 throw new Exception("region not found");
271
272 responseData["rebooting"] = true; 268 responseData["rebooting"] = true;
273 269
274 string message; 270 string message;
@@ -392,14 +388,15 @@ namespace OpenSim.ApplicationPlugins.RemoteController
392 // } 388 // }
393 389
394 CheckStringParameters(requestData, responseData, new string[] {"filename", "regionid"}); 390 CheckStringParameters(requestData, responseData, new string[] {"filename", "regionid"});
391 CheckRegionParams(requestData, responseData);
395 392
396 string file = (string) requestData["filename"]; 393 Scene scene = null;
397 UUID regionID = (UUID) (string) requestData["regionid"]; 394 GetSceneFromRegionParams(requestData, responseData, out scene);
398 m_log.InfoFormat("[RADMIN]: Terrain Loading: {0}", file); 395 string file = (string)requestData["filename"];
399 396
400 responseData["accepted"] = true; 397 responseData["accepted"] = true;
401 398
402 LoadHeightmap(file, regionID); 399 LoadHeightmap(file, scene.RegionInfo.RegionID);
403 400
404 responseData["success"] = true; 401 responseData["success"] = true;
405 402
@@ -416,18 +413,16 @@ namespace OpenSim.ApplicationPlugins.RemoteController
416// m_log.DebugFormat("[RADMIN]: Save Terrain: XmlRpc {0}", request.ToString()); 413// m_log.DebugFormat("[RADMIN]: Save Terrain: XmlRpc {0}", request.ToString());
417 414
418 CheckStringParameters(requestData, responseData, new string[] { "filename", "regionid" }); 415 CheckStringParameters(requestData, responseData, new string[] { "filename", "regionid" });
416 CheckRegionParams(requestData, responseData);
417
418 Scene region = null;
419 GetSceneFromRegionParams(requestData, responseData, out region);
419 420
420 string file = (string)requestData["filename"]; 421 string file = (string)requestData["filename"];
421 UUID regionID = (UUID)(string)requestData["regionid"];
422 m_log.InfoFormat("[RADMIN]: Terrain Saving: {0}", file); 422 m_log.InfoFormat("[RADMIN]: Terrain Saving: {0}", file);
423 423
424 responseData["accepted"] = true; 424 responseData["accepted"] = true;
425 425
426 Scene region = null;
427
428 if (!m_application.SceneManager.TryGetScene(regionID, out region))
429 throw new Exception("1: unable to get a scene with that name");
430
431 ITerrainModule terrainModule = region.RequestModuleInterface<ITerrainModule>(); 426 ITerrainModule terrainModule = region.RequestModuleInterface<ITerrainModule>();
432 if (null == terrainModule) throw new Exception("terrain module not available"); 427 if (null == terrainModule) throw new Exception("terrain module not available");
433 428
@@ -814,7 +809,8 @@ namespace OpenSim.ApplicationPlugins.RemoteController
814 809
815 responseData["success"] = true; 810 responseData["success"] = true;
816 responseData["region_name"] = region.RegionName; 811 responseData["region_name"] = region.RegionName;
817 responseData["region_uuid"] = region.RegionID.ToString(); 812 responseData["region_id"] = region.RegionID.ToString();
813 responseData["region_uuid"] = region.RegionID.ToString(); //Deprecate July 2012
818 814
819 m_log.Info("[RADMIN]: CreateRegion: request complete"); 815 m_log.Info("[RADMIN]: CreateRegion: request complete");
820 } 816 }
@@ -856,16 +852,16 @@ namespace OpenSim.ApplicationPlugins.RemoteController
856 lock (m_requestLock) 852 lock (m_requestLock)
857 { 853 {
858 CheckStringParameters(requestData, responseData, new string[] {"region_name"}); 854 CheckStringParameters(requestData, responseData, new string[] {"region_name"});
855 CheckRegionParams(requestData, responseData);
859 856
860 Scene scene = null; 857 Scene scene = null;
861 string regionName = (string) requestData["region_name"]; 858 GetSceneFromRegionParams(requestData, responseData, out scene);
862 if (!m_application.SceneManager.TryGetScene(regionName, out scene))
863 throw new Exception(String.Format("region \"{0}\" does not exist", regionName));
864 859
865 m_application.RemoveRegion(scene, true); 860 m_application.RemoveRegion(scene, true);
866 861
867 responseData["success"] = true; 862 responseData["success"] = true;
868 responseData["region_name"] = regionName; 863 responseData["region_name"] = scene.RegionInfo.RegionName;
864 responseData["region_id"] = scene.RegionInfo.RegionID;
869 865
870 m_log.Info("[RADMIN]: DeleteRegion: request complete"); 866 m_log.Info("[RADMIN]: DeleteRegion: request complete");
871 } 867 }
@@ -905,44 +901,21 @@ namespace OpenSim.ApplicationPlugins.RemoteController
905 901
906 Hashtable responseData = (Hashtable)response.Value; 902 Hashtable responseData = (Hashtable)response.Value;
907 Hashtable requestData = (Hashtable)request.Params[0]; 903 Hashtable requestData = (Hashtable)request.Params[0];
908 Scene scene = null;
909 904
910 lock (m_requestLock) 905 lock (m_requestLock)
911 { 906 {
912 if (requestData.ContainsKey("region_id") && 907 CheckRegionParams(requestData, responseData);
913 !String.IsNullOrEmpty((string) requestData["region_id"]))
914 {
915 // Region specified by UUID
916 UUID regionID = (UUID) (string) requestData["region_id"];
917 if (!m_application.SceneManager.TryGetScene(regionID, out scene))
918 throw new Exception(String.Format("region \"{0}\" does not exist", regionID));
919
920 m_application.CloseRegion(scene);
921
922 responseData["success"] = true;
923 responseData["region_id"] = regionID;
924 908
925 response.Value = responseData; 909 Scene scene = null;
926 } 910 GetSceneFromRegionParams(requestData, responseData, out scene);
927 else if (
928 requestData.ContainsKey("region_name")
929 && !String.IsNullOrEmpty((string) requestData["region_name"]))
930 {
931 // Region specified by name
932 911
933 string regionName = (string) requestData["region_name"]; 912 m_application.CloseRegion(scene);
934 if (!m_application.SceneManager.TryGetScene(regionName, out scene))
935 throw new Exception(String.Format("region \"{0}\" does not exist", regionName));
936 913
937 m_application.CloseRegion(scene); 914 responseData["success"] = true;
915 responseData["region_name"] = scene.RegionInfo.RegionName;
916 responseData["region_id"] = scene.RegionInfo.RegionID;
938 917
939 responseData["success"] = true; 918 response.Value = responseData;
940 responseData["region_name"] = regionName;
941 }
942 else
943 {
944 throw new Exception("no region specified");
945 }
946 919
947 m_log.Info("[RADMIN]: CloseRegion: request complete"); 920 m_log.Info("[RADMIN]: CloseRegion: request complete");
948 } 921 }
@@ -989,12 +962,10 @@ namespace OpenSim.ApplicationPlugins.RemoteController
989 962
990 lock (m_requestLock) 963 lock (m_requestLock)
991 { 964 {
992 CheckStringParameters(requestData, responseData, new string[] {"region_name"}); 965 CheckRegionParams(requestData, responseData);
993 966
994 Scene scene = null; 967 Scene scene = null;
995 string regionName = (string) requestData["region_name"]; 968 GetSceneFromRegionParams(requestData, responseData, out scene);
996 if (!m_application.SceneManager.TryGetScene(regionName, out scene))
997 throw new Exception(String.Format("region \"{0}\" does not exist", regionName));
998 969
999 // Modify access 970 // Modify access
1000 scene.RegionInfo.EstateSettings.PublicAccess = 971 scene.RegionInfo.EstateSettings.PublicAccess =
@@ -1024,7 +995,8 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1024 } 995 }
1025 996
1026 responseData["success"] = true; 997 responseData["success"] = true;
1027 responseData["region_name"] = regionName; 998 responseData["region_name"] = scene.RegionInfo.RegionName;
999 responseData["region_id"] = scene.RegionInfo.RegionID;
1028 1000
1029 m_log.Info("[RADMIN]: ModifyRegion: request complete"); 1001 m_log.Info("[RADMIN]: ModifyRegion: request complete");
1030 } 1002 }
@@ -1420,22 +1392,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1420 try 1392 try
1421 { 1393 {
1422 CheckStringParameters(requestData, responseData, new string[] {"filename"}); 1394 CheckStringParameters(requestData, responseData, new string[] {"filename"});
1395 CheckRegionParams(requestData, responseData);
1423 1396
1424 string filename = (string) requestData["filename"];
1425 Scene scene = null; 1397 Scene scene = null;
1426 if (requestData.Contains("region_uuid")) 1398 GetSceneFromRegionParams(requestData, responseData, out scene);
1427 { 1399
1428 UUID region_uuid = (UUID) (string) requestData["region_uuid"]; 1400 string filename = (string) requestData["filename"];
1429 if (!m_application.SceneManager.TryGetScene(region_uuid, out scene))
1430 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1431 }
1432 else if (requestData.Contains("region_name"))
1433 {
1434 string region_name = (string) requestData["region_name"];
1435 if (!m_application.SceneManager.TryGetScene(region_name, out scene))
1436 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1437 }
1438 else throw new Exception("neither region_name nor region_uuid given");
1439 1401
1440 bool mergeOar = false; 1402 bool mergeOar = false;
1441 bool skipAssets = false; 1403 bool skipAssets = false;
@@ -1516,22 +1478,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1516 try 1478 try
1517 { 1479 {
1518 CheckStringParameters(requestData, responseData, new string[] {"filename"}); 1480 CheckStringParameters(requestData, responseData, new string[] {"filename"});
1481 CheckRegionParams(requestData, responseData);
1519 1482
1520 string filename = (string)requestData["filename"];
1521 Scene scene = null; 1483 Scene scene = null;
1522 if (requestData.Contains("region_uuid")) 1484 GetSceneFromRegionParams(requestData, responseData, out scene);
1523 { 1485
1524 UUID region_uuid = (UUID) (string) requestData["region_uuid"]; 1486 string filename = (string)requestData["filename"];
1525 if (!m_application.SceneManager.TryGetScene(region_uuid, out scene))
1526 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1527 }
1528 else if (requestData.Contains("region_name"))
1529 {
1530 string region_name = (string) requestData["region_name"];
1531 if (!m_application.SceneManager.TryGetScene(region_name, out scene))
1532 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1533 }
1534 else throw new Exception("neither region_name nor region_uuid given");
1535 1487
1536 Dictionary<string, object> options = new Dictionary<string, object>(); 1488 Dictionary<string, object> options = new Dictionary<string, object>();
1537 1489
@@ -1603,25 +1555,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1603 try 1555 try
1604 { 1556 {
1605 CheckStringParameters(requestData, responseData, new string[] {"filename"}); 1557 CheckStringParameters(requestData, responseData, new string[] {"filename"});
1558 CheckRegionParams(requestData, responseData);
1606 1559
1607 string filename = (string) requestData["filename"]; 1560 Scene scene = null;
1608 if (requestData.Contains("region_uuid")) 1561 GetSceneFromRegionParams(requestData, responseData, out scene);
1609 {
1610 UUID region_uuid = (UUID) (string) requestData["region_uuid"];
1611 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid))
1612 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1613
1614 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_uuid.ToString());
1615 }
1616 else if (requestData.Contains("region_name"))
1617 {
1618 string region_name = (string) requestData["region_name"];
1619 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1620 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1621 1562
1622 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_name); 1563 string filename = (string) requestData["filename"];
1623 }
1624 else throw new Exception("neither region_name nor region_uuid given");
1625 1564
1626 responseData["switched"] = true; 1565 responseData["switched"] = true;
1627 1566
@@ -1669,23 +1608,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1669 try 1608 try
1670 { 1609 {
1671 CheckStringParameters(requestData, responseData, new string[] {"filename"}); 1610 CheckStringParameters(requestData, responseData, new string[] {"filename"});
1611 CheckRegionParams(requestData, responseData);
1612
1613 Scene scene = null;
1614 GetSceneFromRegionParams(requestData, responseData, out scene);
1672 1615
1673 string filename = (string) requestData["filename"]; 1616 string filename = (string) requestData["filename"];
1674 if (requestData.Contains("region_uuid"))
1675 {
1676 UUID region_uuid = (UUID) (string) requestData["region_uuid"];
1677 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid))
1678 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1679 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_uuid.ToString());
1680 }
1681 else if (requestData.Contains("region_name"))
1682 {
1683 string region_name = (string) requestData["region_name"];
1684 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1685 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1686 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_name);
1687 }
1688 else throw new Exception("neither region_name nor region_uuid given");
1689 1617
1690 responseData["switched"] = true; 1618 responseData["switched"] = true;
1691 1619
@@ -1729,24 +1657,10 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1729 1657
1730 responseData["success"] = true; 1658 responseData["success"] = true;
1731 1659
1732 if (requestData.Contains("region_uuid")) 1660 CheckRegionParams(requestData, responseData);
1733 {
1734 UUID region_uuid = (UUID) (string) requestData["region_uuid"];
1735 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid))
1736 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1737 }
1738 else if (requestData.Contains("region_name"))
1739 {
1740 string region_name = (string) requestData["region_name"];
1741 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1742 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1743 }
1744 else
1745 {
1746 throw new Exception("neither region_name nor region_uuid given");
1747 }
1748 1661
1749 Scene scene = m_application.SceneManager.CurrentScene; 1662 Scene scene = null;
1663 GetSceneFromRegionParams(requestData, responseData, out scene);
1750 1664
1751 int flags; 1665 int flags;
1752 string text; 1666 string text;
@@ -1779,24 +1693,11 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1779 1693
1780 responseData["success"] = true; 1694 responseData["success"] = true;
1781 1695
1782 if (requestData.Contains("region_uuid")) 1696 CheckRegionParams(requestData, responseData);
1783 {
1784 UUID region_uuid = (UUID) (string) requestData["region_uuid"];
1785 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid))
1786 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1787 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_uuid.ToString());
1788 }
1789 else if (requestData.Contains("region_name"))
1790 {
1791 string region_name = (string) requestData["region_name"];
1792 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1793 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1794 1697
1795 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_name); 1698 Scene scene = null;
1796 } 1699 GetSceneFromRegionParams(requestData, responseData, out scene);
1797 else throw new Exception("neither region_name nor region_uuid given");
1798 1700
1799 Scene scene = m_application.SceneManager.CurrentScene;
1800 scene.RegionInfo.EstateSettings.EstateAccess = new UUID[]{}; 1701 scene.RegionInfo.EstateSettings.EstateAccess = new UUID[]{};
1801 1702
1802 if (scene.RegionInfo.Persistent) 1703 if (scene.RegionInfo.Persistent)
@@ -1812,32 +1713,17 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1812 Hashtable responseData = (Hashtable)response.Value; 1713 Hashtable responseData = (Hashtable)response.Value;
1813 Hashtable requestData = (Hashtable)request.Params[0]; 1714 Hashtable requestData = (Hashtable)request.Params[0];
1814 1715
1815 if (requestData.Contains("region_uuid")) 1716 CheckRegionParams(requestData, responseData);
1816 { 1717
1817 UUID region_uuid = (UUID) (string) requestData["region_uuid"]; 1718 Scene scene = null;
1818 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid)) 1719 GetSceneFromRegionParams(requestData, responseData, out scene);
1819 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1820 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_uuid.ToString());
1821 }
1822 else if (requestData.Contains("region_name"))
1823 {
1824 string region_name = (string) requestData["region_name"];
1825 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1826 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1827 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_name);
1828 }
1829 else
1830 {
1831 throw new Exception("neither region_name nor region_uuid given");
1832 }
1833 1720
1834 int addedUsers = 0; 1721 int addedUsers = 0;
1835 1722
1836 if (requestData.Contains("users")) 1723 if (requestData.Contains("users"))
1837 { 1724 {
1838 UUID scopeID = m_application.SceneManager.CurrentOrFirstScene.RegionInfo.ScopeID; 1725 UUID scopeID = scene.RegionInfo.ScopeID;
1839 IUserAccountService userService = m_application.SceneManager.CurrentOrFirstScene.UserAccountService; 1726 IUserAccountService userService = scene.UserAccountService;
1840 Scene scene = m_application.SceneManager.CurrentScene;
1841 Hashtable users = (Hashtable) requestData["users"]; 1727 Hashtable users = (Hashtable) requestData["users"];
1842 List<UUID> uuids = new List<UUID>(); 1728 List<UUID> uuids = new List<UUID>();
1843 foreach (string name in users.Values) 1729 foreach (string name in users.Values)
@@ -1876,32 +1762,18 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1876 Hashtable responseData = (Hashtable)response.Value; 1762 Hashtable responseData = (Hashtable)response.Value;
1877 Hashtable requestData = (Hashtable)request.Params[0]; 1763 Hashtable requestData = (Hashtable)request.Params[0];
1878 1764
1879 responseData["success"] = true; 1765 CheckRegionParams(requestData, responseData);
1880 1766
1881 if (requestData.Contains("region_uuid")) 1767 Scene scene = null;
1882 { 1768 GetSceneFromRegionParams(requestData, responseData, out scene);
1883 UUID region_uuid = (UUID) (string) requestData["region_uuid"];
1884 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid))
1885 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1886 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_uuid.ToString());
1887 }
1888 else if (requestData.Contains("region_name"))
1889 {
1890 string region_name = (string) requestData["region_name"];
1891 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1892 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1893 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_name);
1894 }
1895 else throw new Exception("neither region_name nor region_uuid given");
1896 1769
1897 int removedUsers = 0; 1770 int removedUsers = 0;
1898 1771
1899 if (requestData.Contains("users")) 1772 if (requestData.Contains("users"))
1900 { 1773 {
1901 UUID scopeID = m_application.SceneManager.CurrentOrFirstScene.RegionInfo.ScopeID; 1774 UUID scopeID = scene.RegionInfo.ScopeID;
1902 IUserAccountService userService = m_application.SceneManager.CurrentOrFirstScene.UserAccountService; 1775 IUserAccountService userService = scene.UserAccountService;
1903 //UserProfileCacheService ups = m_application.CommunicationsManager.UserProfileCacheService; 1776 //UserProfileCacheService ups = m_application.CommunicationsManager.UserProfileCacheService;
1904 Scene scene = m_application.SceneManager.CurrentScene;
1905 Hashtable users = (Hashtable) requestData["users"]; 1777 Hashtable users = (Hashtable) requestData["users"];
1906 List<UUID> uuids = new List<UUID>(); 1778 List<UUID> uuids = new List<UUID>();
1907 foreach (string name in users.Values) 1779 foreach (string name in users.Values)
@@ -1928,6 +1800,7 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1928 } 1800 }
1929 1801
1930 responseData["removed"] = removedUsers; 1802 responseData["removed"] = removedUsers;
1803 responseData["success"] = true;
1931 1804
1932 m_log.Info("[RADMIN]: Access List Remove Request complete"); 1805 m_log.Info("[RADMIN]: Access List Remove Request complete");
1933 } 1806 }
@@ -1939,32 +1812,18 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1939 Hashtable responseData = (Hashtable)response.Value; 1812 Hashtable responseData = (Hashtable)response.Value;
1940 Hashtable requestData = (Hashtable)request.Params[0]; 1813 Hashtable requestData = (Hashtable)request.Params[0];
1941 1814
1942 responseData["success"] = true; 1815 CheckRegionParams(requestData, responseData);
1943 1816
1944 if (requestData.Contains("region_uuid")) 1817 Scene scene = null;
1945 { 1818 GetSceneFromRegionParams(requestData, responseData, out scene);
1946 UUID region_uuid = (UUID) (string) requestData["region_uuid"];
1947 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid))
1948 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1949 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_uuid.ToString());
1950 }
1951 else if (requestData.Contains("region_name"))
1952 {
1953 string region_name = (string) requestData["region_name"];
1954 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1955 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1956 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_name);
1957 }
1958 else throw new Exception("neither region_name nor region_uuid given");
1959 1819
1960 Scene scene = m_application.SceneManager.CurrentScene;
1961 UUID[] accessControlList = scene.RegionInfo.EstateSettings.EstateAccess; 1820 UUID[] accessControlList = scene.RegionInfo.EstateSettings.EstateAccess;
1962 Hashtable users = new Hashtable(); 1821 Hashtable users = new Hashtable();
1963 1822
1964 foreach (UUID user in accessControlList) 1823 foreach (UUID user in accessControlList)
1965 { 1824 {
1966 UUID scopeID = m_application.SceneManager.CurrentOrFirstScene.RegionInfo.ScopeID; 1825 UUID scopeID = scene.RegionInfo.ScopeID;
1967 UserAccount account = m_application.SceneManager.CurrentOrFirstScene.UserAccountService.GetUserAccount(scopeID, user); 1826 UserAccount account = scene.UserAccountService.GetUserAccount(scopeID, user);
1968 if (account != null) 1827 if (account != null)
1969 { 1828 {
1970 users[user.ToString()] = account.FirstName + " " + account.LastName; 1829 users[user.ToString()] = account.FirstName + " " + account.LastName;
@@ -1972,6 +1831,7 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1972 } 1831 }
1973 1832
1974 responseData["users"] = users; 1833 responseData["users"] = users;
1834 responseData["success"] = true;
1975 1835
1976 m_log.Info("[RADMIN]: Access List List Request complete"); 1836 m_log.Info("[RADMIN]: Access List List Request complete");
1977 } 1837 }
@@ -2089,6 +1949,126 @@ namespace OpenSim.ApplicationPlugins.RemoteController
2089 } 1949 }
2090 } 1950 }
2091 1951
1952 private void CheckRegionParams(Hashtable requestData, Hashtable responseData)
1953 {
1954 //Checks if region parameters exist and gives exeption if no parameters are given
1955 if ((requestData.ContainsKey("region_id") && !String.IsNullOrEmpty((string)requestData["region_id"])) ||
1956 (requestData.ContainsKey("region_name") && !String.IsNullOrEmpty((string)requestData["region_name"])))
1957 {
1958 return;
1959 }
1960 #region Deprecate July 2012
1961 //region_ID, regionid, region_uuid will be deprecated in July 2012!!!!!!
1962 else if (requestData.ContainsKey("regionid") &&
1963 !String.IsNullOrEmpty((string)requestData["regionid"]))
1964 {
1965 m_log.WarnFormat("[RADMIN]: Use of parameter regionid will be deprecated as of July 2012. Use region_id instead");
1966 }
1967 else if (requestData.ContainsKey("region_ID") &&
1968 !String.IsNullOrEmpty((string)requestData["region_ID"]))
1969 {
1970 m_log.WarnFormat("[RADMIN]: Use of parameter region_ID will be deprecated as of July 2012. Use region_id instead");
1971 }
1972 else if (requestData.ContainsKey("regionID") &&
1973 !String.IsNullOrEmpty((string)requestData["regionID"]))
1974 {
1975 m_log.WarnFormat("[RADMIN]: Use of parameter regionID will be deprecated as of July 2012. Use region_id instead");
1976 }
1977 else if (requestData.ContainsKey("region_uuid") &&
1978 !String.IsNullOrEmpty((string)requestData["region_uuid"]))
1979 {
1980 m_log.WarnFormat("[RADMIN]: Use of parameter region_uuid will be deprecated as of July 2012. Use region_id instead");
1981 }
1982 #endregion
1983 else
1984 {
1985 responseData["accepted"] = false;
1986 throw new Exception("no region_name or region_id given");
1987 }
1988 }
1989
1990 private void GetSceneFromRegionParams(Hashtable requestData, Hashtable responseData, out Scene scene)
1991 {
1992 scene = null;
1993
1994 if (requestData.ContainsKey("region_id") &&
1995 !String.IsNullOrEmpty((string)requestData["region_id"]))
1996 {
1997 UUID regionID = (UUID)(string)requestData["region_id"];
1998 if (!m_application.SceneManager.TryGetScene(regionID, out scene))
1999 {
2000 responseData["error"] = String.Format("Region ID {0} not found", regionID);
2001 throw new Exception(String.Format("Region ID {0} not found", regionID));
2002 }
2003 }
2004 #region Deprecate July 2012
2005 else if (requestData.ContainsKey("regionid") &&
2006 !String.IsNullOrEmpty((string)requestData["regionid"]))
2007 {
2008 m_log.WarnFormat("[RADMIN]: Use of parameter regionid will be deprecated as of July 2012. Use region_id instead");
2009
2010 UUID regionID = (UUID)(string)requestData["regionid"];
2011 if (!m_application.SceneManager.TryGetScene(regionID, out scene))
2012 {
2013 responseData["error"] = String.Format("Region ID {0} not found", regionID);
2014 throw new Exception(String.Format("Region ID {0} not found", regionID));
2015 }
2016 }
2017 else if (requestData.ContainsKey("region_ID") &&
2018 !String.IsNullOrEmpty((string)requestData["region_ID"]))
2019 {
2020 m_log.WarnFormat("[RADMIN]: Use of parameter region_ID will be deprecated as of July 2012. Use region_id instead");
2021
2022 UUID regionID = (UUID)(string)requestData["region_ID"];
2023 if (!m_application.SceneManager.TryGetScene(regionID, out scene))
2024 {
2025 responseData["error"] = String.Format("Region ID {0} not found", regionID);
2026 throw new Exception(String.Format("Region ID {0} not found", regionID));
2027 }
2028 }
2029 else if (requestData.ContainsKey("regionID") &&
2030 !String.IsNullOrEmpty((string)requestData["regionID"]))
2031 {
2032 m_log.WarnFormat("[RADMIN]: Use of parameter regionID will be deprecated as of July 2012. Use region_id instead");
2033
2034 UUID regionID = (UUID)(string)requestData["regionID"];
2035 if (!m_application.SceneManager.TryGetScene(regionID, out scene))
2036 {
2037 responseData["error"] = String.Format("Region ID {0} not found", regionID);
2038 throw new Exception(String.Format("Region ID {0} not found", regionID));
2039 }
2040 }
2041 else if (requestData.ContainsKey("region_uuid") &&
2042 !String.IsNullOrEmpty((string)requestData["region_uuid"]))
2043 {
2044 m_log.WarnFormat("[RADMIN]: Use of parameter region_uuid will be deprecated as of July 2012. Use region_id instead");
2045
2046 UUID regionID = (UUID)(string)requestData["region_uuid"];
2047 if (!m_application.SceneManager.TryGetScene(regionID, out scene))
2048 {
2049 responseData["error"] = String.Format("Region ID {0} not found", regionID);
2050 throw new Exception(String.Format("Region ID {0} not found", regionID));
2051 }
2052 }
2053 #endregion
2054 else if (requestData.ContainsKey("region_name") &&
2055 !String.IsNullOrEmpty((string)requestData["region_name"]))
2056 {
2057 string regionName = (string)requestData["region_name"];
2058 if (!m_application.SceneManager.TryGetScene(regionName, out scene))
2059 {
2060 responseData["error"] = String.Format("Region {0} not found", regionName);
2061 throw new Exception(String.Format("Region {0} not found", regionName));
2062 }
2063 }
2064 else
2065 {
2066 responseData["error"] = "no region_name or region_id given";
2067 throw new Exception("no region_name or region_id given");
2068 }
2069 return;
2070 }
2071
2092 private bool GetBoolean(Hashtable requestData, string tag, bool defaultValue) 2072 private bool GetBoolean(Hashtable requestData, string tag, bool defaultValue)
2093 { 2073 {
2094 // If an access value has been provided, apply it. 2074 // If an access value has been provided, apply it.