diff options
Diffstat (limited to 'OpenSim/Region/Environment/Modules/Avatar/Chat/RegionState.cs')
-rw-r--r-- | OpenSim/Region/Environment/Modules/Avatar/Chat/RegionState.cs | 47 |
1 files changed, 16 insertions, 31 deletions
diff --git a/OpenSim/Region/Environment/Modules/Avatar/Chat/RegionState.cs b/OpenSim/Region/Environment/Modules/Avatar/Chat/RegionState.cs index cf2154f..0251388 100644 --- a/OpenSim/Region/Environment/Modules/Avatar/Chat/RegionState.cs +++ b/OpenSim/Region/Environment/Modules/Avatar/Chat/RegionState.cs | |||
@@ -28,6 +28,7 @@ | |||
28 | using System; | 28 | using System; |
29 | using System.Collections.Generic; | 29 | using System.Collections.Generic; |
30 | using System.Reflection; | 30 | using System.Reflection; |
31 | using System.Text.RegularExpressions; | ||
31 | using log4net; | 32 | using log4net; |
32 | using Nini.Config; | 33 | using Nini.Config; |
33 | using OpenSim.Framework; | 34 | using OpenSim.Framework; |
@@ -331,27 +332,16 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Chat | |||
331 | if (!enabled) | 332 | if (!enabled) |
332 | return; | 333 | return; |
333 | 334 | ||
334 | // drop all messages coming in on a private channel, | 335 | // drop messages unless they are on a valid in-world |
335 | // except if we are relaying private channels, in which | 336 | // channel as configured in the ChannelState |
336 | // case we drop if the private channel is not the | ||
337 | // configured m_relayChannelOut | ||
338 | 337 | ||
339 | if (cs.RelayPrivateChannels) | 338 | if (!cs.ValidInWorldChannels.Contains(msg.Channel)) |
340 | { | ||
341 | if (msg.Channel != 0 && msg.Channel != DEBUG_CHANNEL && msg.Channel != cs.RelayChannelOut) | ||
342 | { | ||
343 | m_log.DebugFormat("[IRC-Region {0}] dropping message {1} on channel {2}", Region, msg, msg.Channel); | ||
344 | return; | ||
345 | } | ||
346 | } | ||
347 | else if (msg.Channel != 0 && msg.Channel != DEBUG_CHANNEL) | ||
348 | { | 339 | { |
349 | m_log.DebugFormat("[IRC-Region {0}] dropping message {1} on channel {2}", Region, msg, msg.Channel); | 340 | m_log.DebugFormat("[IRC-Region {0}] dropping message {1} on channel {2}", Region, msg, msg.Channel); |
350 | return; | 341 | return; |
351 | } | 342 | } |
352 | 343 | ||
353 | ScenePresence avatar = null; | 344 | ScenePresence avatar = null; |
354 | |||
355 | string fromName = msg.From; | 345 | string fromName = msg.From; |
356 | 346 | ||
357 | if (msg.Sender != null) | 347 | if (msg.Sender != null) |
@@ -368,31 +358,26 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Chat | |||
368 | 358 | ||
369 | m_log.DebugFormat("[IRC-Region {0}] heard on channel {1} : {2}", Region, msg.Channel, msg.Message); | 359 | m_log.DebugFormat("[IRC-Region {0}] heard on channel {1} : {2}", Region, msg.Channel, msg.Message); |
370 | 360 | ||
371 | if (null != avatar) | 361 | if (null != avatar && cs.RelayChat && (msg.Channel == 0 || msg.Channel == DEBUG_CHANNEL)) |
372 | { | 362 | { |
373 | string txt = msg.Message; | 363 | string txt = msg.Message; |
374 | if (txt.StartsWith("/me ")) | 364 | if (txt.StartsWith("/me ")) |
375 | txt = String.Format("{0} {1}", fromName, msg.Message.Substring(4)); | 365 | txt = String.Format("{0} {1}", fromName, msg.Message.Substring(4)); |
376 | 366 | ||
377 | cs.irc.PrivMsg(cs.PrivateMessageFormat, fromName, Region, txt); | 367 | cs.irc.PrivMsg(cs.PrivateMessageFormat, fromName, Region, txt); |
368 | return; | ||
378 | } | 369 | } |
379 | else | ||
380 | { | ||
381 | //Message came from an object | ||
382 | char[] splits = { ',' }; | ||
383 | string[] tokens = msg.Message.Split(splits,3); // This is certainly wrong | ||
384 | 370 | ||
385 | if (tokens.Length == 3) | 371 | if (null == avatar && cs.RelayPrivateChannels && null != cs.AccessPassword && |
372 | msg.Channel == cs.RelayChannelOut) | ||
373 | { | ||
374 | Match m = cs.AccessPasswordRegex.Match(msg.Message); | ||
375 | if (null != m) | ||
386 | { | 376 | { |
387 | if (tokens[0] == cs.AccessPassword) // This is my really simple check | 377 | m_log.DebugFormat("[IRC] relaying message from {0}: {1}", m.Groups["avatar"].ToString(), |
388 | { | 378 | m.Groups["message"].ToString()); |
389 | m_log.DebugFormat("[IRC-Region {0}] message from object {1}, {2}", Region, tokens[0], tokens[1]); | 379 | cs.irc.PrivMsg(cs.PrivateMessageFormat, m.Groups["avatar"].ToString(), |
390 | cs.irc.PrivMsg(cs.PrivateMessageFormat, tokens[1], scene.RegionInfo.RegionName, tokens[2]); | 380 | scene.RegionInfo.RegionName, m.Groups["message"].ToString()); |
391 | } | ||
392 | else | ||
393 | { | ||
394 | m_log.WarnFormat("[IRC-Region {0}] prim security key mismatch <{1}> not <{2}>", Region, tokens[0], cs.AccessPassword); | ||
395 | } | ||
396 | } | 381 | } |
397 | } | 382 | } |
398 | } | 383 | } |