aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs')
-rw-r--r--OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs211
1 files changed, 195 insertions, 16 deletions
diff --git a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
index 6983479..f19e391 100644
--- a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
+++ b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
@@ -71,6 +71,7 @@ namespace OpenSim.ApplicationPlugins.RemoteController
71 71
72 private string m_name = "RemoteAdminPlugin"; 72 private string m_name = "RemoteAdminPlugin";
73 private string m_version = "0.0"; 73 private string m_version = "0.0";
74 private string m_openSimVersion;
74 75
75 public string Version 76 public string Version
76 { 77 {
@@ -90,6 +91,8 @@ namespace OpenSim.ApplicationPlugins.RemoteController
90 91
91 public void Initialise(OpenSimBase openSim) 92 public void Initialise(OpenSimBase openSim)
92 { 93 {
94 m_openSimVersion = openSim.GetVersionText();
95
93 m_configSource = openSim.ConfigSource.Source; 96 m_configSource = openSim.ConfigSource.Source;
94 try 97 try
95 { 98 {
@@ -132,6 +135,7 @@ namespace OpenSim.ApplicationPlugins.RemoteController
132 availableMethods["admin_region_query"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRegionQueryMethod); 135 availableMethods["admin_region_query"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRegionQueryMethod);
133 availableMethods["admin_shutdown"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcShutdownMethod); 136 availableMethods["admin_shutdown"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcShutdownMethod);
134 availableMethods["admin_broadcast"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAlertMethod); 137 availableMethods["admin_broadcast"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAlertMethod);
138 availableMethods["admin_dialog"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcDialogMethod);
135 availableMethods["admin_restart"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRestartMethod); 139 availableMethods["admin_restart"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRestartMethod);
136 availableMethods["admin_load_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcLoadHeightmapMethod); 140 availableMethods["admin_load_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcLoadHeightmapMethod);
137 availableMethods["admin_save_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcSaveHeightmapMethod); 141 availableMethods["admin_save_heightmap"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcSaveHeightmapMethod);
@@ -157,6 +161,10 @@ namespace OpenSim.ApplicationPlugins.RemoteController
157 availableMethods["admin_acl_remove"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAccessListRemove); 161 availableMethods["admin_acl_remove"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAccessListRemove);
158 availableMethods["admin_acl_list"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAccessListList); 162 availableMethods["admin_acl_list"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcAccessListList);
159 163
164 // Misc
165 availableMethods["admin_refresh_search"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcRefreshSearch);
166 availableMethods["admin_get_opensim_version"] = (req, ep) => InvokeXmlRpcMethod(req, ep, XmlRpcGetOpenSimVersion);
167
160 // Either enable full remote functionality or just selected features 168 // Either enable full remote functionality or just selected features
161 string enabledMethods = m_config.GetString("enabled_methods", "all"); 169 string enabledMethods = m_config.GetString("enabled_methods", "all");
162 170
@@ -258,23 +266,101 @@ namespace OpenSim.ApplicationPlugins.RemoteController
258 { 266 {
259 m_log.Info("[RADMIN]: Request to restart Region."); 267 m_log.Info("[RADMIN]: Request to restart Region.");
260 268
261 CheckRegionParams(requestData, responseData);
262
263 Scene rebootedScene = null; 269 Scene rebootedScene = null;
264 GetSceneFromRegionParams(requestData, responseData, out rebootedScene); 270 bool restartAll = false;
271
272 IConfig startupConfig = m_configSource.Configs["Startup"];
273 if (startupConfig != null)
274 {
275 if (startupConfig.GetBoolean("InworldRestartShutsDown", false))
276 {
277 rebootedScene = m_application.SceneManager.CurrentOrFirstScene;
278 restartAll = true;
279 }
280 }
281
282 if (rebootedScene == null)
283 {
284 CheckRegionParams(requestData, responseData);
285
286 GetSceneFromRegionParams(requestData, responseData, out rebootedScene);
287 }
288
289 IRestartModule restartModule = rebootedScene.RequestModuleInterface<IRestartModule>();
265 290
266 responseData["success"] = false; 291 responseData["success"] = false;
267 responseData["accepted"] = true; 292 responseData["accepted"] = true;
268 responseData["rebooting"] = true; 293 responseData["rebooting"] = true;
269 294
270 IRestartModule restartModule = rebootedScene.RequestModuleInterface<IRestartModule>(); 295 string message;
271 if (restartModule != null) 296 List<int> times = new List<int>();
297
298 if (requestData.ContainsKey("alerts"))
272 { 299 {
273 List<int> times = new List<int> { 30, 15 }; 300 string[] alertTimes = requestData["alerts"].ToString().Split( new char[] {','});
301 if (alertTimes.Length == 1 && Convert.ToInt32(alertTimes[0]) == -1)
302 {
303 if (restartModule != null)
304 {
305 message = "Restart has been cancelled";
274 306
275 restartModule.ScheduleRestart(UUID.Zero, "Region will restart in {0}", times.ToArray(), true); 307 if (requestData.ContainsKey("message"))
276 responseData["success"] = true; 308 message = requestData["message"].ToString();
309
310 restartModule.AbortRestart(message);
311
312 responseData["success"] = true;
313 responseData["rebooting"] = false;
314
315 return;
316 }
317 }
318 foreach (string a in alertTimes)
319 times.Add(Convert.ToInt32(a));
277 } 320 }
321 else
322 {
323 int timeout = 30;
324 if (requestData.ContainsKey("milliseconds"))
325 timeout = Int32.Parse(requestData["milliseconds"].ToString()) / 1000;
326 while (timeout > 0)
327 {
328 times.Add(timeout);
329 if (timeout > 300)
330 timeout -= 120;
331 else if (timeout > 30)
332 timeout -= 30;
333 else
334 timeout -= 15;
335 }
336 }
337
338 message = "Region is restarting in {0}. Please save what you are doing and log out.";
339
340 if (requestData.ContainsKey("message"))
341 message = requestData["message"].ToString();
342
343 bool notice = true;
344 if (requestData.ContainsKey("noticetype")
345 && ((string)requestData["noticetype"] == "dialog"))
346 {
347 notice = false;
348 }
349
350 List<Scene> restartList;
351
352 if (restartAll)
353 restartList = m_application.SceneManager.Scenes;
354 else
355 restartList = new List<Scene>() { rebootedScene };
356
357 foreach (Scene s in m_application.SceneManager.Scenes)
358 {
359 restartModule = s.RequestModuleInterface<IRestartModule>();
360 if (restartModule != null)
361 restartModule.ScheduleRestart(UUID.Zero, message, times.ToArray(), notice);
362 }
363 responseData["success"] = true;
278 } 364 }
279 catch (Exception e) 365 catch (Exception e)
280 { 366 {
@@ -311,6 +397,32 @@ namespace OpenSim.ApplicationPlugins.RemoteController
311 m_log.Info("[RADMIN]: Alert request complete"); 397 m_log.Info("[RADMIN]: Alert request complete");
312 } 398 }
313 399
400 public void XmlRpcDialogMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
401 {
402 Hashtable responseData = (Hashtable)response.Value;
403
404 m_log.Info("[RADMIN]: Dialog request started");
405
406 Hashtable requestData = (Hashtable)request.Params[0];
407
408 string message = (string)requestData["message"];
409 string fromuuid = (string)requestData["from"];
410 m_log.InfoFormat("[RADMIN]: Broadcasting: {0}", message);
411
412 responseData["accepted"] = true;
413 responseData["success"] = true;
414
415 m_application.SceneManager.ForEachScene(
416 delegate(Scene scene)
417 {
418 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>();
419 if (dialogModule != null)
420 dialogModule.SendNotificationToUsersInRegion(UUID.Zero, fromuuid, message);
421 });
422
423 m_log.Info("[RADMIN]: Dialog request complete");
424 }
425
314 private void XmlRpcLoadHeightmapMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) 426 private void XmlRpcLoadHeightmapMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
315 { 427 {
316 m_log.Info("[RADMIN]: Load height maps request started"); 428 m_log.Info("[RADMIN]: Load height maps request started");
@@ -399,13 +511,32 @@ namespace OpenSim.ApplicationPlugins.RemoteController
399 message = "Region is going down now."; 511 message = "Region is going down now.";
400 } 512 }
401 513
402 m_application.SceneManager.ForEachScene( 514 if (requestData.ContainsKey("noticetype")
515 && ((string) requestData["noticetype"] == "dialog"))
516 {
517 m_application.SceneManager.ForEachScene(
518
403 delegate(Scene scene) 519 delegate(Scene scene)
520 {
521 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>();
522 if (dialogModule != null)
523 dialogModule.SendNotificationToUsersInRegion(UUID.Zero, "System", message);
524 });
525 }
526 else
527 {
528 if (!requestData.ContainsKey("noticetype")
529 || ((string)requestData["noticetype"] != "none"))
530 {
531 m_application.SceneManager.ForEachScene(
532 delegate(Scene scene)
404 { 533 {
405 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>(); 534 IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>();
406 if (dialogModule != null) 535 if (dialogModule != null)
407 dialogModule.SendGeneralAlert(message); 536 dialogModule.SendGeneralAlert(message);
408 }); 537 });
538 }
539 }
409 540
410 // Perform shutdown 541 // Perform shutdown
411 System.Timers.Timer shutdownTimer = new System.Timers.Timer(timeout); // Wait before firing 542 System.Timers.Timer shutdownTimer = new System.Timers.Timer(timeout); // Wait before firing
@@ -1577,21 +1708,31 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1577 1708
1578 private void XmlRpcRegionQueryMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) 1709 private void XmlRpcRegionQueryMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
1579 { 1710 {
1580 m_log.Info("[RADMIN]: Received Query XML Administrator Request");
1581
1582 Hashtable responseData = (Hashtable)response.Value; 1711 Hashtable responseData = (Hashtable)response.Value;
1583 Hashtable requestData = (Hashtable)request.Params[0]; 1712 Hashtable requestData = (Hashtable)request.Params[0];
1584 1713
1714 int flags = 0;
1715 string text = String.Empty;
1716 int health = 0;
1717 responseData["success"] = true;
1718
1585 CheckRegionParams(requestData, responseData); 1719 CheckRegionParams(requestData, responseData);
1586 1720
1587 Scene scene = null; 1721 Scene scene = null;
1588 GetSceneFromRegionParams(requestData, responseData, out scene); 1722 try
1589 1723 {
1590 int health = scene.GetHealth(); 1724 GetSceneFromRegionParams(requestData, responseData, out scene);
1591 responseData["health"] = health; 1725 health = scene.GetHealth(out flags, out text);
1726 }
1727 catch (Exception e)
1728 {
1729 responseData["error"] = null;
1730 }
1592 1731
1593 responseData["success"] = true; 1732 responseData["success"] = true;
1594 m_log.Info("[RADMIN]: Query XML Administrator Request complete"); 1733 responseData["health"] = health;
1734 responseData["flags"] = flags;
1735 responseData["message"] = text;
1595 } 1736 }
1596 1737
1597 private void XmlRpcConsoleCommandMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) 1738 private void XmlRpcConsoleCommandMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
@@ -1815,6 +1956,44 @@ namespace OpenSim.ApplicationPlugins.RemoteController
1815 responseData["success"] = true; 1956 responseData["success"] = true;
1816 } 1957 }
1817 1958
1959 private void XmlRpcRefreshSearch(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
1960 {
1961 m_log.Info("[RADMIN]: Received Refresh Search Request");
1962
1963 Hashtable responseData = (Hashtable)response.Value;
1964 Hashtable requestData = (Hashtable)request.Params[0];
1965
1966 CheckRegionParams(requestData, responseData);
1967
1968 Scene scene = null;
1969 GetSceneFromRegionParams(requestData, responseData, out scene);
1970
1971 ISearchModule searchModule = scene.RequestModuleInterface<ISearchModule>();
1972 if (searchModule != null)
1973 {
1974 searchModule.Refresh();
1975 responseData["success"] = true;
1976 }
1977 else
1978 {
1979 responseData["success"] = false;
1980 }
1981
1982 m_log.Info("[RADMIN]: Refresh Search Request complete");
1983 }
1984
1985 private void XmlRpcGetOpenSimVersion(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient)
1986 {
1987 m_log.Info("[RADMIN]: Received Get OpenSim Version Request");
1988
1989 Hashtable responseData = (Hashtable)response.Value;
1990
1991 responseData["version"] = m_openSimVersion;
1992 responseData["success"] = true;
1993
1994 m_log.Info("[RADMIN]: Get OpenSim Version Request complete");
1995 }
1996
1818 /// <summary> 1997 /// <summary>
1819 /// Parse a float with the given parameter name from a request data hash table. 1998 /// Parse a float with the given parameter name from a request data hash table.
1820 /// </summary> 1999 /// </summary>