starting draft attendee list notification support.

0.6.3-post-fixes
Dr Scofield 2009-01-26 21:31:02 +00:00
parent b112109d2c
commit 464ecc15a0
1 changed files with 27 additions and 0 deletions

View File

@ -65,6 +65,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Concierge
private string _announceEntering = "{0} enters {1} (now {2} visitors in this region)"; private string _announceEntering = "{0} enters {1} (now {2} visitors in this region)";
private string _announceLeaving = "{0} leaves {1} (back to {2} visitors in this region)"; private string _announceLeaving = "{0} leaves {1} (back to {2} visitors in this region)";
private string _xmlRpcPassword = String.Empty; private string _xmlRpcPassword = String.Empty;
private string _brokerURI = String.Empty;
internal object _syncy = new object(); internal object _syncy = new object();
@ -118,6 +119,8 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Concierge
_announceEntering = _config.GetString("announce_entering", _announceEntering); _announceEntering = _config.GetString("announce_entering", _announceEntering);
_announceLeaving = _config.GetString("announce_leaving", _announceLeaving); _announceLeaving = _config.GetString("announce_leaving", _announceLeaving);
_xmlRpcPassword = _config.GetString("password", _xmlRpcPassword); _xmlRpcPassword = _config.GetString("password", _xmlRpcPassword);
_brokerURI = _config.GetString("broker", _brokerURI);
_log.InfoFormat("[Concierge] reporting as \"{0}\" to our users", _whoami); _log.InfoFormat("[Concierge] reporting as \"{0}\" to our users", _whoami);
// calculate regions Regex // calculate regions Regex
@ -274,6 +277,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Concierge
RemoveFromAttendeeList(client.AgentId, client.Name, client.Scene); RemoveFromAttendeeList(client.AgentId, client.Name, client.Scene);
AnnounceToAgentsRegion(client.Scene, String.Format(_announceLeaving, client.Name, client.Scene.RegionInfo.RegionName, AnnounceToAgentsRegion(client.Scene, String.Format(_announceLeaving, client.Name, client.Scene.RegionInfo.RegionName,
_sceneAttendees[client.Scene].Count)); _sceneAttendees[client.Scene].Count));
UpdateBroker(client.Scene);
} }
} }
@ -287,6 +291,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Concierge
WelcomeAvatar(agent, agent.Scene); WelcomeAvatar(agent, agent.Scene);
AnnounceToAgentsRegion(agent.Scene, String.Format(_announceEntering, agent.Name, agent.Scene.RegionInfo.RegionName, AnnounceToAgentsRegion(agent.Scene, String.Format(_announceEntering, agent.Name, agent.Scene.RegionInfo.RegionName,
_sceneAttendees[agent.Scene].Count)); _sceneAttendees[agent.Scene].Count));
UpdateBroker(agent.Scene);
} }
} }
@ -299,6 +304,7 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Concierge
RemoveFromAttendeeList(agent.UUID, agent.Name, agent.Scene); RemoveFromAttendeeList(agent.UUID, agent.Name, agent.Scene);
AnnounceToAgentsRegion(agent.Scene, String.Format(_announceLeaving, agent.Name, agent.Scene.RegionInfo.RegionName, AnnounceToAgentsRegion(agent.Scene, String.Format(_announceLeaving, agent.Name, agent.Scene.RegionInfo.RegionName,
_sceneAttendees[agent.Scene].Count)); _sceneAttendees[agent.Scene].Count));
UpdateBroker(agent.Scene);
} }
} }
@ -334,6 +340,27 @@ namespace OpenSim.Region.Environment.Modules.Avatar.Concierge
} }
} }
protected void UpdateBroker(IScene scene)
{
if (String.IsNullOrEmpty(_brokerURI))
return;
// get attendee list for the scene
List<UUID> attendees;
lock (_sceneAttendees)
{
if (!_sceneAttendees.ContainsKey(scene))
{
_log.DebugFormat("[Concierge]: attendee list missing for region {0}", scene.RegionInfo.RegionName);
return;
}
attendees = _sceneAttendees[scene];
}
// post via REST to broker
}
protected void WelcomeAvatar(ScenePresence agent, Scene scene) protected void WelcomeAvatar(ScenePresence agent, Scene scene)
{ {
// welcome mechanics: check whether we have a welcomes // welcome mechanics: check whether we have a welcomes