2007-04-04 18:26:33 +00:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Text;
|
|
|
|
using libsecondlife;
|
|
|
|
using libsecondlife.Packets;
|
|
|
|
using OpenSim.Physics.Manager;
|
|
|
|
using OpenSim.Framework.Interfaces;
|
2007-04-25 13:03:48 +00:00
|
|
|
using OpenSim.Framework.Types;
|
2007-04-04 18:26:33 +00:00
|
|
|
using OpenSim.Framework.Terrain;
|
|
|
|
using OpenSim.Framework.Inventory;
|
2007-04-25 18:12:06 +00:00
|
|
|
using OpenSim.Framework.Utilities;
|
2007-04-04 18:26:33 +00:00
|
|
|
using OpenSim.Assets;
|
|
|
|
|
|
|
|
namespace OpenSim.world
|
|
|
|
{
|
2007-05-16 20:08:55 +00:00
|
|
|
public partial class World
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
2007-05-21 19:12:18 +00:00
|
|
|
public void ModifyTerrain(byte Action, float North, float West)
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
2007-05-21 19:12:18 +00:00
|
|
|
switch (Action)
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
|
|
|
case 1:
|
|
|
|
// raise terrain
|
2007-05-24 05:44:53 +00:00
|
|
|
Terrain.raise(North, West, 10.0, 0.001);
|
|
|
|
RegenerateTerrain(true, (int)North, (int)West);
|
2007-04-04 18:26:33 +00:00
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
//lower terrain
|
2007-05-24 05:44:53 +00:00
|
|
|
Terrain.lower(North, West, 10.0, 0.001);
|
|
|
|
RegenerateTerrain(true, (int)North, (int)West);
|
2007-04-04 18:26:33 +00:00
|
|
|
break;
|
|
|
|
}
|
2007-05-21 19:12:18 +00:00
|
|
|
return;
|
2007-04-04 18:26:33 +00:00
|
|
|
}
|
|
|
|
|
2007-05-21 16:06:58 +00:00
|
|
|
public void SimChat(byte[] message, byte type, LLVector3 fromPos, string fromName, LLUUID fromAgentID)
|
|
|
|
{
|
|
|
|
foreach (ClientView client in m_clientThreads.Values)
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
2007-05-16 17:12:17 +00:00
|
|
|
// int dis = Util.fast_distance2d((int)(client.ClientAvatar.Pos.X - simClient.ClientAvatar.Pos.X), (int)(client.ClientAvatar.Pos.Y - simClient.ClientAvatar.Pos.Y));
|
2007-05-21 16:06:58 +00:00
|
|
|
int dis = (int)client.ClientAvatar.Pos.GetDistanceTo(fromPos);
|
2007-05-16 17:12:17 +00:00
|
|
|
|
2007-05-21 16:06:58 +00:00
|
|
|
switch (type)
|
2007-04-25 18:12:06 +00:00
|
|
|
{
|
2007-05-16 17:12:17 +00:00
|
|
|
case 0: // Whisper
|
2007-04-25 18:12:06 +00:00
|
|
|
if ((dis < 10) && (dis > -10))
|
|
|
|
{
|
2007-05-21 16:06:58 +00:00
|
|
|
//should change so the message is sent through the avatar rather than direct to the ClientView
|
|
|
|
client.SendChatMessage(message, type, fromPos, fromName, fromAgentID);
|
2007-04-25 18:12:06 +00:00
|
|
|
}
|
|
|
|
break;
|
2007-05-16 17:12:17 +00:00
|
|
|
case 1: // Say
|
2007-04-25 18:12:06 +00:00
|
|
|
if ((dis < 30) && (dis > -30))
|
|
|
|
{
|
2007-05-21 16:06:58 +00:00
|
|
|
client.SendChatMessage(message, type, fromPos, fromName, fromAgentID);
|
2007-04-25 18:12:06 +00:00
|
|
|
}
|
|
|
|
break;
|
2007-05-16 17:12:17 +00:00
|
|
|
case 2: // Shout
|
2007-04-25 18:12:06 +00:00
|
|
|
if ((dis < 100) && (dis > -100))
|
|
|
|
{
|
2007-05-21 16:06:58 +00:00
|
|
|
client.SendChatMessage(message, type, fromPos, fromName, fromAgentID);
|
2007-04-25 18:12:06 +00:00
|
|
|
}
|
|
|
|
break;
|
2007-05-16 17:12:17 +00:00
|
|
|
|
|
|
|
case 0xff: // Broadcast
|
2007-05-21 16:06:58 +00:00
|
|
|
client.SendChatMessage(message, type, fromPos, fromName, fromAgentID);
|
2007-05-16 17:12:17 +00:00
|
|
|
break;
|
2007-04-25 18:12:06 +00:00
|
|
|
}
|
2007-05-13 12:25:08 +00:00
|
|
|
|
2007-04-04 18:26:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-05-21 19:12:18 +00:00
|
|
|
public void RezObject(AssetBase primasset, LLVector3 pos)
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
2007-05-21 19:12:18 +00:00
|
|
|
PrimData primd = new PrimData(primasset.Data);
|
|
|
|
Primitive nPrim = new Primitive(m_clientThreads, m_regionHandle, this);
|
|
|
|
nPrim.CreateFromStorage(primd, pos, this._primCount, true);
|
|
|
|
this.Entities.Add(nPrim.uuid, nPrim);
|
|
|
|
this._primCount++;
|
2007-04-04 18:26:33 +00:00
|
|
|
}
|
|
|
|
|
2007-05-21 16:06:58 +00:00
|
|
|
public bool DeRezObject(ClientView simClient, Packet packet)
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
|
|
|
DeRezObjectPacket DeRezPacket = (DeRezObjectPacket)packet;
|
|
|
|
|
|
|
|
//Needs to delete object from physics at a later date
|
|
|
|
if (DeRezPacket.AgentBlock.DestinationID == LLUUID.Zero)
|
|
|
|
{
|
|
|
|
//currently following code not used (or don't know of any case of destination being zero
|
|
|
|
libsecondlife.LLUUID[] DeRezEnts;
|
|
|
|
DeRezEnts = new libsecondlife.LLUUID[DeRezPacket.ObjectData.Length];
|
|
|
|
int i = 0;
|
|
|
|
foreach (DeRezObjectPacket.ObjectDataBlock Data in DeRezPacket.ObjectData)
|
|
|
|
{
|
|
|
|
|
|
|
|
//OpenSim.Framework.Console.MainConsole.Instance.WriteLine("LocalID:" + Data.ObjectLocalID.ToString());
|
|
|
|
foreach (Entity ent in this.Entities.Values)
|
|
|
|
{
|
|
|
|
if (ent.localid == Data.ObjectLocalID)
|
|
|
|
{
|
|
|
|
DeRezEnts[i++] = ent.uuid;
|
|
|
|
this.localStorage.RemovePrim(ent.uuid);
|
|
|
|
KillObjectPacket kill = new KillObjectPacket();
|
|
|
|
kill.ObjectData = new KillObjectPacket.ObjectDataBlock[1];
|
|
|
|
kill.ObjectData[0] = new KillObjectPacket.ObjectDataBlock();
|
|
|
|
kill.ObjectData[0].ID = ent.localid;
|
2007-05-21 16:06:58 +00:00
|
|
|
foreach (ClientView client in m_clientThreads.Values)
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
|
|
|
client.OutPacket(kill);
|
|
|
|
}
|
|
|
|
//Uncommenting this means an old UUID will be re-used, thus crashing the asset server
|
|
|
|
//Uncomment when prim/object UUIDs are random or such
|
|
|
|
//2007-03-22 - Randomskk
|
|
|
|
//this._primCount--;
|
2007-05-16 17:12:17 +00:00
|
|
|
OpenSim.Framework.Console.MainConsole.Instance.WriteLine(OpenSim.Framework.Console.LogPriority.VERBOSE, "Deleted UUID " + ent.uuid);
|
2007-04-04 18:26:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
foreach (libsecondlife.LLUUID uuid in DeRezEnts)
|
|
|
|
{
|
|
|
|
lock (Entities)
|
|
|
|
{
|
|
|
|
Entities.Remove(uuid);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
foreach (DeRezObjectPacket.ObjectDataBlock Data in DeRezPacket.ObjectData)
|
|
|
|
{
|
|
|
|
Entity selectedEnt = null;
|
|
|
|
//OpenSim.Framework.Console.MainConsole.Instance.WriteLine("LocalID:" + Data.ObjectLocalID.ToString());
|
|
|
|
foreach (Entity ent in this.Entities.Values)
|
|
|
|
{
|
|
|
|
if (ent.localid == Data.ObjectLocalID)
|
|
|
|
{
|
|
|
|
AssetBase primAsset = new AssetBase();
|
|
|
|
primAsset.FullID = LLUUID.Random();//DeRezPacket.AgentBlock.TransactionID.Combine(LLUUID.Zero); //should be combining with securesessionid
|
|
|
|
primAsset.InvType = 6;
|
|
|
|
primAsset.Type = 6;
|
|
|
|
primAsset.Name = "Prim";
|
|
|
|
primAsset.Description = "";
|
|
|
|
primAsset.Data = ((Primitive)ent).GetByteArray();
|
|
|
|
this._assetCache.AddAsset(primAsset);
|
|
|
|
this._inventoryCache.AddNewInventoryItem(simClient, DeRezPacket.AgentBlock.DestinationID, primAsset);
|
|
|
|
selectedEnt = ent;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (selectedEnt != null)
|
|
|
|
{
|
|
|
|
this.localStorage.RemovePrim(selectedEnt.uuid);
|
|
|
|
KillObjectPacket kill = new KillObjectPacket();
|
|
|
|
kill.ObjectData = new KillObjectPacket.ObjectDataBlock[1];
|
|
|
|
kill.ObjectData[0] = new KillObjectPacket.ObjectDataBlock();
|
|
|
|
kill.ObjectData[0].ID = selectedEnt.localid;
|
2007-05-21 16:06:58 +00:00
|
|
|
foreach (ClientView client in m_clientThreads.Values)
|
2007-04-04 18:26:33 +00:00
|
|
|
{
|
|
|
|
client.OutPacket(kill);
|
|
|
|
}
|
|
|
|
lock (Entities)
|
|
|
|
{
|
|
|
|
Entities.Remove(selectedEnt.uuid);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-05-22 11:25:34 +00:00
|
|
|
public void SendAvatarsToClient(ClientView RemoteClient)
|
|
|
|
{
|
|
|
|
foreach (ClientView client in m_clientThreads.Values)
|
|
|
|
{
|
|
|
|
if (client.AgentID != RemoteClient.AgentID)
|
|
|
|
{
|
|
|
|
// ObjectUpdatePacket objupdate = client.ClientAvatar.CreateUpdatePacket();
|
|
|
|
// RemoteClient.OutPacket(objupdate);
|
|
|
|
client.ClientAvatar.SendUpdateToOtherClient(RemoteClient.ClientAvatar);
|
|
|
|
client.ClientAvatar.SendAppearanceToOtherAgent(RemoteClient.ClientAvatar);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-05-21 19:12:18 +00:00
|
|
|
/*
|
2007-05-21 16:06:58 +00:00
|
|
|
public void RequestMapBlock(ClientView simClient, int minX, int minY, int maxX, int maxY)
|
2007-05-13 12:25:08 +00:00
|
|
|
{
|
|
|
|
System.Text.Encoding _enc = System.Text.Encoding.ASCII;
|
|
|
|
if (((m_regInfo.RegionLocX > minX) && (m_regInfo.RegionLocX < maxX)) && ((m_regInfo.RegionLocY > minY) && (m_regInfo.RegionLocY < maxY)))
|
|
|
|
{
|
|
|
|
MapBlockReplyPacket mapReply = new MapBlockReplyPacket();
|
|
|
|
mapReply.AgentData.AgentID = simClient.AgentID;
|
|
|
|
mapReply.AgentData.Flags = 0;
|
|
|
|
mapReply.Data = new MapBlockReplyPacket.DataBlock[1];
|
|
|
|
mapReply.Data[0] = new MapBlockReplyPacket.DataBlock();
|
2007-05-13 12:48:42 +00:00
|
|
|
mapReply.Data[0].MapImageID = new LLUUID("00000000-0000-0000-9999-000000000007");
|
2007-05-13 12:25:08 +00:00
|
|
|
mapReply.Data[0].X = (ushort)m_regInfo.RegionLocX;
|
|
|
|
mapReply.Data[0].Y = (ushort)m_regInfo.RegionLocY;
|
2007-05-16 17:12:17 +00:00
|
|
|
mapReply.Data[0].WaterHeight = (byte)m_regInfo.RegionWaterHeight;
|
2007-05-13 12:25:08 +00:00
|
|
|
mapReply.Data[0].Name = _enc.GetBytes(this.m_regionName);
|
|
|
|
mapReply.Data[0].RegionFlags = 72458694;
|
|
|
|
mapReply.Data[0].Access = 13;
|
|
|
|
mapReply.Data[0].Agents = 1; //should send number of clients connected
|
|
|
|
simClient.OutPacket(mapReply);
|
|
|
|
}
|
|
|
|
}
|
2007-05-21 19:12:18 +00:00
|
|
|
public bool RezObjectHandler(ClientView 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;
|
|
|
|
}
|
|
|
|
public bool ModifyTerrain(ClientView simClient, Packet packet)
|
|
|
|
{
|
|
|
|
ModifyLandPacket modify = (ModifyLandPacket)packet;
|
|
|
|
|
|
|
|
switch (modify.ModifyBlock.Action)
|
|
|
|
{
|
|
|
|
case 1:
|
|
|
|
// raise terrain
|
|
|
|
if (modify.ParcelData.Length > 0)
|
|
|
|
{
|
|
|
|
Terrain.raise(modify.ParcelData[0].North, modify.ParcelData[0].West, 10.0, 0.1);
|
|
|
|
RegenerateTerrain(true, (int)modify.ParcelData[0].North, (int)modify.ParcelData[0].West);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
//lower terrain
|
|
|
|
if (modify.ParcelData.Length > 0)
|
|
|
|
{
|
|
|
|
Terrain.lower(modify.ParcelData[0].North, modify.ParcelData[0].West, 10.0, 0.1);
|
|
|
|
RegenerateTerrain(true, (int)modify.ParcelData[0].North, (int)modify.ParcelData[0].West);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
*/
|
2007-05-13 12:25:08 +00:00
|
|
|
|
2007-04-04 18:26:33 +00:00
|
|
|
}
|
|
|
|
}
|