aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs105
1 files changed, 92 insertions, 13 deletions
diff --git a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
index 7106e6a..d26a1bd 100644
--- a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
+++ b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
@@ -131,6 +131,7 @@ namespace OpenSim.ApplicationPlugins.RemoteController
131 availableMethods["admin_region_query"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRegionQueryMethod); 131 availableMethods["admin_region_query"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRegionQueryMethod);
132 availableMethods["admin_shutdown"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcShutdownMethod); 132 availableMethods["admin_shutdown"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcShutdownMethod);
133 availableMethods["admin_broadcast"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAlertMethod); 133 availableMethods["admin_broadcast"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAlertMethod);
134 availableMethods["admin_dialog"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcDialogMethod);
134 availableMethods["admin_restart"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRestartMethod); 135 availableMethods["admin_restart"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRestartMethod);
135 availableMethods["admin_load_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcLoadHeightmapMethod); 136 availableMethods["admin_load_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcLoadHeightmapMethod);
136 availableMethods["admin_save_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcSaveHeightmapMethod); 137 availableMethods["admin_save_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcSaveHeightmapMethod);
@@ -270,12 +271,48 @@ namespace OpenSim.ApplicationPlugins.RemoteController
270 271
271 responseData["rebooting"] = true; 272 responseData["rebooting"] = true;
272 273
274 string message;
275 List<int> times = new List<int>();
276
277 if (requestData.ContainsKey("alerts"))
278 {
279 string[] alertTimes = requestData["alerts"].ToString().Split( new char[] {','});
280 foreach (string a in alertTimes)
281 times.Add(Convert.ToInt32(a));
282 }
283 else
284 {
285 int timeout = 30;
286 if (requestData.ContainsKey("milliseconds"))
287 timeout = Int32.Parse(requestData["milliseconds"].ToString()) / 1000;
288 while (timeout > 0)
289 {
290 times.Add(timeout);
291 if (timeout > 300)
292 timeout -= 120;
293 else if (timeout > 30)
294 timeout -= 30;
295 else
296 timeout -= 15;
297 }
298 }
299
300 message = "Region is restarting in {0}. Please save what you are doing and log out.";
301
302 if (requestData.ContainsKey("message"))
303 message = requestData["message"].ToString();
304
305 bool notice = true;
306 if (requestData.ContainsKey("noticetype")
307 && ((string)requestData["noticetype"] == "dialog"))
308 {
309 notice = false;
310 }
311
273 IRestartModule restartModule = rebootedScene.RequestModuleInterface<IRestartModule>(); 312 IRestartModule restartModule = rebootedScene.RequestModuleInterface<IRestartModule>();
274 if (restartModule != null) 313 if (restartModule != null)
275 { 314 {
276 List<int> times = new List<int> { 30, 15 }; 315 restartModule.ScheduleRestart(UUID.Zero, message, times.ToArray(), notice);
277
278 restartModule.ScheduleRestart(UUID.Zero, "Region will restart in {0}", times.ToArray(), true);
279 responseData["success"] = true; 316 responseData["success"] = true;
280 } 317 }
281 } 318 }
@@ -314,6 +351,32 @@ namespace OpenSim.ApplicationPlugins.RemoteController
314 m_log.Info("[RADMIN]: Alert request complete"); 351 m_log.Info("[RADMIN]: Alert request complete");
315 } 352 }
316 353
354 public void XmlRpcDialogMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
355 {
356 Hashtable responseData = (Hashtable)response.Value;
357
358 m_log.Info("[RADMIN]: Dialog request started");
359
360 Hashtable requestData = (Hashtable)request.Params[0];
361
362 string message = (string)requestData["message"];
363 string fromuuid = (string)requestData["from"];
364 m_log.InfoFormat("[RADMIN]: Broadcasting: {0}", message);
365
366 responseData["accepted"] = true;
367 responseData["success"] = true;
368
369 m_application.SceneManager.ForEachScene(
370 delegate(Scene scene)
371 {
372 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>();
373 if (dialogModule != null)
374 dialogModule.SendNotificationToUsersInRegion(UUID.Zero, fromuuid, message);
375 });
376
377 m_log.Info("[RADMIN]: Dialog request complete");
378 }
379
317 private void XmlRpcLoadHeightmapMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) 380 private void XmlRpcLoadHeightmapMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
318 { 381 {
319 m_log.Info("[RADMIN]: Load height maps request started"); 382 m_log.Info("[RADMIN]: Load height maps request started");
@@ -403,13 +466,32 @@ namespace OpenSim.ApplicationPlugins.RemoteController
403 message = "Region is going down now."; 466 message = "Region is going down now.";
404 } 467 }
405 468
406 m_application.SceneManager.ForEachScene( 469 if (requestData.ContainsKey("noticetype")
470 && ((string) requestData["noticetype"] == "dialog"))
471 {
472 m_application.SceneManager.ForEachScene(
473
407 delegate(Scene scene) 474 delegate(Scene scene)
475 {
476 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>();
477 if (dialogModule != null)
478 dialogModule.SendNotificationToUsersInRegion(UUID.Zero, "System", message);
479 });
480 }
481 else
482 {
483 if (!requestData.ContainsKey("noticetype")
484 || ((string)requestData["noticetype"] != "none"))
485 {
486 m_application.SceneManager.ForEachScene(
487 delegate(Scene scene)
408 { 488 {
409 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>(); 489 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>();
410 if (dialogModule != null) 490 if (dialogModule != null)
411 dialogModule.SendGeneralAlert(message); 491 dialogModule.SendGeneralAlert(message);
412 }); 492 });
493 }
494 }
413 495
414 // Perform shutdown 496 // Perform shutdown
415 System.Timers.Timer shutdownTimer = new System.Timers.Timer(timeout); // Wait before firing 497 System.Timers.Timer shutdownTimer = new System.Timers.Timer(timeout); // Wait before firing
@@ -1642,8 +1724,6 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1642 1724
1643 private void XmlRpcRegionQueryMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) 1725 private void XmlRpcRegionQueryMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
1644 { 1726 {
1645 m_log.Info("[RADMIN]: Received Query XML Administrator Request");
1646
1647 Hashtable responseData = (Hashtable)response.Value; 1727 Hashtable responseData = (Hashtable)response.Value;
1648 Hashtable requestData = (Hashtable)request.Params[0]; 1728 Hashtable requestData = (Hashtable)request.Params[0];
1649 1729
@@ -1654,16 +1734,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1654 UUID region_uuid = (UUID) (string) requestData["region_uuid"]; 1734 UUID region_uuid = (UUID) (string) requestData["region_uuid"];
1655 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid)) 1735 if (!m_application.SceneManager.TrySetCurrentScene(region_uuid))
1656 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString())); 1736 throw new Exception(String.Format("failed to switch to region {0}", region_uuid.ToString()));
1657
1658 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_uuid.ToString());
1659 } 1737 }
1660 else if (requestData.Contains("region_name")) 1738 else if (requestData.Contains("region_name"))
1661 { 1739 {
1662 string region_name = (string) requestData["region_name"]; 1740 string region_name = (string) requestData["region_name"];
1663 if (!m_application.SceneManager.TrySetCurrentScene(region_name)) 1741 if (!m_application.SceneManager.TrySetCurrentScene(region_name))
1664 throw new Exception(String.Format("failed to switch to region {0}", region_name)); 1742 throw new Exception(String.Format("failed to switch to region {0}", region_name));
1665
1666 m_log.InfoFormat("[RADMIN]: Switched to region {0}", region_name);
1667 } 1743 }
1668 else 1744 else
1669 { 1745 {
@@ -1671,10 +1747,13 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1671 } 1747 }
1672 1748
1673 Scene scene = m_application.SceneManager.CurrentScene; 1749 Scene scene = m_application.SceneManager.CurrentScene;
1674 int health = scene.GetHealth();
1675 responseData["health"] = health;
1676 1750
1677 m_log.Info("[RADMIN]: Query XML Administrator Request complete"); 1751 int flags;
1752 string text;
1753 int health = scene.GetHealth(out flags, out text);
1754 responseData["health"] = health;
1755 responseData["flags"] = flags;
1756 responseData["message"] = text;
1678 } 1757 }
1679 1758
1680 private void XmlRpcConsoleCommandMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) 1759 private void XmlRpcConsoleCommandMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)