diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs | 166 |
1 files changed, 150 insertions, 16 deletions
diff --git a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs index a75d10d..3d80eb6 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); |
@@ -257,23 +258,101 @@ namespace OpenSim.ApplicationPlugins.RemoteController | |||
257 | { | 258 | { |
258 | m_log.Info("[RADMIN]: Request to restart Region."); | 259 | m_log.Info("[RADMIN]: Request to restart Region."); |
259 | 260 | ||
260 | CheckRegionParams(requestData, responseData); | ||
261 | |||
262 | Scene rebootedScene = null; | 261 | Scene rebootedScene = null; |
263 | GetSceneFromRegionParams(requestData, responseData, out rebootedScene); | 262 | bool restartAll = false; |
263 | |||
264 | IConfig startupConfig = m_configSource.Configs["Startup"]; | ||
265 | if (startupConfig != null) | ||
266 | { | ||
267 | if (startupConfig.GetBoolean("InworldRestartShutsDown", false)) | ||
268 | { | ||
269 | rebootedScene = m_application.SceneManager.CurrentOrFirstScene; | ||
270 | restartAll = true; | ||
271 | } | ||
272 | } | ||
273 | |||
274 | if (rebootedScene == null) | ||
275 | { | ||
276 | CheckRegionParams(requestData, responseData); | ||
277 | |||
278 | GetSceneFromRegionParams(requestData, responseData, out rebootedScene); | ||
279 | } | ||
280 | |||
281 | IRestartModule restartModule = rebootedScene.RequestModuleInterface<IRestartModule>(); | ||
264 | 282 | ||
265 | responseData["success"] = false; | 283 | responseData["success"] = false; |
266 | responseData["accepted"] = true; | 284 | responseData["accepted"] = true; |
267 | responseData["rebooting"] = true; | 285 | responseData["rebooting"] = true; |
268 | 286 | ||
269 | IRestartModule restartModule = rebootedScene.RequestModuleInterface<IRestartModule>(); | 287 | string message; |
270 | if (restartModule != null) | 288 | List<int> times = new List<int>(); |
289 | |||
290 | if (requestData.ContainsKey("alerts")) | ||
271 | { | 291 | { |
272 | List<int> times = new List<int> { 30, 15 }; | 292 | string[] alertTimes = requestData["alerts"].ToString().Split( new char[] {','}); |
293 | if (alertTimes.Length == 1 && Convert.ToInt32(alertTimes[0]) == -1) | ||
294 | { | ||
295 | if (restartModule != null) | ||
296 | { | ||
297 | message = "Restart has been cancelled"; | ||
273 | 298 | ||
274 | restartModule.ScheduleRestart(UUID.Zero, "Region will restart in {0}", times.ToArray(), true); | 299 | if (requestData.ContainsKey("message")) |
275 | responseData["success"] = true; | 300 | message = requestData["message"].ToString(); |
301 | |||
302 | restartModule.AbortRestart(message); | ||
303 | |||
304 | responseData["success"] = true; | ||
305 | responseData["rebooting"] = false; | ||
306 | |||
307 | return; | ||
308 | } | ||
309 | } | ||
310 | foreach (string a in alertTimes) | ||
311 | times.Add(Convert.ToInt32(a)); | ||
276 | } | 312 | } |
313 | else | ||
314 | { | ||
315 | int timeout = 30; | ||
316 | if (requestData.ContainsKey("milliseconds")) | ||
317 | timeout = Int32.Parse(requestData["milliseconds"].ToString()) / 1000; | ||
318 | while (timeout > 0) | ||
319 | { | ||
320 | times.Add(timeout); | ||
321 | if (timeout > 300) | ||
322 | timeout -= 120; | ||
323 | else if (timeout > 30) | ||
324 | timeout -= 30; | ||
325 | else | ||
326 | timeout -= 15; | ||
327 | } | ||
328 | } | ||
329 | |||
330 | message = "Region is restarting in {0}. Please save what you are doing and log out."; | ||
331 | |||
332 | if (requestData.ContainsKey("message")) | ||
333 | message = requestData["message"].ToString(); | ||
334 | |||
335 | bool notice = true; | ||
336 | if (requestData.ContainsKey("noticetype") | ||
337 | && ((string)requestData["noticetype"] == "dialog")) | ||
338 | { | ||
339 | notice = false; | ||
340 | } | ||
341 | |||
342 | List<Scene> restartList; | ||
343 | |||
344 | if (restartAll) | ||
345 | restartList = m_application.SceneManager.Scenes; | ||
346 | else | ||
347 | restartList = new List<Scene>() { rebootedScene }; | ||
348 | |||
349 | foreach (Scene s in m_application.SceneManager.Scenes) | ||
350 | { | ||
351 | restartModule = s.RequestModuleInterface<IRestartModule>(); | ||
352 | if (restartModule != null) | ||
353 | restartModule.ScheduleRestart(UUID.Zero, message, times.ToArray(), notice); | ||
354 | } | ||
355 | responseData["success"] = true; | ||
277 | } | 356 | } |
278 | catch (Exception e) | 357 | catch (Exception e) |
279 | { | 358 | { |
@@ -310,6 +389,32 @@ namespace OpenSim.ApplicationPlugins.RemoteController | |||
310 | m_log.Info("[RADMIN]: Alert request complete"); | 389 | m_log.Info("[RADMIN]: Alert request complete"); |
311 | } | 390 | } |
312 | 391 | ||
392 | public void XmlRpcDialogMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) | ||
393 | { | ||
394 | Hashtable responseData = (Hashtable)response.Value; | ||
395 | |||
396 | m_log.Info("[RADMIN]: Dialog request started"); | ||
397 | |||
398 | Hashtable requestData = (Hashtable)request.Params[0]; | ||
399 | |||
400 | string message = (string)requestData["message"]; | ||
401 | string fromuuid = (string)requestData["from"]; | ||
402 | m_log.InfoFormat("[RADMIN]: Broadcasting: {0}", message); | ||
403 | |||
404 | responseData["accepted"] = true; | ||
405 | responseData["success"] = true; | ||
406 | |||
407 | m_application.SceneManager.ForEachScene( | ||
408 | delegate(Scene scene) | ||
409 | { | ||
410 | IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>(); | ||
411 | if (dialogModule != null) | ||
412 | dialogModule.SendNotificationToUsersInRegion(UUID.Zero, fromuuid, message); | ||
413 | }); | ||
414 | |||
415 | m_log.Info("[RADMIN]: Dialog request complete"); | ||
416 | } | ||
417 | |||
313 | private void XmlRpcLoadHeightmapMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) | 418 | private void XmlRpcLoadHeightmapMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) |
314 | { | 419 | { |
315 | m_log.Info("[RADMIN]: Load height maps request started"); | 420 | m_log.Info("[RADMIN]: Load height maps request started"); |
@@ -398,13 +503,32 @@ namespace OpenSim.ApplicationPlugins.RemoteController | |||
398 | message = "Region is going down now."; | 503 | message = "Region is going down now."; |
399 | } | 504 | } |
400 | 505 | ||
401 | m_application.SceneManager.ForEachScene( | 506 | if (requestData.ContainsKey("noticetype") |
507 | && ((string) requestData["noticetype"] == "dialog")) | ||
508 | { | ||
509 | m_application.SceneManager.ForEachScene( | ||
510 | |||
402 | delegate(Scene scene) | 511 | delegate(Scene scene) |
512 | { | ||
513 | IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>(); | ||
514 | if (dialogModule != null) | ||
515 | dialogModule.SendNotificationToUsersInRegion(UUID.Zero, "System", message); | ||
516 | }); | ||
517 | } | ||
518 | else | ||
519 | { | ||
520 | if (!requestData.ContainsKey("noticetype") | ||
521 | || ((string)requestData["noticetype"] != "none")) | ||
522 | { | ||
523 | m_application.SceneManager.ForEachScene( | ||
524 | delegate(Scene scene) | ||
403 | { | 525 | { |
404 | IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>(); | 526 | IDialogModule dialogModule = scene.RequestModuleInterface<IDialogModule>(); |
405 | if (dialogModule != null) | 527 | if (dialogModule != null) |
406 | dialogModule.SendGeneralAlert(message); | 528 | dialogModule.SendGeneralAlert(message); |
407 | }); | 529 | }); |
530 | } | ||
531 | } | ||
408 | 532 | ||
409 | // Perform shutdown | 533 | // Perform shutdown |
410 | System.Timers.Timer shutdownTimer = new System.Timers.Timer(timeout); // Wait before firing | 534 | System.Timers.Timer shutdownTimer = new System.Timers.Timer(timeout); // Wait before firing |
@@ -1576,21 +1700,31 @@ namespace OpenSim.ApplicationPlugins.RemoteController | |||
1576 | 1700 | ||
1577 | private void XmlRpcRegionQueryMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) | 1701 | private void XmlRpcRegionQueryMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) |
1578 | { | 1702 | { |
1579 | m_log.Info("[RADMIN]: Received Query XML Administrator Request"); | ||
1580 | |||
1581 | Hashtable responseData = (Hashtable)response.Value; | 1703 | Hashtable responseData = (Hashtable)response.Value; |
1582 | Hashtable requestData = (Hashtable)request.Params[0]; | 1704 | Hashtable requestData = (Hashtable)request.Params[0]; |
1583 | 1705 | ||
1706 | int flags = 0; | ||
1707 | string text = String.Empty; | ||
1708 | int health = 0; | ||
1709 | responseData["success"] = true; | ||
1710 | |||
1584 | CheckRegionParams(requestData, responseData); | 1711 | CheckRegionParams(requestData, responseData); |
1585 | 1712 | ||
1586 | Scene scene = null; | 1713 | Scene scene = null; |
1587 | GetSceneFromRegionParams(requestData, responseData, out scene); | 1714 | try |
1588 | 1715 | { | |
1589 | int health = scene.GetHealth(); | 1716 | GetSceneFromRegionParams(requestData, responseData, out scene); |
1590 | responseData["health"] = health; | 1717 | health = scene.GetHealth(out flags, out text); |
1718 | } | ||
1719 | catch (Exception e) | ||
1720 | { | ||
1721 | responseData["error"] = null; | ||
1722 | } | ||
1591 | 1723 | ||
1592 | responseData["success"] = true; | 1724 | responseData["success"] = true; |
1593 | m_log.Info("[RADMIN]: Query XML Administrator Request complete"); | 1725 | responseData["health"] = health; |
1726 | responseData["flags"] = flags; | ||
1727 | responseData["message"] = text; | ||
1594 | } | 1728 | } |
1595 | 1729 | ||
1596 | private void XmlRpcConsoleCommandMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) | 1730 | private void XmlRpcConsoleCommandMethod(XmlRpcRequest request, XmlRpcResponse response, IPEndPoint remoteClient) |