aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Application/OpenSimBase.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/Application/OpenSimBase.cs103
1 files changed, 99 insertions, 4 deletions
diff --git a/OpenSim/Region/Application/OpenSimBase.cs b/OpenSim/Region/Application/OpenSimBase.cs
index 866ba9a..3e58287 100644
--- a/OpenSim/Region/Application/OpenSimBase.cs
+++ b/OpenSim/Region/Application/OpenSimBase.cs
@@ -92,6 +92,10 @@ namespace OpenSim
92 92
93 protected List<IApplicationPlugin> m_plugins = new List<IApplicationPlugin>(); 93 protected List<IApplicationPlugin> m_plugins = new List<IApplicationPlugin>();
94 94
95 private List<string> m_permsModules;
96
97 private bool m_securePermissionsLoading = true;
98
95 /// <value> 99 /// <value>
96 /// The config information passed into the OpenSimulator region server. 100 /// The config information passed into the OpenSimulator region server.
97 /// </value> 101 /// </value>
@@ -189,6 +193,11 @@ namespace OpenSim
189 CreatePIDFile(pidFile); 193 CreatePIDFile(pidFile);
190 194
191 userStatsURI = startupConfig.GetString("Stats_URI", String.Empty); 195 userStatsURI = startupConfig.GetString("Stats_URI", String.Empty);
196
197 m_securePermissionsLoading = startupConfig.GetBoolean("SecurePermissionsLoading", true);
198
199 string permissionModules = startupConfig.GetString("permissionmodules", "DefaultPermissionsModule");
200 m_permsModules = new List<string>(permissionModules.Split(','));
192 } 201 }
193 202
194 // Load the simulation data service 203 // Load the simulation data service
@@ -217,6 +226,12 @@ namespace OpenSim
217 m_moduleLoader = new ModuleLoader(m_config.Source); 226 m_moduleLoader = new ModuleLoader(m_config.Source);
218 227
219 LoadPlugins(); 228 LoadPlugins();
229
230 if (m_plugins.Count == 0) // We failed to load any modules. Mono Addins glitch!
231 {
232 Environment.Exit(1);
233 }
234
220 foreach (IApplicationPlugin plugin in m_plugins) 235 foreach (IApplicationPlugin plugin in m_plugins)
221 { 236 {
222 plugin.PostInitialise(); 237 plugin.PostInitialise();
@@ -364,7 +379,41 @@ namespace OpenSim
364 } 379 }
365 else m_log.Error("[REGIONMODULES]: The new RegionModulesController is missing..."); 380 else m_log.Error("[REGIONMODULES]: The new RegionModulesController is missing...");
366 381
382 if (m_securePermissionsLoading)
383 {
384 foreach (string s in m_permsModules)
385 {
386 if (!scene.RegionModules.ContainsKey(s))
387 {
388 bool found = false;
389 foreach (IRegionModule m in modules)
390 {
391 if (m.Name == s)
392 {
393 found = true;
394 }
395 }
396 if (!found)
397 {
398 m_log.Fatal("[MODULES]: Required module " + s + " not found.");
399 Environment.Exit(0);
400 }
401 }
402 }
403 }
404
367 scene.SetModuleInterfaces(); 405 scene.SetModuleInterfaces();
406// First Step of bootreport sequence
407 if (scene.SnmpService != null)
408 {
409 scene.SnmpService.ColdStart(1,scene);
410 scene.SnmpService.LinkDown(scene);
411 }
412
413 if (scene.SnmpService != null)
414 {
415 scene.SnmpService.BootInfo("Loading prins", scene);
416 }
368 417
369 while (regionInfo.EstateSettings.EstateOwner == UUID.Zero && MainConsole.Instance != null) 418 while (regionInfo.EstateSettings.EstateOwner == UUID.Zero && MainConsole.Instance != null)
370 SetUpEstateOwner(scene); 419 SetUpEstateOwner(scene);
@@ -375,6 +424,10 @@ namespace OpenSim
375 // TODO : Try setting resource for region xstats here on scene 424 // TODO : Try setting resource for region xstats here on scene
376 MainServer.Instance.AddStreamHandler(new Region.Framework.Scenes.RegionStatsHandler(regionInfo)); 425 MainServer.Instance.AddStreamHandler(new Region.Framework.Scenes.RegionStatsHandler(regionInfo));
377 426
427 if (scene.SnmpService != null)
428 {
429 scene.SnmpService.BootInfo("Grid Registration in progress", scene);
430 }
378 try 431 try
379 { 432 {
380 scene.RegisterRegionWithGrid(); 433 scene.RegisterRegionWithGrid();
@@ -385,11 +438,20 @@ namespace OpenSim
385 "[STARTUP]: Registration of region with grid failed, aborting startup due to {0} {1}", 438 "[STARTUP]: Registration of region with grid failed, aborting startup due to {0} {1}",
386 e.Message, e.StackTrace); 439 e.Message, e.StackTrace);
387 440
441 if (scene.SnmpService != null)
442 {
443 scene.SnmpService.Critical("Grid registration failed. Startup aborted.", scene);
444 }
388 // Carrying on now causes a lot of confusion down the 445 // Carrying on now causes a lot of confusion down the
389 // line - we need to get the user's attention 446 // line - we need to get the user's attention
390 Environment.Exit(1); 447 Environment.Exit(1);
391 } 448 }
392 449
450 if (scene.SnmpService != null)
451 {
452 scene.SnmpService.BootInfo("Grid Registration done", scene);
453 }
454
393 scene.loadAllLandObjectsFromStorage(regionInfo.originRegionID); 455 scene.loadAllLandObjectsFromStorage(regionInfo.originRegionID);
394 scene.EventManager.TriggerParcelPrimCountUpdate(); 456 scene.EventManager.TriggerParcelPrimCountUpdate();
395 457
@@ -397,6 +459,11 @@ namespace OpenSim
397 // scripting engines. 459 // scripting engines.
398 scene.CreateScriptInstances(); 460 scene.CreateScriptInstances();
399 461
462 if (scene.SnmpService != null)
463 {
464 scene.SnmpService.BootInfo("ScriptEngine started", scene);
465 }
466
400 m_sceneManager.Add(scene); 467 m_sceneManager.Add(scene);
401 468
402 if (m_autoCreateClientStack) 469 if (m_autoCreateClientStack)
@@ -405,6 +472,10 @@ namespace OpenSim
405 clientServer.Start(); 472 clientServer.Start();
406 } 473 }
407 474
475 if (scene.SnmpService != null)
476 {
477 scene.SnmpService.BootInfo("Initializing region modules", scene);
478 }
408 if (do_post_init) 479 if (do_post_init)
409 { 480 {
410 foreach (IRegionModule module in modules) 481 foreach (IRegionModule module in modules)
@@ -416,7 +487,14 @@ namespace OpenSim
416 487
417 mscene = scene; 488 mscene = scene;
418 489
490 if (scene.SnmpService != null)
491 {
492 scene.SnmpService.BootInfo("The region is operational", scene);
493 scene.SnmpService.LinkUp(scene);
494 }
495
419 scene.StartTimer(); 496 scene.StartTimer();
497 scene.StartTimerWatchdog();
420 498
421 scene.StartScripts(); 499 scene.StartScripts();
422 500
@@ -462,9 +540,18 @@ namespace OpenSim
462 string password = MainConsole.Instance.PasswdPrompt("Password"); 540 string password = MainConsole.Instance.PasswdPrompt("Password");
463 string email = MainConsole.Instance.CmdPrompt("Email", ""); 541 string email = MainConsole.Instance.CmdPrompt("Email", "");
464 542
543 string rawPrincipalId = MainConsole.Instance.CmdPrompt("ID", UUID.Random().ToString());
544
545 UUID principalId = UUID.Zero;
546 if (!UUID.TryParse(rawPrincipalId, out principalId))
547 {
548 m_log.ErrorFormat("[OPENSIM]: ID {0} is not a valid UUID", rawPrincipalId);
549 return;
550 }
551
465 account 552 account
466 = ((UserAccountService)scene.UserAccountService).CreateUser( 553 = ((UserAccountService)scene.UserAccountService).CreateUser(
467 regionInfo.ScopeID, first, last, password, email); 554 regionInfo.ScopeID, principalId, first, last, password, email);
468 } 555 }
469// } 556// }
470 } 557 }
@@ -484,6 +571,11 @@ namespace OpenSim
484 private void ShutdownRegion(Scene scene) 571 private void ShutdownRegion(Scene scene)
485 { 572 {
486 m_log.DebugFormat("[SHUTDOWN]: Shutting down region {0}", scene.RegionInfo.RegionName); 573 m_log.DebugFormat("[SHUTDOWN]: Shutting down region {0}", scene.RegionInfo.RegionName);
574 if (scene.SnmpService != null)
575 {
576 scene.SnmpService.BootInfo("The region is shutting down", scene);
577 scene.SnmpService.LinkDown(scene);
578 }
487 IRegionModulesController controller; 579 IRegionModulesController controller;
488 if (ApplicationRegistry.TryGet<IRegionModulesController>(out controller)) 580 if (ApplicationRegistry.TryGet<IRegionModulesController>(out controller))
489 { 581 {
@@ -927,7 +1019,7 @@ namespace OpenSim
927 = MainConsole.Instance.CmdPrompt( 1019 = MainConsole.Instance.CmdPrompt(
928 string.Format( 1020 string.Format(
929 "Do you wish to join region {0} to an existing estate (yes/no)?", regInfo.RegionName), 1021 "Do you wish to join region {0} to an existing estate (yes/no)?", regInfo.RegionName),
930 "yes", 1022 "no",
931 new List<string>() { "yes", "no" }); 1023 new List<string>() { "yes", "no" });
932 1024
933 if (response == "no") 1025 if (response == "no")
@@ -943,12 +1035,15 @@ namespace OpenSim
943 = MainConsole.Instance.CmdPrompt( 1035 = MainConsole.Instance.CmdPrompt(
944 string.Format( 1036 string.Format(
945 "Name of estate to join. Existing estate names are ({0})", string.Join(", ", estateNames.ToArray())), 1037 "Name of estate to join. Existing estate names are ({0})", string.Join(", ", estateNames.ToArray())),
946 estateNames[0]); 1038 "None");
1039
1040 if (response == "None")
1041 continue;
947 1042
948 List<int> estateIDs = EstateDataService.GetEstates(response); 1043 List<int> estateIDs = EstateDataService.GetEstates(response);
949 if (estateIDs.Count < 1) 1044 if (estateIDs.Count < 1)
950 { 1045 {
951 MainConsole.Instance.Output("The name you have entered matches no known estate. Please try again."); 1046 MainConsole.Instance.Output("The name you have entered matches no known estate. Please try again.");
952 continue; 1047 continue;
953 } 1048 }
954 1049