aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs46
1 files changed, 35 insertions, 11 deletions
diff --git a/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs b/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs
index 1687205..2634717 100644
--- a/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs
+++ b/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs
@@ -25,6 +25,7 @@ namespace OpenSim.Client.MXP.PacketHandler
25 private readonly Transmitter transmitter; 25 private readonly Transmitter transmitter;
26 26
27 private readonly IList<Session> sessions = new List<Session>(); 27 private readonly IList<Session> sessions = new List<Session>();
28 private readonly IList<Session> sessionsToClient = new List<Session>();
28 private readonly IList<MXPClientView> sessionsToRemove = new List<MXPClientView>(); 29 private readonly IList<MXPClientView> sessionsToRemove = new List<MXPClientView>();
29 30
30 private readonly String cloudUrl; 31 private readonly String cloudUrl;
@@ -217,24 +218,24 @@ namespace OpenSim.Client.MXP.PacketHandler
217 { 218 {
218 if (transmitter.PendingSessionCount > 0) 219 if (transmitter.PendingSessionCount > 0)
219 { 220 {
220 sessions.Add(transmitter.AcceptPendingSession()); 221 Session tmp = transmitter.AcceptPendingSession();
222 sessions.Add(tmp);
223 sessionsToClient.Add(tmp);
224
221 } 225 }
222 226
223 foreach (MXPClientView clientView in Clients) 227 List<Session> tmpRemove = new List<Session>();
224 {
225
226 int messagesProcessedCount = 0;
227 Session session = clientView.Session;
228 228
229 foreach (Session session in sessionsToClient)
230 {
229 while (session.AvailableMessages > 0) 231 while (session.AvailableMessages > 0)
230 { 232 {
231
232 Message message = session.Receive(); 233 Message message = session.Receive();
233 234
234 if (message.GetType() == typeof(JoinRequestMessage)) 235 if (message.GetType() == typeof (JoinRequestMessage))
235 { 236 {
236 237
237 JoinRequestMessage joinRequestMessage = (JoinRequestMessage)message; 238 JoinRequestMessage joinRequestMessage = (JoinRequestMessage) message;
238 239
239 bool authorized = AuthoriseUser(joinRequestMessage.ParticipantName, 240 bool authorized = AuthoriseUser(joinRequestMessage.ParticipantName,
240 joinRequestMessage.ParticipantPassphrase, 241 joinRequestMessage.ParticipantPassphrase,
@@ -246,7 +247,9 @@ namespace OpenSim.Client.MXP.PacketHandler
246 247
247 UUID mxpSessionID = UUID.Random(); 248 UUID mxpSessionID = UUID.Random();
248 249
249 m_log.Info("[MXP ClientStack] Session join request success: " + session.SessionId + " (" + (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + session.RemoteEndPoint.Port + ")"); 250 m_log.Info("[MXP ClientStack] Session join request success: " + session.SessionId + " (" +
251 (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" +
252 session.RemoteEndPoint.Port + ")");
250 253
251 AcceptConnection(session, joinRequestMessage, mxpSessionID); 254 AcceptConnection(session, joinRequestMessage, mxpSessionID);
252 255
@@ -258,12 +261,33 @@ namespace OpenSim.Client.MXP.PacketHandler
258 } 261 }
259 else 262 else
260 { 263 {
261 m_log.Info("[MXP ClientStack] Session join request failure: " + session.SessionId + " (" + (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + session.RemoteEndPoint.Port + ")"); 264 m_log.Info("[MXP ClientStack] Session join request failure: " + session.SessionId + " (" +
265 (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" +
266 session.RemoteEndPoint.Port + ")");
262 267
263 DeclineConnection(session, joinRequestMessage); 268 DeclineConnection(session, joinRequestMessage);
264 } 269 }
265 270
271 tmpRemove.Add(session);
266 } 272 }
273 }
274 }
275
276 foreach (Session session in tmpRemove)
277 {
278 sessionsToClient.Remove(session);
279 }
280
281 foreach (MXPClientView clientView in Clients)
282 {
283
284 int messagesProcessedCount = 0;
285 Session session = clientView.Session;
286
287 while (session.AvailableMessages > 0)
288 {
289 Message message = session.Receive();
290
267 if (message.GetType() == typeof(LeaveRequestMessage)) 291 if (message.GetType() == typeof(LeaveRequestMessage))
268 { 292 {
269 293