Applied patch from Mantis# 3240, thanks tlaukkan/Tommil

GenericGridServerConcept
MW 2009-02-27 14:50:49 +00:00
parent b83d5c7cdb
commit 95230c244c
3 changed files with 127 additions and 53 deletions

View File

@ -46,30 +46,38 @@ namespace OpenSim.Client.MXP.ClientStack
{
internal static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
private readonly Session mxpSession;
private readonly UUID mxpSessionID;
private readonly IScene mxpHostBubble;
private readonly string mxpUsername;
private readonly Session m_session;
private readonly UUID m_sessionID;
private readonly UUID m_userID;
private readonly IScene m_hostBubble;
private readonly string m_firstName;
private readonly string m_lastName;
private int debugLevel;
private Vector3 m_startPosition=new Vector3(128f, 128f, 128f);
private int m_debugLevel;
public MXPClientView(Session mxpSession, UUID mxpSessionID, IScene mxpHostBubble, string mxpUsername)
public MXPClientView(Session mxpSession, UUID mxpSessionID, UUID userID, IScene mxpHostBubble, string mxpFirstName, string mxpLastName)
{
this.mxpSession = mxpSession;
this.mxpUsername = mxpUsername;
this.mxpHostBubble = mxpHostBubble;
this.mxpSessionID = mxpSessionID;
this.m_session = mxpSession;
this.m_userID = userID;
this.m_firstName = mxpFirstName;
this.m_lastName = mxpLastName;
this.m_hostBubble = mxpHostBubble;
this.m_sessionID = mxpSessionID;
}
public Session Session
{
get { return mxpSession; }
get { return m_session; }
}
public bool ProcessMXPPacket(Message msg)
{
if (debugLevel > 0)
m_log.Warn("[MXP] Got Action/Command Packet: " + msg);
if (m_debugLevel > 0)
{
m_log.Warn("[MXP] Received messaged unhandled: " + msg);
}
return false;
}
@ -78,23 +86,23 @@ namespace OpenSim.Client.MXP.ClientStack
public Vector3 StartPos
{
get { return new Vector3(128f, 128f, 128f); }
set { } // TODO: Implement Me
get { return m_startPosition; }
set { m_startPosition = value; }
}
public UUID AgentId
{
get { return mxpSessionID; }
get { return m_userID; }
}
public UUID SessionId
{
get { return mxpSessionID; }
get { return m_sessionID; }
}
public UUID SecureSessionId
{
get { return mxpSessionID; }
get { return m_sessionID; }
}
public UUID ActiveGroupId
@ -124,17 +132,17 @@ namespace OpenSim.Client.MXP.ClientStack
public string FirstName
{
get { return mxpUsername; }
get { return m_firstName; }
}
public string LastName
{
get { return "@mxp://" + Session.RemoteEndPoint.Address; }
get { return m_lastName; }
}
public IScene Scene
{
get { return mxpHostBubble; }
get { return m_hostBubble; }
}
public int NextAnimationSequenceNumber
@ -165,7 +173,7 @@ namespace OpenSim.Client.MXP.ClientStack
public uint CircuitCode
{
get { return mxpSessionID.CRC(); }
get { return m_sessionID.CRC(); }
}
public event GenericMessage OnGenericMessage;
@ -348,7 +356,7 @@ namespace OpenSim.Client.MXP.ClientStack
public void SetDebugPacketLevel(int newDebug)
{
debugLevel = newDebug;
m_debugLevel = newDebug;
}
public void InPacket(object NewPack)
@ -560,14 +568,42 @@ namespace OpenSim.Client.MXP.ClientStack
// Need to translate to MXP somehow
}
public void SendAvatarData(ulong regionHandle, string firstName, string lastName, string grouptitle, UUID avatarID, uint avatarLocalID, Vector3 Pos, byte[] textureEntry, uint parentID, Quaternion rotation)
public void SendAvatarData(ulong regionHandle, string firstName, string lastName, string grouptitle, UUID avatarID, uint avatarLocalID, Vector3 pos, byte[] textureEntry, uint parentID, Quaternion rotation)
{
// TODO: This needs handling - to display other avatars
m_log.Info("[MXP] Transmitting Avatar Data " + firstName + " " + lastName);
PerceptionEventMessage pe = new PerceptionEventMessage();
pe.ObjectFragment.ObjectId = avatarID.Guid;
// TODO Resolve ParentID
pe.ObjectFragment.ParentObjectId = Guid.Empty;
pe.ObjectFragment.ObjectIndex = avatarLocalID;
pe.ObjectFragment.ObjectName = firstName+" "+lastName;
pe.ObjectFragment.OwnerId = Guid.Empty;
pe.ObjectFragment.TypeId = Guid.Empty;
pe.ObjectFragment.TypeName = "Avatar";
pe.ObjectFragment.Acceleration = new float[3];
pe.ObjectFragment.AngularAcceleration = new float[4];
pe.ObjectFragment.AngularVelocity = new float[4];
pe.ObjectFragment.BoundingSphereRadius = 1; // TODO Fill in appropriate value
pe.ObjectFragment.Location = new float[] { pos.X, pos.Y, pos.Z };
pe.ObjectFragment.Mass = 1.0f; // TODO Fill in appropriate value
pe.ObjectFragment.Orientation = new float[] { rotation.X, rotation.Y, rotation.Z, rotation.W };
pe.ObjectFragment.Velocity = new float[3];
Session.Send(pe);
}
public void SendAvatarTerseUpdate(ulong regionHandle, ushort timeDilation, uint localID, Vector3 position, Vector3 velocity, Quaternion rotation)
{
// TODO: This probably needs handling - update other avatar positions
MovementEventMessage me = new MovementEventMessage();
me.ObjectIndex = localID;
me.Location = new float[] { position.X, position.Y, position.Z };
me.Orientation = new float[] { rotation.X, rotation.Y, rotation.Z, rotation.W };
Session.Send(me);
}
public void SendCoarseLocationUpdate(List<Vector3> CoarseLocations)
@ -610,20 +646,17 @@ namespace OpenSim.Client.MXP.ClientStack
pe.ObjectFragment.AngularVelocity = new float[] { rvel.X, rvel.Y, rvel.Z, 0.0f };
pe.ObjectFragment.BoundingSphereRadius = primShape.Scale.Length();
pe.ObjectFragment.Location = new float[] { pos.X - 120.0f, pos.Z, pos.Y - 128.0f };
pe.ObjectFragment.Location = new float[] { pos.X , pos.Y, pos.Z };
pe.ObjectFragment.Mass = 1.0f;
pe.ObjectFragment.Orientation = new float[] { rotation.X, rotation.Y, rotation.Z, rotation.W };
pe.ObjectFragment.Velocity = new float[] { vel.X, vel.Y, vel.Z };
ObjectExtFragment ext = new ObjectExtFragment();
if (!((primShape.PCode == (byte)PCode.NewTree) || (primShape.PCode == (byte)PCode.Tree) || (primShape.PCode == (byte)PCode.Grass)))
{
ObjectExtFragment ext = new ObjectExtFragment();
ext.UpdateFlags = flags;
ext.TextureEntry = primShape.TextureEntry;
ext.TextureAnim = textureanim;
ext.State = primShape.State;
ext.PathBegin = primShape.PathBegin;
ext.PathEnd = primShape.PathEnd;
ext.PathScaleX = primShape.PathScaleX;
@ -633,7 +666,6 @@ namespace OpenSim.Client.MXP.ClientStack
ext.PathSkew = primShape.PathSkew;
ext.ProfileBegin = primShape.ProfileBegin;
ext.ProfileEnd = primShape.ProfileEnd;
ext.Scale = EncodeVector(primShape.Scale);
ext.PathCurve = primShape.PathCurve;
ext.ProfileCurve = primShape.ProfileCurve;
ext.ProfileHollow = primShape.ProfileHollow;
@ -643,8 +675,16 @@ namespace OpenSim.Client.MXP.ClientStack
ext.PathTaperY = primShape.PathTaperY;
ext.PathTwist = primShape.PathTwist;
ext.PathTwistBegin = primShape.PathTwistBegin;
ext.ExtraParams = primShape.ExtraParams;
}
ext.UpdateFlags = flags;
ext.ExtraParams = primShape.ExtraParams;
ext.State = primShape.State;
ext.TextureEntry = primShape.TextureEntry;
ext.TextureAnim = textureanim;
ext.Scale = EncodeVector(primShape.Scale);
ext.Text = text;
ext.TextColor = EncodeColor(textColor);
ext.PSBlock = particleSystem;
@ -653,8 +693,6 @@ namespace OpenSim.Client.MXP.ClientStack
pe.SetExtension<ObjectExtFragment>(ext);
}
Session.Send(pe);
}

View File

@ -216,8 +216,8 @@ namespace OpenSim.Client.MXP.PacketHandler
m_log.Info("Pending Sessions: " + PendingSessionCount);
m_log.Info("Sessions: " + SessionCount + " (Clients: " + Clients.Count + " )");
m_log.Info("Transmitter Alive?: " + IsTransmitterAlive);
m_log.Info("Packets Sent/Recieved: " + PacketsSent + " / " + PacketsReceived);
m_log.Info("Bytes Sent/Recieved: " + BytesSent + " / " + BytesReceived);
m_log.Info("Packets Sent/Received: " + PacketsSent + " / " + PacketsReceived);
m_log.Info("Bytes Sent/Received: " + BytesSent + " / " + BytesReceived);
m_log.Info("Send/Recieve Rate (bps): " + SendRate + " / " + ReceiveRate);
}
@ -247,14 +247,45 @@ namespace OpenSim.Client.MXP.PacketHandler
sessionsToRemove.Clear();
}
public bool AuthoriseUser(string participantName, string pass, UUID scene)
public bool AuthoriseUser(string participantName, string password, UUID sceneId, out UUID userId, out string firstName, out string lastName)
{
if (Scenes.ContainsKey(scene))
return true;
userId = UUID.Zero;
firstName = "";
lastName = "";
if (!Scenes.ContainsKey(sceneId))
{
m_log.Info("Login failed as region was not found: " + sceneId);
return false;
}
string[] nameParts=participantName.Split(' ');
if(nameParts.Length!=2)
{
m_log.Info("Login failed as user name is not formed of first and last name separated by space: " + participantName);
return false;
}
firstName = nameParts[0];
lastName = nameParts[1];
UserProfileData userProfile = Scenes[sceneId].CommsManager.UserService.GetUserProfile(firstName, lastName);
if (userProfile == null)
{
m_log.Info("Login failed as user was not found: " + participantName);
return false;
}
userId = userProfile.ID;
if (!password.StartsWith("$1$"))
{
password = "$1$" + Util.Md5Hash(password);
}
password = password.Remove(0, 3); //remove $1$
string s = Util.Md5Hash(password + ":" + userProfile.PasswordSalt);
return (userProfile.PasswordHash.Equals(s.ToString(), StringComparison.InvariantCultureIgnoreCase)
|| userProfile.PasswordHash.Equals(password, StringComparison.InvariantCultureIgnoreCase));
}
public void ProcessMessages()
{
if (transmitter.PendingSessionCount > 0)
@ -278,9 +309,13 @@ namespace OpenSim.Client.MXP.PacketHandler
JoinRequestMessage joinRequestMessage = (JoinRequestMessage) message;
UUID userId;
string firstName;
string lastName;
bool authorized = AuthoriseUser(joinRequestMessage.ParticipantName,
joinRequestMessage.ParticipantPassphrase,
new UUID(joinRequestMessage.BubbleId));
new UUID(joinRequestMessage.BubbleId), out userId, out firstName, out lastName);
if (authorized)
{
@ -292,10 +327,10 @@ namespace OpenSim.Client.MXP.PacketHandler
(session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" +
session.RemoteEndPoint.Port + ")");
AcceptConnection(session, joinRequestMessage, mxpSessionID);
AcceptConnection(session, joinRequestMessage, mxpSessionID,userId);
MXPClientView client = new MXPClientView(session, mxpSessionID, target,
joinRequestMessage.ParticipantName);
MXPClientView client = new MXPClientView(session, mxpSessionID,userId, target,
firstName, lastName);
m_log.Info("[MXP ClientStack] Created Client");
Clients.Add(client);
@ -393,7 +428,7 @@ namespace OpenSim.Client.MXP.PacketHandler
}
}
private void AcceptConnection(Session session, JoinRequestMessage joinRequestMessage, UUID mxpSessionID)
private void AcceptConnection(Session session, JoinRequestMessage joinRequestMessage, UUID mxpSessionID, UUID userId)
{
JoinResponseMessage joinResponseMessage = (JoinResponseMessage)MessageFactory.Current.ReserveMessage(
typeof(JoinResponseMessage));
@ -401,7 +436,7 @@ namespace OpenSim.Client.MXP.PacketHandler
joinResponseMessage.RequestMessageId = joinRequestMessage.MessageId;
joinResponseMessage.FailureCode = 0;
joinResponseMessage.ParticipantId = mxpSessionID.Guid;
joinResponseMessage.ParticipantId = userId.Guid;
joinResponseMessage.CloudUrl = cloudUrl;
joinResponseMessage.BubbleName = Scenes[new UUID(joinRequestMessage.BubbleId)].RegionInfo.RegionName;

View File

@ -1702,6 +1702,7 @@
<Reference name="System"/>
<Reference name="OpenSim.Framework"/>
<Reference name="OpenSim.Region.Framework"/>
<Reference name="OpenSim.Framework.Communications"/>
<Reference name="Nini.dll" />
<Reference name="log4net.dll"/>
<Reference name="protobuf-net"/>