Moved more packet types to handlers
parent
def7335b6c
commit
f0a3edfb34
|
@ -353,6 +353,8 @@ namespace OpenSim
|
||||||
protected virtual void RegisterClientPacketHandlers()
|
protected virtual void RegisterClientPacketHandlers()
|
||||||
{
|
{
|
||||||
SimClient.AddPacketHandler(PacketType.ModifyLand, LocalWorld.ModifyTerrain);
|
SimClient.AddPacketHandler(PacketType.ModifyLand, LocalWorld.ModifyTerrain);
|
||||||
|
SimClient.AddPacketHandler(PacketType.ChatFromViewer, LocalWorld.SimChat);
|
||||||
|
SimClient.AddPacketHandler(PacketType.UUIDNameRequest, this.RequestUUIDName);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void RunCmd(string command, string[] cmdparams)
|
public void RunCmd(string command, string[] cmdparams)
|
||||||
|
@ -401,6 +403,29 @@ namespace OpenSim
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#region Client Packet Handlers
|
||||||
|
|
||||||
|
public bool RequestUUIDName(SimClient simClient, Packet packet)
|
||||||
|
{
|
||||||
|
System.Text.Encoding enc = System.Text.Encoding.ASCII;
|
||||||
|
Console.WriteLine(packet.ToString());
|
||||||
|
UUIDNameRequestPacket nameRequest = (UUIDNameRequestPacket)packet;
|
||||||
|
UUIDNameReplyPacket nameReply = new UUIDNameReplyPacket();
|
||||||
|
nameReply.UUIDNameBlock = new UUIDNameReplyPacket.UUIDNameBlockBlock[nameRequest.UUIDNameBlock.Length];
|
||||||
|
|
||||||
|
for (int i = 0; i < nameRequest.UUIDNameBlock.Length; i++)
|
||||||
|
{
|
||||||
|
nameReply.UUIDNameBlock[i] = new UUIDNameReplyPacket.UUIDNameBlockBlock();
|
||||||
|
nameReply.UUIDNameBlock[i].ID = nameRequest.UUIDNameBlock[i].ID;
|
||||||
|
nameReply.UUIDNameBlock[i].FirstName = enc.GetBytes("Who\0"); //for now send any name
|
||||||
|
nameReply.UUIDNameBlock[i].LastName = enc.GetBytes("Knows\0"); //in future need to look it up
|
||||||
|
}
|
||||||
|
simClient.OutPacket(nameReply);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -123,7 +123,8 @@ namespace OpenSim
|
||||||
|
|
||||||
protected virtual void RegisterLocalPacketHandlers()
|
protected virtual void RegisterLocalPacketHandlers()
|
||||||
{
|
{
|
||||||
|
this.AddLocalPacketHandler(PacketType.LogoutRequest, this.Logout);
|
||||||
|
this.AddLocalPacketHandler(PacketType.AgentCachedTexture, this.AgentTextureCached);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static bool AddPacketHandler(PacketType packetType, PacketMethod handler)
|
public static bool AddPacketHandler(PacketType packetType, PacketMethod handler)
|
||||||
|
@ -250,24 +251,6 @@ namespace OpenSim
|
||||||
// Console.WriteLine(appear.ToString());
|
// Console.WriteLine(appear.ToString());
|
||||||
this.ClientAvatar.SetAppearance(appear);
|
this.ClientAvatar.SetAppearance(appear);
|
||||||
break;
|
break;
|
||||||
case PacketType.AgentCachedTexture:
|
|
||||||
Console.WriteLine(Pack.ToString());
|
|
||||||
AgentCachedTexturePacket chechedtex = (AgentCachedTexturePacket)Pack;
|
|
||||||
AgentCachedTextureResponsePacket cachedresp = new AgentCachedTextureResponsePacket();
|
|
||||||
cachedresp.AgentData.AgentID = this.AgentID;
|
|
||||||
cachedresp.AgentData.SessionID = this.SessionID;
|
|
||||||
cachedresp.AgentData.SerialNum = this.cachedtextureserial;
|
|
||||||
this.cachedtextureserial++;
|
|
||||||
cachedresp.WearableData = new AgentCachedTextureResponsePacket.WearableDataBlock[chechedtex.WearableData.Length];
|
|
||||||
for (int i = 0; i < chechedtex.WearableData.Length; i++)
|
|
||||||
{
|
|
||||||
cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
|
|
||||||
cachedresp.WearableData[i].TextureIndex = chechedtex.WearableData[i].TextureIndex;
|
|
||||||
cachedresp.WearableData[i].TextureID = LLUUID.Zero;
|
|
||||||
cachedresp.WearableData[i].HostName = new byte[0];
|
|
||||||
}
|
|
||||||
this.OutPacket(cachedresp);
|
|
||||||
break;
|
|
||||||
case PacketType.ObjectAdd:
|
case PacketType.ObjectAdd:
|
||||||
m_world.AddNewPrim((ObjectAddPacket)Pack, this);
|
m_world.AddNewPrim((ObjectAddPacket)Pack, this);
|
||||||
break;
|
break;
|
||||||
|
@ -292,7 +275,6 @@ namespace OpenSim
|
||||||
break;
|
break;
|
||||||
case PacketType.MultipleObjectUpdate:
|
case PacketType.MultipleObjectUpdate:
|
||||||
MultipleObjectUpdatePacket multipleupdate = (MultipleObjectUpdatePacket)Pack;
|
MultipleObjectUpdatePacket multipleupdate = (MultipleObjectUpdatePacket)Pack;
|
||||||
|
|
||||||
for (int i = 0; i < multipleupdate.ObjectData.Length; i++)
|
for (int i = 0; i < multipleupdate.ObjectData.Length; i++)
|
||||||
{
|
{
|
||||||
if (multipleupdate.ObjectData[i].Type == 9) //change position
|
if (multipleupdate.ObjectData[i].Type == 9) //change position
|
||||||
|
@ -306,7 +288,6 @@ namespace OpenSim
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//should update stored position of the prim
|
//should update stored position of the prim
|
||||||
}
|
}
|
||||||
else if (multipleupdate.ObjectData[i].Type == 10)//rotation
|
else if (multipleupdate.ObjectData[i].Type == 10)//rotation
|
||||||
|
@ -350,63 +331,6 @@ namespace OpenSim
|
||||||
case PacketType.AgentUpdate:
|
case PacketType.AgentUpdate:
|
||||||
ClientAvatar.HandleUpdate((AgentUpdatePacket)Pack);
|
ClientAvatar.HandleUpdate((AgentUpdatePacket)Pack);
|
||||||
break;
|
break;
|
||||||
case PacketType.LogoutRequest:
|
|
||||||
OpenSim.Framework.Console.MainConsole.Instance.WriteLine("OpenSimClient.cs:ProcessInPacket() - Got a logout request");
|
|
||||||
//send reply to let the client logout
|
|
||||||
LogoutReplyPacket logReply = new LogoutReplyPacket();
|
|
||||||
logReply.AgentData.AgentID = this.AgentID;
|
|
||||||
logReply.AgentData.SessionID = this.SessionID;
|
|
||||||
logReply.InventoryData = new LogoutReplyPacket.InventoryDataBlock[1];
|
|
||||||
logReply.InventoryData[0] = new LogoutReplyPacket.InventoryDataBlock();
|
|
||||||
logReply.InventoryData[0].ItemID = LLUUID.Zero;
|
|
||||||
OutPacket(logReply);
|
|
||||||
//tell all clients to kill our object
|
|
||||||
KillObjectPacket kill = new KillObjectPacket();
|
|
||||||
kill.ObjectData = new KillObjectPacket.ObjectDataBlock[1];
|
|
||||||
kill.ObjectData[0] = new KillObjectPacket.ObjectDataBlock();
|
|
||||||
kill.ObjectData[0].ID = this.ClientAvatar.localid;
|
|
||||||
foreach (SimClient client in m_clientThreads.Values)
|
|
||||||
{
|
|
||||||
client.OutPacket(kill);
|
|
||||||
}
|
|
||||||
if (this.m_userServer != null)
|
|
||||||
{
|
|
||||||
this.m_inventoryCache.ClientLeaving(this.AgentID, this.m_userServer);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
this.m_inventoryCache.ClientLeaving(this.AgentID, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
m_gridServer.LogoutSession(this.SessionID, this.AgentID, this.CircuitCode);
|
|
||||||
lock (m_world.Entities)
|
|
||||||
{
|
|
||||||
m_world.Entities.Remove(this.AgentID);
|
|
||||||
}
|
|
||||||
//need to do other cleaning up here too
|
|
||||||
m_clientThreads.Remove(this.CircuitCode); //this.userEP);
|
|
||||||
m_application.RemoveClientCircuit(this.CircuitCode);
|
|
||||||
this.ClientThread.Abort();
|
|
||||||
break;
|
|
||||||
case PacketType.ChatFromViewer:
|
|
||||||
ChatFromViewerPacket inchatpack = (ChatFromViewerPacket)Pack;
|
|
||||||
if (Helpers.FieldToString(inchatpack.ChatData.Message) == "") break;
|
|
||||||
|
|
||||||
|
|
||||||
libsecondlife.Packets.ChatFromSimulatorPacket reply = new ChatFromSimulatorPacket();
|
|
||||||
reply.ChatData.Audible = 1;
|
|
||||||
reply.ChatData.Message = inchatpack.ChatData.Message;
|
|
||||||
reply.ChatData.ChatType = 1;
|
|
||||||
reply.ChatData.SourceType = 1;
|
|
||||||
reply.ChatData.Position = this.ClientAvatar.position;
|
|
||||||
reply.ChatData.FromName = _enc.GetBytes(this.ClientAvatar.firstname + " " + this.ClientAvatar.lastname + "\0");
|
|
||||||
reply.ChatData.OwnerID = this.AgentID;
|
|
||||||
reply.ChatData.SourceID = this.AgentID;
|
|
||||||
foreach (SimClient client in m_clientThreads.Values)
|
|
||||||
{
|
|
||||||
client.OutPacket(reply);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case PacketType.ObjectImage:
|
case PacketType.ObjectImage:
|
||||||
ObjectImagePacket imagePack = (ObjectImagePacket)Pack;
|
ObjectImagePacket imagePack = (ObjectImagePacket)Pack;
|
||||||
for (int i = 0; i < imagePack.ObjectData.Length; i++)
|
for (int i = 0; i < imagePack.ObjectData.Length; i++)
|
||||||
|
@ -429,23 +353,12 @@ namespace OpenSim
|
||||||
((OpenSim.world.Primitive)ent).UpdateObjectFlags(flags);
|
((OpenSim.world.Primitive)ent).UpdateObjectFlags(flags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case PacketType.AssetUploadRequest:
|
case PacketType.AssetUploadRequest:
|
||||||
//this.debug = true;
|
|
||||||
AssetUploadRequestPacket request = (AssetUploadRequestPacket)Pack;
|
AssetUploadRequestPacket request = (AssetUploadRequestPacket)Pack;
|
||||||
// Console.WriteLine(Pack.ToString());
|
|
||||||
// if (request.AssetBlock.Type == 0)
|
|
||||||
// {
|
|
||||||
//this.UploadAssets.HandleUploadPacket(request, LLUUID.Random());
|
|
||||||
//}
|
|
||||||
//else
|
|
||||||
//{
|
|
||||||
this.UploadAssets.HandleUploadPacket(request, request.AssetBlock.TransactionID.Combine(this.SecureSessionID));
|
this.UploadAssets.HandleUploadPacket(request, request.AssetBlock.TransactionID.Combine(this.SecureSessionID));
|
||||||
//}
|
|
||||||
break;
|
break;
|
||||||
case PacketType.SendXferPacket:
|
case PacketType.SendXferPacket:
|
||||||
Console.WriteLine(Pack.ToString());
|
|
||||||
this.UploadAssets.HandleXferPacket((SendXferPacketPacket)Pack);
|
this.UploadAssets.HandleXferPacket((SendXferPacketPacket)Pack);
|
||||||
break;
|
break;
|
||||||
case PacketType.CreateInventoryFolder:
|
case PacketType.CreateInventoryFolder:
|
||||||
|
@ -522,11 +435,11 @@ namespace OpenSim
|
||||||
break;
|
break;
|
||||||
case PacketType.DeRezObject:
|
case PacketType.DeRezObject:
|
||||||
//OpenSim.Framework.Console.MainConsole.Instance.WriteLine("Received DeRezObject packet");
|
//OpenSim.Framework.Console.MainConsole.Instance.WriteLine("Received DeRezObject packet");
|
||||||
m_world.DeRezObject((DeRezObjectPacket)Pack, this);
|
m_world.DeRezObject(this, Pack);
|
||||||
break;
|
break;
|
||||||
case PacketType.RezObject:
|
case PacketType.RezObject:
|
||||||
//Console.WriteLine(Pack.ToString());
|
//Console.WriteLine(Pack.ToString());
|
||||||
m_world.RezObject(this, (RezObjectPacket)Pack);
|
m_world.RezObject(this, Pack);
|
||||||
break;
|
break;
|
||||||
case PacketType.RequestTaskInventory:
|
case PacketType.RequestTaskInventory:
|
||||||
// Console.WriteLine(Pack.ToString());
|
// Console.WriteLine(Pack.ToString());
|
||||||
|
@ -548,22 +461,6 @@ namespace OpenSim
|
||||||
this.OutPacket(replytask);
|
this.OutPacket(replytask);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case PacketType.UUIDNameRequest:
|
|
||||||
//System.Text.Encoding _enc = System.Text.Encoding.ASCII;
|
|
||||||
Console.WriteLine(Pack.ToString());
|
|
||||||
UUIDNameRequestPacket nameRequest = (UUIDNameRequestPacket)Pack;
|
|
||||||
UUIDNameReplyPacket nameReply = new UUIDNameReplyPacket();
|
|
||||||
nameReply.UUIDNameBlock = new UUIDNameReplyPacket.UUIDNameBlockBlock[nameRequest.UUIDNameBlock.Length];
|
|
||||||
|
|
||||||
for (int i = 0; i < nameRequest.UUIDNameBlock.Length; i++)
|
|
||||||
{
|
|
||||||
nameReply.UUIDNameBlock[i] = new UUIDNameReplyPacket.UUIDNameBlockBlock();
|
|
||||||
nameReply.UUIDNameBlock[i].ID = nameRequest.UUIDNameBlock[i].ID;
|
|
||||||
nameReply.UUIDNameBlock[i].FirstName = _enc.GetBytes("Who\0"); //for now send any name
|
|
||||||
nameReply.UUIDNameBlock[i].LastName = _enc.GetBytes("Knows\0"); //in future need to look it up
|
|
||||||
}
|
|
||||||
this.OutPacket(nameReply);
|
|
||||||
break;
|
|
||||||
case PacketType.AgentAnimation:
|
case PacketType.AgentAnimation:
|
||||||
//Console.WriteLine(Pack.ToString());
|
//Console.WriteLine(Pack.ToString());
|
||||||
break;
|
break;
|
||||||
|
@ -872,6 +769,71 @@ namespace OpenSim
|
||||||
ClientLoop();
|
ClientLoop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#region Packet handlers
|
||||||
|
|
||||||
|
protected virtual bool Logout(SimClient simClient, Packet packet)
|
||||||
|
{
|
||||||
|
OpenSim.Framework.Console.MainConsole.Instance.WriteLine("OpenSimClient.cs:ProcessInPacket() - Got a logout request");
|
||||||
|
//send reply to let the client logout
|
||||||
|
LogoutReplyPacket logReply = new LogoutReplyPacket();
|
||||||
|
logReply.AgentData.AgentID = this.AgentID;
|
||||||
|
logReply.AgentData.SessionID = this.SessionID;
|
||||||
|
logReply.InventoryData = new LogoutReplyPacket.InventoryDataBlock[1];
|
||||||
|
logReply.InventoryData[0] = new LogoutReplyPacket.InventoryDataBlock();
|
||||||
|
logReply.InventoryData[0].ItemID = LLUUID.Zero;
|
||||||
|
OutPacket(logReply);
|
||||||
|
//tell all clients to kill our object
|
||||||
|
KillObjectPacket kill = new KillObjectPacket();
|
||||||
|
kill.ObjectData = new KillObjectPacket.ObjectDataBlock[1];
|
||||||
|
kill.ObjectData[0] = new KillObjectPacket.ObjectDataBlock();
|
||||||
|
kill.ObjectData[0].ID = this.ClientAvatar.localid;
|
||||||
|
foreach (SimClient client in m_clientThreads.Values)
|
||||||
|
{
|
||||||
|
client.OutPacket(kill);
|
||||||
|
}
|
||||||
|
if (this.m_userServer != null)
|
||||||
|
{
|
||||||
|
this.m_inventoryCache.ClientLeaving(this.AgentID, this.m_userServer);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.m_inventoryCache.ClientLeaving(this.AgentID, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_gridServer.LogoutSession(this.SessionID, this.AgentID, this.CircuitCode);
|
||||||
|
lock (m_world.Entities)
|
||||||
|
{
|
||||||
|
m_world.Entities.Remove(this.AgentID);
|
||||||
|
}
|
||||||
|
//need to do other cleaning up here too
|
||||||
|
m_clientThreads.Remove(this.CircuitCode); //this.userEP);
|
||||||
|
m_application.RemoveClientCircuit(this.CircuitCode);
|
||||||
|
this.ClientThread.Abort();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected bool AgentTextureCached(SimClient simclient, Packet packet)
|
||||||
|
{
|
||||||
|
Console.WriteLine(packet.ToString());
|
||||||
|
AgentCachedTexturePacket chechedtex = (AgentCachedTexturePacket)packet;
|
||||||
|
AgentCachedTextureResponsePacket cachedresp = new AgentCachedTextureResponsePacket();
|
||||||
|
cachedresp.AgentData.AgentID = this.AgentID;
|
||||||
|
cachedresp.AgentData.SessionID = this.SessionID;
|
||||||
|
cachedresp.AgentData.SerialNum = this.cachedtextureserial;
|
||||||
|
this.cachedtextureserial++;
|
||||||
|
cachedresp.WearableData = new AgentCachedTextureResponsePacket.WearableDataBlock[chechedtex.WearableData.Length];
|
||||||
|
for (int i = 0; i < chechedtex.WearableData.Length; i++)
|
||||||
|
{
|
||||||
|
cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
|
||||||
|
cachedresp.WearableData[i].TextureIndex = chechedtex.WearableData[i].TextureIndex;
|
||||||
|
cachedresp.WearableData[i].TextureID = LLUUID.Zero;
|
||||||
|
cachedresp.WearableData[i].HostName = new byte[0];
|
||||||
|
}
|
||||||
|
this.OutPacket(cachedresp);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
private AgentInventory CreateInventory(LLUUID baseFolder)
|
private AgentInventory CreateInventory(LLUUID baseFolder)
|
||||||
{
|
{
|
||||||
|
|
|
@ -308,8 +308,9 @@ namespace OpenSim.world
|
||||||
this._primCount++;
|
this._primCount++;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void DeRezObject(DeRezObjectPacket DeRezPacket, SimClient AgentClient)
|
public void DeRezObject(SimClient simClient, Packet packet)
|
||||||
{
|
{
|
||||||
|
DeRezObjectPacket DeRezPacket = (DeRezObjectPacket)packet;
|
||||||
// Console.WriteLine(DeRezPacket);
|
// Console.WriteLine(DeRezPacket);
|
||||||
//Needs to delete object from physics at a later date
|
//Needs to delete object from physics at a later date
|
||||||
if (DeRezPacket.AgentBlock.DestinationID == LLUUID.Zero)
|
if (DeRezPacket.AgentBlock.DestinationID == LLUUID.Zero)
|
||||||
|
@ -369,7 +370,7 @@ namespace OpenSim.world
|
||||||
primAsset.Description = "";
|
primAsset.Description = "";
|
||||||
primAsset.Data = ((Primitive)ent).GetByteArray();
|
primAsset.Data = ((Primitive)ent).GetByteArray();
|
||||||
this._assetCache.AddAsset(primAsset);
|
this._assetCache.AddAsset(primAsset);
|
||||||
this._inventoryCache.AddNewInventoryItem(AgentClient, DeRezPacket.AgentBlock.DestinationID, primAsset);
|
this._inventoryCache.AddNewInventoryItem(simClient, DeRezPacket.AgentBlock.DestinationID, primAsset);
|
||||||
selectedEnt = ent;
|
selectedEnt = ent;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -394,27 +395,6 @@ namespace OpenSim.world
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void RezObject(SimClient remoteClient, RezObjectPacket packet)
|
|
||||||
{
|
|
||||||
AgentInventory inven =this._inventoryCache.GetAgentsInventory(remoteClient.AgentID);
|
|
||||||
if(inven != null)
|
|
||||||
{
|
|
||||||
if (inven.InventoryItems.ContainsKey(packet.InventoryData.ItemID))
|
|
||||||
{
|
|
||||||
AssetBase asset = this._assetCache.GetAsset(inven.InventoryItems[packet.InventoryData.ItemID].AssetID);
|
|
||||||
if (asset != null)
|
|
||||||
{
|
|
||||||
PrimData primd = new PrimData(asset.Data);
|
|
||||||
Primitive nPrim = new Primitive(m_clientThreads, m_regionHandle, this);
|
|
||||||
nPrim.CreateFromStorage(primd, packet.RezData.RayEnd, this._primCount, true);
|
|
||||||
this.Entities.Add(nPrim.uuid, nPrim);
|
|
||||||
this._primCount++;
|
|
||||||
this._inventoryCache.DeleteInventoryItem(remoteClient, packet.InventoryData.ItemID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool Backup()
|
public bool Backup()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -470,6 +450,56 @@ namespace OpenSim.world
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public bool SimChat(SimClient simClient, Packet packet)
|
||||||
|
{
|
||||||
|
System.Text.Encoding enc = System.Text.Encoding.ASCII;
|
||||||
|
ChatFromViewerPacket inchatpack = (ChatFromViewerPacket)packet;
|
||||||
|
if (Helpers.FieldToString(inchatpack.ChatData.Message) == "")
|
||||||
|
{
|
||||||
|
//empty message so don't bother with it
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
libsecondlife.Packets.ChatFromSimulatorPacket reply = new ChatFromSimulatorPacket();
|
||||||
|
reply.ChatData.Audible = 1;
|
||||||
|
reply.ChatData.Message = inchatpack.ChatData.Message;
|
||||||
|
reply.ChatData.ChatType = 1;
|
||||||
|
reply.ChatData.SourceType = 1;
|
||||||
|
reply.ChatData.Position = simClient.ClientAvatar.position;
|
||||||
|
reply.ChatData.FromName = enc.GetBytes(simClient.ClientAvatar.firstname + " " + simClient.ClientAvatar.lastname + "\0");
|
||||||
|
reply.ChatData.OwnerID = simClient.AgentID;
|
||||||
|
reply.ChatData.SourceID = simClient.AgentID;
|
||||||
|
foreach (SimClient client in m_clientThreads.Values)
|
||||||
|
{
|
||||||
|
client.OutPacket(reply);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool RezObject(SimClient simClient, Packet packet)
|
||||||
|
{
|
||||||
|
RezObjectPacket rezPacket = (RezObjectPacket)packet;
|
||||||
|
AgentInventory inven = this._inventoryCache.GetAgentsInventory(simClient.AgentID);
|
||||||
|
if (inven != null)
|
||||||
|
{
|
||||||
|
if (inven.InventoryItems.ContainsKey(rezPacket.InventoryData.ItemID))
|
||||||
|
{
|
||||||
|
AssetBase asset = this._assetCache.GetAsset(inven.InventoryItems[rezPacket.InventoryData.ItemID].AssetID);
|
||||||
|
if (asset != null)
|
||||||
|
{
|
||||||
|
PrimData primd = new PrimData(asset.Data);
|
||||||
|
Primitive nPrim = new Primitive(m_clientThreads, m_regionHandle, this);
|
||||||
|
nPrim.CreateFromStorage(primd, rezPacket.RezData.RayEnd, this._primCount, true);
|
||||||
|
this.Entities.Add(nPrim.uuid, nPrim);
|
||||||
|
this._primCount++;
|
||||||
|
this._inventoryCache.DeleteInventoryItem(simClient, rezPacket.InventoryData.ItemID);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue