aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Application/OpenSimBase.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Application/OpenSimBase.cs84
1 files changed, 84 insertions, 0 deletions
diff --git a/OpenSim/Region/Application/OpenSimBase.cs b/OpenSim/Region/Application/OpenSimBase.cs
index 808c760..7bef1aa 100644
--- a/OpenSim/Region/Application/OpenSimBase.cs
+++ b/OpenSim/Region/Application/OpenSimBase.cs
@@ -97,6 +97,10 @@ namespace OpenSim
97 97
98 protected List<IApplicationPlugin> m_plugins = new List<IApplicationPlugin>(); 98 protected List<IApplicationPlugin> m_plugins = new List<IApplicationPlugin>();
99 99
100 private List<string> m_permsModules;
101
102 private bool m_securePermissionsLoading = true;
103
100 /// <value> 104 /// <value>
101 /// The config information passed into the OpenSimulator region server. 105 /// The config information passed into the OpenSimulator region server.
102 /// </value> 106 /// </value>
@@ -193,6 +197,11 @@ namespace OpenSim
193 CreatePIDFile(pidFile); 197 CreatePIDFile(pidFile);
194 198
195 userStatsURI = startupConfig.GetString("Stats_URI", String.Empty); 199 userStatsURI = startupConfig.GetString("Stats_URI", String.Empty);
200
201 m_securePermissionsLoading = startupConfig.GetBoolean("SecurePermissionsLoading", true);
202
203 string permissionModules = startupConfig.GetString("permissionmodules", "DefaultPermissionsModule");
204 m_permsModules = new List<string>(permissionModules.Split(','));
196 } 205 }
197 206
198 // Load the simulation data service 207 // Load the simulation data service
@@ -230,6 +239,12 @@ namespace OpenSim
230 base.StartupSpecific(); 239 base.StartupSpecific();
231 240
232 LoadPlugins(); 241 LoadPlugins();
242
243 if (m_plugins.Count == 0) // We failed to load any modules. Mono Addins glitch!
244 {
245 Environment.Exit(1);
246 }
247
233 foreach (IApplicationPlugin plugin in m_plugins) 248 foreach (IApplicationPlugin plugin in m_plugins)
234 { 249 {
235 plugin.PostInitialise(); 250 plugin.PostInitialise();
@@ -382,7 +397,42 @@ namespace OpenSim
382 } 397 }
383 else m_log.Error("[REGIONMODULES]: The new RegionModulesController is missing..."); 398 else m_log.Error("[REGIONMODULES]: The new RegionModulesController is missing...");
384 399
400 // XPTO: Fix this
401// if (m_securePermissionsLoading)
402// {
403// foreach (string s in m_permsModules)
404// {
405// if (!scene.RegionModules.ContainsKey(s))
406// {
407// bool found = false;
408// foreach (IRegionModule m in modules)
409// {
410// if (m.Name == s)
411// {
412// found = true;
413// }
414// }
415// if (!found)
416// {
417// m_log.Fatal("[MODULES]: Required module " + s + " not found.");
418// Environment.Exit(0);
419// }
420// }
421// }
422// }
423
385 scene.SetModuleInterfaces(); 424 scene.SetModuleInterfaces();
425// First Step of bootreport sequence
426 if (scene.SnmpService != null)
427 {
428 scene.SnmpService.ColdStart(1,scene);
429 scene.SnmpService.LinkDown(scene);
430 }
431
432 if (scene.SnmpService != null)
433 {
434 scene.SnmpService.BootInfo("Loading prins", scene);
435 }
386 436
387 while (regionInfo.EstateSettings.EstateOwner == UUID.Zero && MainConsole.Instance != null) 437 while (regionInfo.EstateSettings.EstateOwner == UUID.Zero && MainConsole.Instance != null)
388 SetUpEstateOwner(scene); 438 SetUpEstateOwner(scene);
@@ -396,6 +446,11 @@ namespace OpenSim
396 scene.loadAllLandObjectsFromStorage(regionInfo.originRegionID); 446 scene.loadAllLandObjectsFromStorage(regionInfo.originRegionID);
397 scene.EventManager.TriggerParcelPrimCountUpdate(); 447 scene.EventManager.TriggerParcelPrimCountUpdate();
398 448
449 if (scene.SnmpService != null)
450 {
451 scene.SnmpService.BootInfo("Grid Registration in progress", scene);
452 }
453
399 try 454 try
400 { 455 {
401 scene.RegisterRegionWithGrid(); 456 scene.RegisterRegionWithGrid();
@@ -406,15 +461,29 @@ namespace OpenSim
406 "[STARTUP]: Registration of region with grid failed, aborting startup due to {0} {1}", 461 "[STARTUP]: Registration of region with grid failed, aborting startup due to {0} {1}",
407 e.Message, e.StackTrace); 462 e.Message, e.StackTrace);
408 463
464 if (scene.SnmpService != null)
465 {
466 scene.SnmpService.Critical("Grid registration failed. Startup aborted.", scene);
467 }
409 // Carrying on now causes a lot of confusion down the 468 // Carrying on now causes a lot of confusion down the
410 // line - we need to get the user's attention 469 // line - we need to get the user's attention
411 Environment.Exit(1); 470 Environment.Exit(1);
412 } 471 }
413 472
473 if (scene.SnmpService != null)
474 {
475 scene.SnmpService.BootInfo("Grid Registration done", scene);
476 }
477
414 // We need to do this after we've initialized the 478 // We need to do this after we've initialized the
415 // scripting engines. 479 // scripting engines.
416 scene.CreateScriptInstances(); 480 scene.CreateScriptInstances();
417 481
482 if (scene.SnmpService != null)
483 {
484 scene.SnmpService.BootInfo("ScriptEngine started", scene);
485 }
486
418 SceneManager.Add(scene); 487 SceneManager.Add(scene);
419 488
420 if (m_autoCreateClientStack) 489 if (m_autoCreateClientStack)
@@ -423,10 +492,20 @@ namespace OpenSim
423 clientServer.Start(); 492 clientServer.Start();
424 } 493 }
425 494
495 if (scene.SnmpService != null)
496 {
497 scene.SnmpService.BootInfo("Initializing region modules", scene);
498 }
426 scene.EventManager.OnShutdown += delegate() { ShutdownRegion(scene); }; 499 scene.EventManager.OnShutdown += delegate() { ShutdownRegion(scene); };
427 500
428 mscene = scene; 501 mscene = scene;
429 502
503 if (scene.SnmpService != null)
504 {
505 scene.SnmpService.BootInfo("The region is operational", scene);
506 scene.SnmpService.LinkUp(scene);
507 }
508
430 scene.Start(); 509 scene.Start();
431 scene.StartScripts(); 510 scene.StartScripts();
432 511
@@ -545,6 +624,11 @@ namespace OpenSim
545 private void ShutdownRegion(Scene scene) 624 private void ShutdownRegion(Scene scene)
546 { 625 {
547 m_log.DebugFormat("[SHUTDOWN]: Shutting down region {0}", scene.RegionInfo.RegionName); 626 m_log.DebugFormat("[SHUTDOWN]: Shutting down region {0}", scene.RegionInfo.RegionName);
627 if (scene.SnmpService != null)
628 {
629 scene.SnmpService.BootInfo("The region is shutting down", scene);
630 scene.SnmpService.LinkDown(scene);
631 }
548 IRegionModulesController controller; 632 IRegionModulesController controller;
549 if (ApplicationRegistry.TryGet<IRegionModulesController>(out controller)) 633 if (ApplicationRegistry.TryGet<IRegionModulesController>(out controller))
550 { 634 {