aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/CoreModules/Scripting/EMailModules/EmailModule.cs24
-rw-r--r--OpenSim/Region/Framework/Scenes/Scene.cs81
-rw-r--r--OpenSim/Region/Framework/Scenes/ScenePresence.cs103
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs28
4 files changed, 172 insertions, 64 deletions
diff --git a/OpenSim/Region/CoreModules/Scripting/EMailModules/EmailModule.cs b/OpenSim/Region/CoreModules/Scripting/EMailModules/EmailModule.cs
index 9255791..e91e8b9 100644
--- a/OpenSim/Region/CoreModules/Scripting/EMailModules/EmailModule.cs
+++ b/OpenSim/Region/CoreModules/Scripting/EMailModules/EmailModule.cs
@@ -64,6 +64,8 @@ namespace OpenSim.Region.CoreModules.Scripting.EmailModules
64 private TimeSpan m_QueueTimeout = new TimeSpan(2, 0, 0); // 2 hours without llGetNextEmail drops the queue 64 private TimeSpan m_QueueTimeout = new TimeSpan(2, 0, 0); // 2 hours without llGetNextEmail drops the queue
65 private string m_InterObjectHostname = "lsl.opensim.local"; 65 private string m_InterObjectHostname = "lsl.opensim.local";
66 66
67 private int m_MaxEmailSize = 4096; // largest email allowed by default, as per lsl docs.
68
67 // Scenes by Region Handle 69 // Scenes by Region Handle
68 private Dictionary<ulong, Scene> m_Scenes = 70 private Dictionary<ulong, Scene> m_Scenes =
69 new Dictionary<ulong, Scene>(); 71 new Dictionary<ulong, Scene>();
@@ -127,6 +129,7 @@ namespace OpenSim.Region.CoreModules.Scripting.EmailModules
127 SMTP_SERVER_PORT = SMTPConfig.GetInt("SMTP_SERVER_PORT", SMTP_SERVER_PORT); 129 SMTP_SERVER_PORT = SMTPConfig.GetInt("SMTP_SERVER_PORT", SMTP_SERVER_PORT);
128 SMTP_SERVER_LOGIN = SMTPConfig.GetString("SMTP_SERVER_LOGIN", SMTP_SERVER_LOGIN); 130 SMTP_SERVER_LOGIN = SMTPConfig.GetString("SMTP_SERVER_LOGIN", SMTP_SERVER_LOGIN);
129 SMTP_SERVER_PASSWORD = SMTPConfig.GetString("SMTP_SERVER_PASSWORD", SMTP_SERVER_PASSWORD); 131 SMTP_SERVER_PASSWORD = SMTPConfig.GetString("SMTP_SERVER_PASSWORD", SMTP_SERVER_PASSWORD);
132 m_MaxEmailSize = SMTPConfig.GetInt("email_max_size", m_MaxEmailSize);
130 } 133 }
131 catch (Exception e) 134 catch (Exception e)
132 { 135 {
@@ -176,18 +179,6 @@ namespace OpenSim.Region.CoreModules.Scripting.EmailModules
176 get { return true; } 179 get { return true; }
177 } 180 }
178 181
179 /// <summary>
180 /// Delay function using thread in seconds
181 /// </summary>
182 /// <param name="seconds"></param>
183 private void DelayInSeconds(int delay)
184 {
185 delay = (int)((float)delay * 1000);
186 if (delay == 0)
187 return;
188 System.Threading.Thread.Sleep(delay);
189 }
190
191 private bool IsLocal(UUID objectID) 182 private bool IsLocal(UUID objectID)
192 { 183 {
193 string unused; 184 string unused;
@@ -267,10 +258,9 @@ namespace OpenSim.Region.CoreModules.Scripting.EmailModules
267 m_log.Error("[EMAIL] REGEX Problem in EMail Address: "+address); 258 m_log.Error("[EMAIL] REGEX Problem in EMail Address: "+address);
268 return; 259 return;
269 } 260 }
270 //FIXME:Check if subject + body = 4096 Byte 261 if ((subject.Length + body.Length) > m_MaxEmailSize)
271 if ((subject.Length + body.Length) > 1024)
272 { 262 {
273 m_log.Error("[EMAIL] subject + body > 1024 Byte"); 263 m_log.Error("[EMAIL] subject + body larger than limit of " + m_MaxEmailSize + " bytes");
274 return; 264 return;
275 } 265 }
276 266
@@ -345,10 +335,6 @@ namespace OpenSim.Region.CoreModules.Scripting.EmailModules
345 // TODO FIX 335 // TODO FIX
346 } 336 }
347 } 337 }
348
349 //DONE: Message as Second Life style
350 //20 second delay - AntiSpam System - for now only 10 seconds
351 DelayInSeconds(10);
352 } 338 }
353 339
354 /// <summary> 340 /// <summary>
diff --git a/OpenSim/Region/Framework/Scenes/Scene.cs b/OpenSim/Region/Framework/Scenes/Scene.cs
index 3d2213a..2a2830f 100644
--- a/OpenSim/Region/Framework/Scenes/Scene.cs
+++ b/OpenSim/Region/Framework/Scenes/Scene.cs
@@ -569,6 +569,15 @@ namespace OpenSim.Region.Framework.Scenes
569 get { return m_sceneGraph.Entities; } 569 get { return m_sceneGraph.Entities; }
570 } 570 }
571 571
572 // can be closest/random/sequence
573 private string m_SpawnPointRouting = "closest";
574 // used in sequence see: SpawnPoint()
575 private int m_SpawnPoint;
576 public string SpawnPointRouting
577 {
578 get { return m_SpawnPointRouting; }
579 }
580
572 #endregion Properties 581 #endregion Properties
573 582
574 #region Constructors 583 #region Constructors
@@ -586,7 +595,7 @@ namespace OpenSim.Region.Framework.Scenes
586 595
587 Random random = new Random(); 596 Random random = new Random();
588 597
589 m_lastAllocatedLocalId = (uint)(random.NextDouble() * (double)(uint.MaxValue/2))+(uint)(uint.MaxValue/4); 598 m_lastAllocatedLocalId = (uint)(random.NextDouble() * (double)(uint.MaxValue / 2)) + (uint)(uint.MaxValue / 4);
590 m_moduleLoader = moduleLoader; 599 m_moduleLoader = moduleLoader;
591 m_authenticateHandler = authen; 600 m_authenticateHandler = authen;
592 m_sceneGridService = sceneGridService; 601 m_sceneGridService = sceneGridService;
@@ -678,7 +687,7 @@ namespace OpenSim.Region.Framework.Scenes
678 { 687 {
679 IConfig startupConfig = m_config.Configs["Startup"]; 688 IConfig startupConfig = m_config.Configs["Startup"];
680 689
681 m_defaultDrawDistance = startupConfig.GetFloat("DefaultDrawDistance",m_defaultDrawDistance); 690 m_defaultDrawDistance = startupConfig.GetFloat("DefaultDrawDistance", m_defaultDrawDistance);
682 m_useBackup = startupConfig.GetBoolean("UseSceneBackup", m_useBackup); 691 m_useBackup = startupConfig.GetBoolean("UseSceneBackup", m_useBackup);
683 if (!m_useBackup) 692 if (!m_useBackup)
684 m_log.InfoFormat("[SCENE]: Backup has been disabled for {0}", RegionInfo.RegionName); 693 m_log.InfoFormat("[SCENE]: Backup has been disabled for {0}", RegionInfo.RegionName);
@@ -711,7 +720,7 @@ namespace OpenSim.Region.Framework.Scenes
711 m_clampPrimSize = true; 720 m_clampPrimSize = true;
712 } 721 }
713 722
714 m_useTrashOnDelete = startupConfig.GetBoolean("UseTrashOnDelete",m_useTrashOnDelete); 723 m_useTrashOnDelete = startupConfig.GetBoolean("UseTrashOnDelete", m_useTrashOnDelete);
715 m_trustBinaries = startupConfig.GetBoolean("TrustBinaries", m_trustBinaries); 724 m_trustBinaries = startupConfig.GetBoolean("TrustBinaries", m_trustBinaries);
716 m_allowScriptCrossings = startupConfig.GetBoolean("AllowScriptCrossing", m_allowScriptCrossings); 725 m_allowScriptCrossings = startupConfig.GetBoolean("AllowScriptCrossing", m_allowScriptCrossings);
717 m_dontPersistBefore = 726 m_dontPersistBefore =
@@ -723,6 +732,8 @@ namespace OpenSim.Region.Framework.Scenes
723 732
724 m_defaultScriptEngine = startupConfig.GetString("DefaultScriptEngine", "XEngine"); 733 m_defaultScriptEngine = startupConfig.GetString("DefaultScriptEngine", "XEngine");
725 734
735 m_SpawnPointRouting = startupConfig.GetString("SpawnPointRouting", "closest");
736
726 IConfig packetConfig = m_config.Configs["PacketPool"]; 737 IConfig packetConfig = m_config.Configs["PacketPool"];
727 if (packetConfig != null) 738 if (packetConfig != null)
728 { 739 {
@@ -3389,7 +3400,7 @@ namespace OpenSim.Region.Framework.Scenes
3389 public bool NewUserConnection(AgentCircuitData agent, uint teleportFlags, out string reason, bool requirePresenceLookup) 3400 public bool NewUserConnection(AgentCircuitData agent, uint teleportFlags, out string reason, bool requirePresenceLookup)
3390 { 3401 {
3391 bool vialogin = ((teleportFlags & (uint)TPFlags.ViaLogin) != 0 || 3402 bool vialogin = ((teleportFlags & (uint)TPFlags.ViaLogin) != 0 ||
3392 (teleportFlags & (uint)TPFlags.ViaHGLogin) != 0); 3403 (teleportFlags & (uint)TPFlags.ViaHGLogin) != 0);
3393 bool viahome = ((teleportFlags & (uint)TPFlags.ViaHome) != 0); 3404 bool viahome = ((teleportFlags & (uint)TPFlags.ViaHome) != 0);
3394 bool godlike = ((teleportFlags & (uint)TPFlags.Godlike) != 0); 3405 bool godlike = ((teleportFlags & (uint)TPFlags.Godlike) != 0);
3395 3406
@@ -3405,8 +3416,17 @@ namespace OpenSim.Region.Framework.Scenes
3405 // Don't disable this log message - it's too helpful 3416 // Don't disable this log message - it's too helpful
3406 m_log.DebugFormat( 3417 m_log.DebugFormat(
3407 "[SCENE]: Region {0} told of incoming {1} agent {2} {3} {4} (circuit code {5}, IP {6}, viewer {7}, teleportflags ({8}), position {9})", 3418 "[SCENE]: Region {0} told of incoming {1} agent {2} {3} {4} (circuit code {5}, IP {6}, viewer {7}, teleportflags ({8}), position {9})",
3408 RegionInfo.RegionName, (agent.child ? "child" : "root"),agent.firstname, agent.lastname, 3419 RegionInfo.RegionName,
3409 agent.AgentID, agent.circuitcode, agent.IPAddress, agent.Viewer, ((TPFlags)teleportFlags).ToString(), agent.startpos); 3420 (agent.child ? "child" : "root"),
3421 agent.firstname,
3422 agent.lastname,
3423 agent.AgentID,
3424 agent.circuitcode,
3425 agent.IPAddress,
3426 agent.Viewer,
3427 ((TPFlags)teleportFlags).ToString(),
3428 agent.startpos
3429 );
3410 3430
3411 if (LoginsDisabled) 3431 if (LoginsDisabled)
3412 { 3432 {
@@ -3421,7 +3441,11 @@ namespace OpenSim.Region.Framework.Scenes
3421 // We have a zombie from a crashed session. 3441 // We have a zombie from a crashed session.
3422 // Or the same user is trying to be root twice here, won't work. 3442 // Or the same user is trying to be root twice here, won't work.
3423 // Kill it. 3443 // Kill it.
3424 m_log.DebugFormat("[SCENE]: Zombie scene presence detected for {0} in {1}", agent.AgentID, RegionInfo.RegionName); 3444 m_log.DebugFormat(
3445 "[SCENE]: Zombie scene presence detected for {0} in {1}",
3446 agent.AgentID,
3447 RegionInfo.RegionName
3448 );
3425 sp.ControllingClient.Close(); 3449 sp.ControllingClient.Close();
3426 sp = null; 3450 sp = null;
3427 } 3451 }
@@ -3445,8 +3469,7 @@ namespace OpenSim.Region.Framework.Scenes
3445 { 3469 {
3446 if (!VerifyUserPresence(agent, out reason)) 3470 if (!VerifyUserPresence(agent, out reason))
3447 return false; 3471 return false;
3448 } 3472 } catch (Exception e)
3449 catch (Exception e)
3450 { 3473 {
3451 m_log.ErrorFormat( 3474 m_log.ErrorFormat(
3452 "[SCENE]: Exception verifying presence {0}{1}", e.Message, e.StackTrace); 3475 "[SCENE]: Exception verifying presence {0}{1}", e.Message, e.StackTrace);
@@ -3458,8 +3481,7 @@ namespace OpenSim.Region.Framework.Scenes
3458 { 3481 {
3459 if (!AuthorizeUser(agent, out reason)) 3482 if (!AuthorizeUser(agent, out reason))
3460 return false; 3483 return false;
3461 } 3484 } catch (Exception e)
3462 catch (Exception e)
3463 { 3485 {
3464 m_log.ErrorFormat( 3486 m_log.ErrorFormat(
3465 "[SCENE]: Exception authorizing user {0}{1}", e.Message, e.StackTrace); 3487 "[SCENE]: Exception authorizing user {0}{1}", e.Message, e.StackTrace);
@@ -3476,8 +3498,7 @@ namespace OpenSim.Region.Framework.Scenes
3476 CapsModule.SetAgentCapsSeeds(agent); 3498 CapsModule.SetAgentCapsSeeds(agent);
3477 CapsModule.CreateCaps(agent.AgentID); 3499 CapsModule.CreateCaps(agent.AgentID);
3478 } 3500 }
3479 } 3501 } else
3480 else
3481 { 3502 {
3482 // Let the SP know how we got here. This has a lot of interesting 3503 // Let the SP know how we got here. This has a lot of interesting
3483 // uses down the line. 3504 // uses down the line.
@@ -3500,7 +3521,7 @@ namespace OpenSim.Region.Framework.Scenes
3500 agent.teleportFlags = teleportFlags; 3521 agent.teleportFlags = teleportFlags;
3501 m_authenticateHandler.AddNewCircuit(agent.circuitcode, agent); 3522 m_authenticateHandler.AddNewCircuit(agent.circuitcode, agent);
3502 3523
3503 if (vialogin) 3524 if (vialogin)
3504 { 3525 {
3505// CleanDroppedAttachments(); 3526// CleanDroppedAttachments();
3506 3527
@@ -3541,8 +3562,7 @@ namespace OpenSim.Region.Framework.Scenes
3541 agent.startpos.Z = 720; 3562 agent.startpos.Z = 720;
3542 } 3563 }
3543 } 3564 }
3544 } 3565 } else
3545 else
3546 { 3566 {
3547 if (agent.startpos.X > EastBorders[0].BorderLine.Z) 3567 if (agent.startpos.X > EastBorders[0].BorderLine.Z)
3548 { 3568 {
@@ -3568,10 +3588,19 @@ namespace OpenSim.Region.Framework.Scenes
3568 SceneObjectGroup telehub = GetSceneObjectGroup(RegionInfo.RegionSettings.TelehubObject); 3588 SceneObjectGroup telehub = GetSceneObjectGroup(RegionInfo.RegionSettings.TelehubObject);
3569 // Can have multiple SpawnPoints 3589 // Can have multiple SpawnPoints
3570 List<SpawnPoint> spawnpoints = RegionInfo.RegionSettings.SpawnPoints(); 3590 List<SpawnPoint> spawnpoints = RegionInfo.RegionSettings.SpawnPoints();
3571 if ( spawnpoints.Count > 1) 3591 if (spawnpoints.Count > 1)
3572 { 3592 {
3573 // We have multiple SpawnPoints, Route the agent to a random one 3593 // We have multiple SpawnPoints, Route the agent to a random or sequential one
3574 agent.startpos = spawnpoints[Util.RandomClass.Next(spawnpoints.Count)].GetLocation(telehub.AbsolutePosition, telehub.GroupRotation); 3594 if (SpawnPointRouting == "random")
3595 agent.startpos = spawnpoints[Util.RandomClass.Next(spawnpoints.Count) - 1].GetLocation(
3596 telehub.AbsolutePosition,
3597 telehub.GroupRotation
3598 );
3599 else
3600 agent.startpos = spawnpoints[SpawnPoint()].GetLocation(
3601 telehub.AbsolutePosition,
3602 telehub.GroupRotation
3603 );
3575 } 3604 }
3576 else 3605 else
3577 { 3606 {
@@ -5257,5 +5286,19 @@ namespace OpenSim.Region.Framework.Scenes
5257 } 5286 }
5258 } 5287 }
5259 } 5288 }
5289
5290 // manage and select spawn points in sequence
5291 public int SpawnPoint()
5292 {
5293 int spawnpoints = RegionInfo.RegionSettings.SpawnPoints().Count;
5294
5295 if (spawnpoints == 0)
5296 return 0;
5297
5298 m_SpawnPoint++;
5299 if (m_SpawnPoint > spawnpoints)
5300 m_SpawnPoint = 1;
5301 return m_SpawnPoint - 1;
5302 }
5260 } 5303 }
5261} 5304}
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
index b737f91..bdcef71 100644
--- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs
+++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs
@@ -3934,28 +3934,93 @@ namespace OpenSim.Region.Framework.Scenes
3934 if (spawnPoints.Length == 0) 3934 if (spawnPoints.Length == 0)
3935 return; 3935 return;
3936 3936
3937 float distance = 9999; 3937 int index;
3938 int closest = -1; 3938 bool selected = false;
3939 3939
3940 for (int i = 0 ; i < spawnPoints.Length ; i++) 3940 switch (m_scene.SpawnPointRouting)
3941 { 3941 {
3942 Vector3 spawnPosition = spawnPoints[i].GetLocation(telehub.AbsolutePosition, telehub.GroupRotation); 3942 case "closest":
3943 Vector3 offset = spawnPosition - pos;
3944 float d = Vector3.Mag(offset);
3945 if (d >= distance)
3946 continue;
3947 ILandObject land = m_scene.LandChannel.GetLandObject(spawnPosition.X, spawnPosition.Y);
3948 if (land == null)
3949 continue;
3950 if (land.IsEitherBannedOrRestricted(UUID))
3951 continue;
3952 distance = d;
3953 closest = i;
3954 }
3955 if (closest == -1)
3956 return;
3957 3943
3958 pos = spawnPoints[closest].GetLocation(telehub.AbsolutePosition, telehub.GroupRotation); 3944 float distance = 9999;
3945 int closest = -1;
3946
3947 for (int i = 0; i < spawnPoints.Length; i++)
3948 {
3949 Vector3 spawnPosition = spawnPoints[i].GetLocation(
3950 telehub.AbsolutePosition,
3951 telehub.GroupRotation
3952 );
3953 Vector3 offset = spawnPosition - pos;
3954 float d = Vector3.Mag(offset);
3955 if (d >= distance)
3956 continue;
3957 ILandObject land = m_scene.LandChannel.GetLandObject(spawnPosition.X, spawnPosition.Y);
3958 if (land == null)
3959 continue;
3960 if (land.IsEitherBannedOrRestricted(UUID))
3961 continue;
3962 distance = d;
3963 closest = i;
3964 }
3965 if (closest == -1)
3966 return;
3967
3968 pos = spawnPoints[closest].GetLocation(telehub.AbsolutePosition, telehub.GroupRotation);
3969 return;
3970
3971 case "random":
3972
3973 do
3974 {
3975 index = Util.RandomClass.Next(spawnPoints.Length - 1);
3976
3977 Vector3 spawnPosition = spawnPoints[index].GetLocation(
3978 telehub.AbsolutePosition,
3979 telehub.GroupRotation
3980 );
3981 // SpawnPoint sp = spawnPoints[index];
3982
3983 ILandObject land = m_scene.LandChannel.GetLandObject(spawnPosition.X, spawnPosition.Y);
3984 if (land == null || land.IsEitherBannedOrRestricted(UUID))
3985 selected = false;
3986 else
3987 selected = true;
3988
3989 } while ( selected == false);
3990
3991 pos = spawnPoints[index].GetLocation(
3992 telehub.AbsolutePosition,
3993 telehub.GroupRotation
3994 );
3995 return;
3996
3997 case "sequence":
3998
3999 do
4000 {
4001 index = m_scene.SpawnPoint();
4002
4003 Vector3 spawnPosition = spawnPoints[index].GetLocation(
4004 telehub.AbsolutePosition,
4005 telehub.GroupRotation
4006 );
4007 // SpawnPoint sp = spawnPoints[index];
4008
4009 ILandObject land = m_scene.LandChannel.GetLandObject(spawnPosition.X, spawnPosition.Y);
4010 if (land == null || land.IsEitherBannedOrRestricted(UUID))
4011 selected = false;
4012 else
4013 selected = true;
4014
4015 } while (selected == false);
4016
4017 pos = spawnPoints[index].GetLocation(telehub.AbsolutePosition, telehub.GroupRotation);
4018 ;
4019 return;
4020
4021 default:
4022 return;
4023 }
3959 } 4024 }
3960 } 4025 }
3961 } 4026 }
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
index 5b5cab8..5bff2e9 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
@@ -106,6 +106,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
106 protected IUrlModule m_UrlModule = null; 106 protected IUrlModule m_UrlModule = null;
107 protected Dictionary<UUID, UserInfoCacheEntry> m_userInfoCache = 107 protected Dictionary<UUID, UserInfoCacheEntry> m_userInfoCache =
108 new Dictionary<UUID, UserInfoCacheEntry>(); 108 new Dictionary<UUID, UserInfoCacheEntry>();
109 protected int EMAIL_PAUSE_TIME = 20; // documented delay value for smtp.
109 110
110 public void Initialize(IScriptEngine ScriptEngine, SceneObjectPart host, TaskInventoryItem item) 111 public void Initialize(IScriptEngine ScriptEngine, SceneObjectPart host, TaskInventoryItem item)
111 { 112 {
@@ -113,6 +114,18 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
113 m_host = host; 114 m_host = host;
114 m_item = item; 115 m_item = item;
115 116
117 LoadLimits(); // read script limits from config.
118
119 m_TransferModule =
120 m_ScriptEngine.World.RequestModuleInterface<IMessageTransferModule>();
121 m_UrlModule = m_ScriptEngine.World.RequestModuleInterface<IUrlModule>();
122
123 AsyncCommands = new AsyncCommandManager(ScriptEngine);
124 }
125
126 /* load configuration items that affect script, object and run-time behavior. */
127 private void LoadLimits()
128 {
116 m_ScriptDelayFactor = 129 m_ScriptDelayFactor =
117 m_ScriptEngine.Config.GetFloat("ScriptDelayFactor", 1.0f); 130 m_ScriptEngine.Config.GetFloat("ScriptDelayFactor", 1.0f);
118 m_ScriptDistanceFactor = 131 m_ScriptDistanceFactor =
@@ -125,12 +138,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
125 m_ScriptEngine.Config.GetInt("NotecardLineReadCharsMax", 255); 138 m_ScriptEngine.Config.GetInt("NotecardLineReadCharsMax", 255);
126 if (m_notecardLineReadCharsMax > 65535) 139 if (m_notecardLineReadCharsMax > 65535)
127 m_notecardLineReadCharsMax = 65535; 140 m_notecardLineReadCharsMax = 65535;
128 141 // load limits for particular subsystems.
129 m_TransferModule = 142 IConfig SMTPConfig;
130 m_ScriptEngine.World.RequestModuleInterface<IMessageTransferModule>(); 143 if ((SMTPConfig = m_ScriptEngine.ConfigSource.Configs["SMTP"]) != null) {
131 m_UrlModule = m_ScriptEngine.World.RequestModuleInterface<IUrlModule>(); 144 // there's an smtp config, so load in the snooze time.
132 145 EMAIL_PAUSE_TIME = SMTPConfig.GetInt("email_pause_time", EMAIL_PAUSE_TIME);
133 AsyncCommands = new AsyncCommandManager(ScriptEngine); 146 }
134 } 147 }
135 148
136 public override Object InitializeLifetimeService() 149 public override Object InitializeLifetimeService()
@@ -2877,6 +2890,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
2877 2890
2878 public virtual void llSleep(double sec) 2891 public virtual void llSleep(double sec)
2879 { 2892 {
2893// m_log.Info("llSleep snoozing " + sec + "s.");
2880 m_host.AddScriptLPS(1); 2894 m_host.AddScriptLPS(1);
2881 Thread.Sleep((int)(sec * 1000)); 2895 Thread.Sleep((int)(sec * 1000));
2882 } 2896 }
@@ -3130,7 +3144,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
3130 } 3144 }
3131 3145
3132 emailModule.SendEmail(m_host.UUID, address, subject, message); 3146 emailModule.SendEmail(m_host.UUID, address, subject, message);
3133 ScriptSleep(20000); 3147 llSleep(EMAIL_PAUSE_TIME);
3134 } 3148 }
3135 3149
3136 public void llGetNextEmail(string address, string subject) 3150 public void llGetNextEmail(string address, string subject)