From 429a84f390212d0f414a08420707fc90aca2a331 Mon Sep 17 00:00:00 2001
From: John Hurliman
Date: Mon, 5 Oct 2009 17:38:14 -0700
Subject: Beginning work on the new LLUDP implementation
---
.../Region/ClientStack/LindenUDP/LLClientView.cs | 12635 +++++++++----------
1 file changed, 6060 insertions(+), 6575 deletions(-)
(limited to 'OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs')
diff --git a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
index 0052729..31cd53f 100644
--- a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
@@ -58,442 +58,120 @@ namespace OpenSim.Region.ClientStack.LindenUDP
///
public class LLClientView : IClientAPI, IClientCore, IClientIM, IClientChat, IClientIPEndpoint, IStatsCollector
{
+ // LLClientView Only
+ public delegate void BinaryGenericMessage(Object sender, string method, byte[][] args);
+
+ /// Used to adjust Sun Orbit values so Linden based viewers properly position sun
+ private const float m_sunPainDaHalfOrbitalCutoff = 4.712388980384689858f;
+
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
+ protected static Dictionary PacketHandlers = new Dictionary(); //Global/static handlers for all clients
- /* static variables */
- public static SynchronizeClientHandler SynchronizeClient;
- /* private variables */
+ private readonly LLUDPServer m_udpServer;
+ private readonly LLUDPClient m_udpClient;
private readonly UUID m_sessionId;
private readonly UUID m_secureSessionId = UUID.Zero;
+ private readonly UUID m_agentId;
+ private readonly uint m_circuitCode;
+ private readonly byte[] m_channelVersion = Utils.StringToBytes("OpenSimulator Server"); // Dummy value needed by libSL
+ private readonly Dictionary m_defaultAnimations = new Dictionary();
+ private readonly IGroupsModule m_GroupsModule;
private int m_debugPacketLevel;
-
- //private readonly IAssetCache m_assetCache;
private int m_cachedTextureSerial;
private Timer m_clientPingTimer;
-
private Timer m_avatarTerseUpdateTimer;
private List m_avatarTerseUpdates = new List();
-
private Timer m_primTerseUpdateTimer;
private List m_primTerseUpdates = new List();
private Timer m_primFullUpdateTimer;
- private List m_primFullUpdates =
- new List();
-
+ private List m_primFullUpdates = new List();
private bool m_clientBlocked;
-
private int m_probesWithNoIngressPackets;
-
- private readonly UUID m_agentId;
- private readonly uint m_circuitCode;
private int m_moneyBalance;
- private readonly ILLPacketHandler m_PacketHandler;
-
private int m_animationSequenceNumber = 1;
-
- private readonly byte[] m_channelVersion = Utils.StringToBytes("OpenSimulator Server"); // Dummy value needed by libSL
-
- private readonly Dictionary m_defaultAnimations = new Dictionary();
-
private bool m_SendLogoutPacketWhenClosing = true;
-
private int m_inPacketsChecked;
-
- // Used to adjust Sun Orbit values so Linden based viewers properly position sun
- private const float m_sunPainDaHalfOrbitalCutoff = 4.712388980384689858f;
-
-
- /* protected variables */
-
- protected static Dictionary PacketHandlers =
- new Dictionary(); //Global/static handlers for all clients
+ private AgentUpdateArgs lastarg;
+ private bool m_IsActive = true;
protected Dictionary m_packetHandlers = new Dictionary();
protected Dictionary m_genericPacketHandlers = new Dictionary(); //PauPaw:Local Generic Message handlers
-
protected IScene m_scene;
-
- protected LLPacketServer m_networkServer;
-
protected LLImageManager m_imageManager;
-
- /* public variables */
protected string m_firstName;
protected string m_lastName;
protected Thread m_clientThread;
protected Vector3 m_startpos;
protected EndPoint m_userEndPoint;
- protected EndPoint m_proxyEndPoint;
protected UUID m_activeGroupID = UUID.Zero;
protected string m_activeGroupName = String.Empty;
protected ulong m_activeGroupPowers;
protected Dictionary m_groupPowers = new Dictionary();
- protected int m_avatarTerseUpdateRate = 50;
- protected int m_avatarTerseUpdatesPerPacket = 5;
+ protected int m_terrainCheckerCount;
- // LL uses these limits, apparently. Compressed terse would be
- // 23, but we don't have that yet
- //
+ // LL uses these limits, apparently. Compressed terse would be 23, but we don't have that yet
protected int m_primTerseUpdatesPerPacket = 10;
protected int m_primFullUpdatesPerPacket = 14;
-
protected int m_primTerseUpdateRate = 10;
protected int m_primFullUpdateRate = 14;
-
protected int m_textureSendLimit = 20;
protected int m_textureDataLimit = 10;
-
+ protected int m_avatarTerseUpdateRate = 50;
+ protected int m_avatarTerseUpdatesPerPacket = 5;
protected int m_packetMTU = 1400;
-
protected IAssetService m_assetService;
- // LLClientView Only
- public delegate void BinaryGenericMessage(Object sender, string method, byte[][] args);
-
- /* Instantiated Designated Event Delegates */
- //- used so we don't create new objects for each incoming packet and then toss it out later */
-
- private GenericMessage handlerGenericMessage;
- private RequestAvatarProperties handlerRequestAvatarProperties; //OnRequestAvatarProperties;
- private UpdateAvatarProperties handlerUpdateAvatarProperties; // OnUpdateAvatarProperties;
- private ChatMessage handlerChatFromClient; //OnChatFromClient;
- private ChatMessage handlerChatFromClient2; //OnChatFromClient;
- private ImprovedInstantMessage handlerInstantMessage; //OnInstantMessage;
- private FriendActionDelegate handlerApproveFriendRequest; //OnApproveFriendRequest;
- private FriendshipTermination handlerTerminateFriendship; //OnTerminateFriendship;
- private RezObject handlerRezObject; //OnRezObject;
- private DeRezObject handlerDeRezObject; //OnDeRezObject;
- private ModifyTerrain handlerModifyTerrain;
- private BakeTerrain handlerBakeTerrain;
- private EstateChangeInfo handlerEstateChangeInfo;
- private Action handlerRegionHandShakeReply; //OnRegionHandShakeReply;
- private GenericCall2 handlerRequestWearables; //OnRequestWearables;
- private Action handlerRequestAvatarsData; //OnRequestAvatarsData;
- private SetAppearance handlerSetAppearance; //OnSetAppearance;
- private AvatarNowWearing handlerAvatarNowWearing; //OnAvatarNowWearing;
- private RezSingleAttachmentFromInv handlerRezSingleAttachment; //OnRezSingleAttachmentFromInv;
- private RezMultipleAttachmentsFromInv handlerRezMultipleAttachments; //OnRezMultipleAttachmentsFromInv;
- private UUIDNameRequest handlerDetachAttachmentIntoInv; // Detach attachment!
- private ObjectAttach handlerObjectAttach; //OnObjectAttach;
- private SetAlwaysRun handlerSetAlwaysRun; //OnSetAlwaysRun;
- private GenericCall2 handlerCompleteMovementToRegion; //OnCompleteMovementToRegion;
- private UpdateAgent handlerAgentUpdate; //OnAgentUpdate;
- private StartAnim handlerStartAnim;
- private StopAnim handlerStopAnim;
- private AgentRequestSit handlerAgentRequestSit; //OnAgentRequestSit;
- private AgentSit handlerAgentSit; //OnAgentSit;
- private AvatarPickerRequest handlerAvatarPickerRequest; //OnAvatarPickerRequest;
- private FetchInventory handlerAgentDataUpdateRequest; //OnAgentDataUpdateRequest;
- private TeleportLocationRequest handlerSetStartLocationRequest; //OnSetStartLocationRequest;
- private TeleportLandmarkRequest handlerTeleportLandmarkRequest; //OnTeleportLandmarkRequest;
- private LinkObjects handlerLinkObjects; //OnLinkObjects;
- private DelinkObjects handlerDelinkObjects; //OnDelinkObjects;
- private AddNewPrim handlerAddPrim; //OnAddPrim;
- private UpdateShape handlerUpdatePrimShape; //null;
- private ObjectExtraParams handlerUpdateExtraParams; //OnUpdateExtraParams;
- private ObjectDuplicate handlerObjectDuplicate;
- private ObjectDuplicateOnRay handlerObjectDuplicateOnRay;
- private ObjectRequest handlerObjectRequest;
- private ObjectSelect handlerObjectSelect;
- private ObjectDeselect handlerObjectDeselect;
- private ObjectIncludeInSearch handlerObjectIncludeInSearch;
- private UpdatePrimFlags handlerUpdatePrimFlags; //OnUpdatePrimFlags;
- private UpdatePrimTexture handlerUpdatePrimTexture;
- private GrabObject handlerGrabObject; //OnGrabObject;
- private MoveObject handlerGrabUpdate; //OnGrabUpdate;
- private DeGrabObject handlerDeGrabObject; //OnDeGrabObject;
- private SpinStart handlerSpinStart; //OnSpinStart;
- private SpinObject handlerSpinUpdate; //OnSpinUpdate;
- private SpinStop handlerSpinStop; //OnSpinStop;
- private GenericCall7 handlerObjectDescription;
- private GenericCall7 handlerObjectName;
- private GenericCall7 handlerObjectClickAction;
- private GenericCall7 handlerObjectMaterial;
- private ObjectPermissions handlerObjectPermissions;
- private RequestObjectPropertiesFamily handlerRequestObjectPropertiesFamily; //OnRequestObjectPropertiesFamily;
- //private TextureRequest handlerTextureRequest;
- private UDPAssetUploadRequest handlerAssetUploadRequest; //OnAssetUploadRequest;
- private RequestXfer handlerRequestXfer; //OnRequestXfer;
- private XferReceive handlerXferReceive; //OnXferReceive;
- private ConfirmXfer handlerConfirmXfer; //OnConfirmXfer;
- private AbortXfer handlerAbortXfer;
- private CreateInventoryFolder handlerCreateInventoryFolder; //OnCreateNewInventoryFolder;
- private UpdateInventoryFolder handlerUpdateInventoryFolder;
- private MoveInventoryFolder handlerMoveInventoryFolder;
- private CreateNewInventoryItem handlerCreateNewInventoryItem; //OnCreateNewInventoryItem;
- private FetchInventory handlerFetchInventory;
- private FetchInventoryDescendents handlerFetchInventoryDescendents; //OnFetchInventoryDescendents;
- private PurgeInventoryDescendents handlerPurgeInventoryDescendents; //OnPurgeInventoryDescendents;
- private UpdateInventoryItem handlerUpdateInventoryItem;
- private CopyInventoryItem handlerCopyInventoryItem;
- private MoveInventoryItem handlerMoveInventoryItem;
- private RemoveInventoryItem handlerRemoveInventoryItem;
- private RemoveInventoryFolder handlerRemoveInventoryFolder;
- private RequestTaskInventory handlerRequestTaskInventory; //OnRequestTaskInventory;
- private UpdateTaskInventory handlerUpdateTaskInventory; //OnUpdateTaskInventory;
- private MoveTaskInventory handlerMoveTaskItem;
- private RemoveTaskInventory handlerRemoveTaskItem; //OnRemoveTaskItem;
- private RezScript handlerRezScript; //OnRezScript;
- private RequestMapBlocks handlerRequestMapBlocks; //OnRequestMapBlocks;
- private RequestMapName handlerMapNameRequest; //OnMapNameRequest;
- private TeleportLocationRequest handlerTeleportLocationRequest; //OnTeleportLocationRequest;
- private MoneyBalanceRequest handlerMoneyBalanceRequest; //OnMoneyBalanceRequest;
- private UUIDNameRequest handlerNameRequest;
- private ParcelAccessListRequest handlerParcelAccessListRequest; //OnParcelAccessListRequest;
- private ParcelAccessListUpdateRequest handlerParcelAccessListUpdateRequest; //OnParcelAccessListUpdateRequest;
- private ParcelPropertiesRequest handlerParcelPropertiesRequest; //OnParcelPropertiesRequest;
- private ParcelDivideRequest handlerParcelDivideRequest; //OnParcelDivideRequest;
- private ParcelJoinRequest handlerParcelJoinRequest; //OnParcelJoinRequest;
- private ParcelPropertiesUpdateRequest handlerParcelPropertiesUpdateRequest; //OnParcelPropertiesUpdateRequest;
- private ParcelSelectObjects handlerParcelSelectObjects; //OnParcelSelectObjects;
- private ParcelObjectOwnerRequest handlerParcelObjectOwnerRequest; //OnParcelObjectOwnerRequest;
- private ParcelAbandonRequest handlerParcelAbandonRequest;
- private ParcelGodForceOwner handlerParcelGodForceOwner;
- private ParcelReclaim handlerParcelReclaim;
- private RequestTerrain handlerRequestTerrain;
- private RequestTerrain handlerUploadTerrain;
- private ParcelReturnObjectsRequest handlerParcelReturnObjectsRequest;
- private RegionInfoRequest handlerRegionInfoRequest; //OnRegionInfoRequest;
- private EstateCovenantRequest handlerEstateCovenantRequest; //OnEstateCovenantRequest;
- private RequestGodlikePowers handlerReqGodlikePowers; //OnRequestGodlikePowers;
- private GodKickUser handlerGodKickUser; //OnGodKickUser;
- private ViewerEffectEventHandler handlerViewerEffect; //OnViewerEffect;
- private Action handlerLogout; //OnLogout;
- private MoneyTransferRequest handlerMoneyTransferRequest; //OnMoneyTransferRequest;
- private ParcelBuy handlerParcelBuy;
- private EconomyDataRequest handlerEconomoyDataRequest;
-
- private UpdateVector handlerUpdatePrimSinglePosition; //OnUpdatePrimSinglePosition;
- private UpdatePrimSingleRotation handlerUpdatePrimSingleRotation; //OnUpdatePrimSingleRotation;
- private UpdatePrimSingleRotationPosition handlerUpdatePrimSingleRotationPosition; //OnUpdatePrimSingleRotation;
- private UpdateVector handlerUpdatePrimScale; //OnUpdatePrimScale;
- private UpdateVector handlerUpdatePrimGroupScale; //OnUpdateGroupScale;
- private UpdateVector handlerUpdateVector; //OnUpdatePrimGroupPosition;
- private UpdatePrimRotation handlerUpdatePrimRotation; //OnUpdatePrimGroupRotation;
- // private UpdatePrimGroupRotation handlerUpdatePrimGroupRotation; //OnUpdatePrimGroupMouseRotation;
- // private RequestAsset handlerRequestAsset; // OnRequestAsset;
- private UUIDNameRequest handlerTeleportHomeRequest;
-
- private RegionHandleRequest handlerRegionHandleRequest; // OnRegionHandleRequest
- private ParcelInfoRequest handlerParcelInfoRequest; // OnParcelInfoRequest
-
- private ScriptAnswer handlerScriptAnswer;
- private RequestPayPrice handlerRequestPayPrice;
- private ObjectSaleInfo handlerObjectSaleInfo;
- private ObjectBuy handlerObjectBuy;
- //private BuyObjectInventory handlerBuyObjectInventory;
- private ObjectDeselect handlerObjectDetach;
- private ObjectDrop handlerObjectDrop;
- private AgentSit handlerOnUndo;
-
- private ForceReleaseControls handlerForceReleaseControls;
-
- private GodLandStatRequest handlerLandStatRequest;
-
- private UUIDNameRequest handlerUUIDGroupNameRequest;
-
- private ParcelDeedToGroup handlerParcelDeedToGroup;
-
- private RequestObjectPropertiesFamily handlerObjectGroupRequest;
- private ScriptReset handlerScriptReset;
- private GetScriptRunning handlerGetScriptRunning;
- private SetScriptRunning handlerSetScriptRunning;
- private UpdateVector handlerAutoPilotGo;
- //Gesture
- private ActivateGesture handlerActivateGesture;
- private DeactivateGesture handlerDeactivateGesture;
- //Sound
- private SoundTrigger handlerSoundTrigger;
- private ObjectOwner handlerObjectOwner;
-
- private DirPlacesQuery handlerDirPlacesQuery;
- private DirFindQuery handlerDirFindQuery;
- private DirLandQuery handlerDirLandQuery;
- private DirPopularQuery handlerDirPopularQuery;
- private DirClassifiedQuery handlerDirClassifiedQuery;
- private ParcelSetOtherCleanTime handlerParcelSetOtherCleanTime;
-
- private MapItemRequest handlerMapItemRequest;
-
- private StartLure handlerStartLure;
- private TeleportLureRequest handlerTeleportLureRequest;
-
- private NetworkStats handlerNetworkStatsUpdate;
-
- private ClassifiedInfoRequest handlerClassifiedInfoRequest;
- private ClassifiedInfoUpdate handlerClassifiedInfoUpdate;
- private ClassifiedDelete handlerClassifiedDelete;
- private ClassifiedDelete handlerClassifiedGodDelete;
-
- private EventNotificationAddRequest handlerEventNotificationAddRequest;
- private EventNotificationRemoveRequest handlerEventNotificationRemoveRequest;
- private EventGodDelete handlerEventGodDelete;
-
- private ParcelDwellRequest handlerParcelDwellRequest;
-
- private UserInfoRequest handlerUserInfoRequest;
- private UpdateUserInfo handlerUpdateUserInfo;
-
- private RetrieveInstantMessages handlerRetrieveInstantMessages;
-
- private PickDelete handlerPickDelete;
- private PickGodDelete handlerPickGodDelete;
- private PickInfoUpdate handlerPickInfoUpdate;
- private AvatarNotesUpdate handlerAvatarNotesUpdate;
-
- private MuteListRequest handlerMuteListRequest;
-
- //private AvatarInterestUpdate handlerAvatarInterestUpdate;
-
- private PlacesQuery handlerPlacesQuery;
-
- private readonly IGroupsModule m_GroupsModule;
-
- private AgentUpdateArgs lastarg = null;
-
- //private TerrainUnacked handlerUnackedTerrain = null;
-
- //**
-
- /* Properties */
-
- public UUID SecureSessionId
- {
- get { return m_secureSessionId; }
- }
-
- public IScene Scene
- {
- get { return m_scene; }
- }
-
- public UUID SessionId
- {
- get { return m_sessionId; }
- }
+ #region Properties
+ public UUID SecureSessionId { get { return m_secureSessionId; } }
+ public IScene Scene { get { return m_scene; } }
+ public UUID SessionId { get { return m_sessionId; } }
public Vector3 StartPos
{
get { return m_startpos; }
set { m_startpos = value; }
}
-
- public UUID AgentId
- {
- get { return m_agentId; }
- }
-
- public UUID ActiveGroupId
- {
- get { return m_activeGroupID; }
- }
-
- public string ActiveGroupName
- {
- get { return m_activeGroupName; }
- }
-
- public ulong ActiveGroupPowers
- {
- get { return m_activeGroupPowers; }
- }
-
- public bool IsGroupMember(UUID groupID)
- {
- return m_groupPowers.ContainsKey(groupID);
- }
-
- public ulong GetGroupPowers(UUID groupID)
- {
- if (groupID == m_activeGroupID)
- return m_activeGroupPowers;
-
- if (m_groupPowers.ContainsKey(groupID))
- return m_groupPowers[groupID];
-
- return 0;
- }
-
- ///
- /// This is a utility method used by single states to not duplicate kicks and blue card of death messages.
- ///
- public bool ChildAgentStatus()
- {
- return m_scene.PresenceChildStatus(AgentId);
- }
-
+ public UUID AgentId { get { return m_agentId; } }
+ public UUID ActiveGroupId { get { return m_activeGroupID; } }
+ public string ActiveGroupName { get { return m_activeGroupName; } }
+ public ulong ActiveGroupPowers { get { return m_activeGroupPowers; } }
+ public bool IsGroupMember(UUID groupID) { return m_groupPowers.ContainsKey(groupID); }
///
/// First name of the agent/avatar represented by the client
///
- public string FirstName
- {
- get { return m_firstName; }
- }
-
+ public string FirstName { get { return m_firstName; } }
///
/// Last name of the agent/avatar represented by the client
///
- public string LastName
- {
- get { return m_lastName; }
- }
-
+ public string LastName { get { return m_lastName; } }
///
/// Full name of the client (first name and last name)
///
- public string Name
- {
- get { return FirstName + " " + LastName; }
- }
-
- public uint CircuitCode
- {
- get { return m_circuitCode; }
- }
-
- public int MoneyBalance
- {
- get { return m_moneyBalance; }
- }
-
- public int NextAnimationSequenceNumber
- {
- get { return m_animationSequenceNumber++; }
- }
-
- public ILLPacketHandler PacketHandler
- {
- get { return m_PacketHandler; }
- }
-
- bool m_IsActive = true;
-
+ public string Name { get { return FirstName + " " + LastName; } }
+ public uint CircuitCode { get { return m_circuitCode; } }
+ public int MoneyBalance { get { return m_moneyBalance; } }
+ public int NextAnimationSequenceNumber { get { return m_animationSequenceNumber++; } }
public bool IsActive
{
get { return m_IsActive; }
set { m_IsActive = value; }
}
+ public bool SendLogoutPacketWhenClosing { set { m_SendLogoutPacketWhenClosing = value; } }
- public bool SendLogoutPacketWhenClosing
- {
- set { m_SendLogoutPacketWhenClosing = value; }
- }
-
- /* METHODS */
+ #endregion Properties
///
/// Constructor
///
- public LLClientView(
- EndPoint remoteEP, IScene scene, LLPacketServer packServer,
- AuthenticateResponse sessionInfo, UUID agentId, UUID sessionId, uint circuitCode, EndPoint proxyEP,
- ClientStackUserSettings userSettings)
+ public LLClientView(EndPoint remoteEP, IScene scene, LLUDPServer udpServer, LLUDPClient udpClient, AuthenticateResponse sessionInfo,
+ UUID agentId, UUID sessionId, uint circuitCode)
{
- // Should be called first?
- RegisterInterfaces();
-
+ RegisterInterface(this);
+ RegisterInterface(this);
+ RegisterInterface(this);
m_GroupsModule = scene.RequestModuleInterface();
+
m_moneyBalance = 1000;
m_channelVersion = Utils.StringToBytes(scene.GetSimulatorVersion());
@@ -505,14 +183,14 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_assetService = m_scene.RequestModuleInterface();
- m_networkServer = packServer;
+ m_udpServer = udpServer;
+ m_udpClient = udpClient;
m_agentId = agentId;
m_sessionId = sessionId;
m_circuitCode = circuitCode;
m_userEndPoint = remoteEP;
- m_proxyEndPoint = proxyEP;
m_firstName = sessionInfo.LoginInfo.First;
m_lastName = sessionInfo.LoginInfo.Last;
@@ -528,40 +206,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
// in it to process. It's an on-purpose threadlock though because
// without it, the clientloop will suck up all sim resources.
- m_PacketHandler = new LLPacketHandler(this, m_networkServer, userSettings);
- m_PacketHandler.SynchronizeClient = SynchronizeClient;
- m_PacketHandler.OnPacketStats += PopulateStats;
- m_PacketHandler.OnQueueEmpty += HandleQueueEmpty;
-
- if (scene.Config != null)
- {
- IConfig clientConfig = scene.Config.Configs["LLClient"];
- if (clientConfig != null)
- {
- m_PacketHandler.ReliableIsImportant =
- clientConfig.GetBoolean("ReliableIsImportant",
- false);
- m_PacketHandler.MaxReliableResends = clientConfig.GetInt("MaxReliableResends",
- m_PacketHandler.MaxReliableResends);
- m_primTerseUpdatesPerPacket = clientConfig.GetInt("TerseUpdatesPerPacket",
- m_primTerseUpdatesPerPacket);
- m_primFullUpdatesPerPacket = clientConfig.GetInt("FullUpdatesPerPacket",
- m_primFullUpdatesPerPacket);
-
- m_primTerseUpdateRate = clientConfig.GetInt("TerseUpdateRate",
- m_primTerseUpdateRate);
- m_primFullUpdateRate = clientConfig.GetInt("FullUpdateRate",
- m_primFullUpdateRate);
-
- m_textureSendLimit = clientConfig.GetInt("TextureSendLimit",
- m_textureSendLimit);
-
- m_textureDataLimit = clientConfig.GetInt("TextureDataLimit",
- m_textureDataLimit);
-
- m_packetMTU = clientConfig.GetInt("PacketMTU", 1400);
- }
- }
+ //m_PacketHandler = new LLPacketHandler(this, m_networkServer, userSettings);
+ //m_PacketHandler.SynchronizeClient = SynchronizeClient;
+ //m_PacketHandler.OnPacketStats += PopulateStats;
+ //m_PacketHandler.OnQueueEmpty += HandleQueueEmpty;
RegisterLocalPacketHandlers();
m_imageManager = new LLImageManager(this, m_assetService, Scene.RequestModuleInterface());
@@ -572,12 +220,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_debugPacketLevel = newDebugPacketLevel;
}
- # region Client Methods
+ #region Client Methods
private void CloseCleanup(bool shutdownCircuit)
{
-
-
m_scene.RemoveClient(AgentId);
//m_log.InfoFormat("[CLIENTVIEW] Memory pre GC {0}", System.GC.GetTotalMemory(false));
@@ -645,8 +291,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
if (m_imageManager != null)
m_imageManager.Close();
- if (m_PacketHandler != null)
- m_PacketHandler.Flush();
+ if (m_udpServer != null)
+ m_udpServer.Flush();
// raise an event on the packet server to Shutdown the circuit
// Now, if we raise the event then the packet server will call this method itself, so don't try cleanup
@@ -700,28 +346,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_primFullUpdateTimer.Stop();
}
- public void Restart()
- {
- // re-construct
- m_PacketHandler.Clear();
-
- m_clientPingTimer = new Timer(5000);
- m_clientPingTimer.Elapsed += CheckClientConnectivity;
- m_clientPingTimer.Enabled = true;
-
- m_avatarTerseUpdateTimer = new Timer(m_avatarTerseUpdateRate);
- m_avatarTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessAvatarTerseUpdates);
- m_avatarTerseUpdateTimer.AutoReset = false;
-
- m_primTerseUpdateTimer = new Timer(m_primTerseUpdateRate);
- m_primTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessPrimTerseUpdates);
- m_primTerseUpdateTimer.AutoReset = false;
-
- m_primFullUpdateTimer = new Timer(m_primFullUpdateRate);
- m_primFullUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessPrimFullUpdates);
- m_primFullUpdateTimer.AutoReset = false;
- }
-
private void Terminate()
{
IsActive = false;
@@ -730,9 +354,9 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_avatarTerseUpdateTimer.Close();
m_primTerseUpdateTimer.Close();
m_primFullUpdateTimer.Close();
-
- m_PacketHandler.OnPacketStats -= PopulateStats;
- m_PacketHandler.Dispose();
+
+ //m_udpServer.OnPacketStats -= PopulateStats;
+ m_udpClient.Shutdown();
// wait for thread stoped
// m_clientThread.Join();
@@ -741,13 +365,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP
//m_networkServer.CloseClient(this);
}
- #endregion
+ #endregion Client Methods
- # region Packet Handling
+ #region Packet Handling
public void PopulateStats(int inPackets, int outPackets, int unAckedBytes)
{
- handlerNetworkStatsUpdate = OnNetworkStatsUpdate;
+ NetworkStats handlerNetworkStatsUpdate = OnNetworkStatsUpdate;
if (handlerNetworkStatsUpdate != null)
{
handlerNetworkStatsUpdate(inPackets, outPackets, unAckedBytes);
@@ -856,86 +480,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
Console.WriteLine(m_circuitCode + ":" + direction + ": " + info);
}
- ///
- /// Main packet processing loop for the UDP component of the client session. Both incoming and outgoing
- /// packets are processed here.
- ///
- protected virtual void ClientLoop()
- {
- m_log.DebugFormat(
- "[CLIENT]: Entered main packet processing loop for {0} in {1}", Name, Scene.RegionInfo.RegionName);
-
- while (IsActive)
- {
- LLQueItem nextPacket = m_PacketHandler.PacketQueue.Dequeue();
-
- if (nextPacket == null) {
- m_log.DebugFormat("[CLIENT]: PacketQueue return null LLQueItem");
- continue;
- }
-
- if (nextPacket.Incoming)
- {
- if (m_debugPacketLevel > 0)
- DebugPacket("IN", nextPacket.Packet);
- m_PacketHandler.ProcessInPacket(nextPacket);
- }
- else
- {
- if (m_debugPacketLevel > 0)
- DebugPacket("OUT", nextPacket.Packet);
- m_PacketHandler.ProcessOutPacket(nextPacket);
- }
- }
- }
-
- # endregion
-
- protected int m_terrainCheckerCount;
-
- ///
- /// Event handler for check client timer
- /// Checks to ensure that the client is still connected. If the client has failed to respond to many pings
- /// in succession then close down the connection.
- ///
- ///
- ///
- protected void CheckClientConnectivity(object sender, ElapsedEventArgs e)
- {
- if (m_PacketHandler.PacketsReceived == m_inPacketsChecked)
- {
- // no packet came in since the last time we checked...
-
- m_probesWithNoIngressPackets++;
- if ((m_probesWithNoIngressPackets > 30 && !m_clientBlocked) // agent active
- || (m_probesWithNoIngressPackets > 90 && m_clientBlocked)) // agent paused
- {
- m_clientPingTimer.Enabled = false;
-
- m_log.WarnFormat(
- "[CLIENT]: Client for agent {0} {1} has stopped responding to pings. Closing connection",
- Name, AgentId);
-
- if (OnConnectionClosed != null)
- {
- OnConnectionClosed(this);
- }
- }
- else
- {
- // this will normally trigger at least one packet (ping response)
- SendStartPingCheck(0);
- }
- }
- else
- {
- // Something received in the meantime - we can reset the counters
- m_probesWithNoIngressPackets = 0;
- // ... and store the current number of packets received to find out if another one got in on the next cycle
- m_inPacketsChecked = m_PacketHandler.PacketsReceived;
- }
-
- }
+ #endregion Packet Handling
# region Setup
@@ -947,11 +492,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
{
//this.UploadAssets = new AgentAssetUpload(this, m_assetCache, m_inventoryCache);
- // Ping the client regularly to check that it's still there
- m_clientPingTimer = new Timer(5000);
- m_clientPingTimer.Elapsed += CheckClientConnectivity;
- m_clientPingTimer.Enabled = true;
-
m_avatarTerseUpdateTimer = new Timer(m_avatarTerseUpdateRate);
m_avatarTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessAvatarTerseUpdates);
m_avatarTerseUpdateTimer.AutoReset = false;
@@ -981,7 +521,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
///
/// Run a user session. This method lies at the base of the entire client thread.
///
- protected virtual void RunUserSession()
+ protected void RunUserSession()
{
//tell this thread we are using the culture set up for the sim (currently hardcoded to en_US)
//otherwise it will override this and use the system default
@@ -991,7 +531,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
{
// This sets up all the timers
InitNewClient();
- ClientLoop();
}
catch (Exception e)
{
@@ -1015,11 +554,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
+ "Any further actions taken will not be processed.\n"
+ "Please relog", true);
- LLQueItem item = new LLQueItem();
- item.Packet = packet;
- item.Sequence = packet.Header.Sequence;
-
- m_PacketHandler.ProcessOutPacket(item);
+ m_udpServer.SendPacket(m_agentId, packet, ThrottleOutPacketType.Unknown, false);
// There may be a better way to do this. Perhaps kick? Not sure this propogates notifications to
// listeners yet, though.
@@ -1037,7 +572,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
# endregion
- // Previously ClientView.API partial class
+ #region Events
+
public event GenericMessage OnGenericMessage;
public event BinaryGenericMessage OnBinaryGenericMessage;
public event Action OnLogout;
@@ -1197,13 +733,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public event GetScriptRunning OnGetScriptRunning;
public event SetScriptRunning OnSetScriptRunning;
public event UpdateVector OnAutoPilotGo;
-
public event TerrainUnacked OnUnackedTerrain;
-
public event ActivateGesture OnActivateGesture;
public event DeactivateGesture OnDeactivateGesture;
public event ObjectOwner OnObjectOwner;
-
public event DirPlacesQuery OnDirPlacesQuery;
public event DirFindQuery OnDirFindQuery;
public event DirLandQuery OnDirLandQuery;
@@ -1211,45 +744,35 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public event DirClassifiedQuery OnDirClassifiedQuery;
public event EventInfoRequest OnEventInfoRequest;
public event ParcelSetOtherCleanTime OnParcelSetOtherCleanTime;
-
public event MapItemRequest OnMapItemRequest;
-
public event OfferCallingCard OnOfferCallingCard;
public event AcceptCallingCard OnAcceptCallingCard;
public event DeclineCallingCard OnDeclineCallingCard;
public event SoundTrigger OnSoundTrigger;
-
public event StartLure OnStartLure;
public event TeleportLureRequest OnTeleportLureRequest;
public event NetworkStats OnNetworkStatsUpdate;
-
public event ClassifiedInfoRequest OnClassifiedInfoRequest;
public event ClassifiedInfoUpdate OnClassifiedInfoUpdate;
public event ClassifiedDelete OnClassifiedDelete;
public event ClassifiedDelete OnClassifiedGodDelete;
-
public event EventNotificationAddRequest OnEventNotificationAddRequest;
public event EventNotificationRemoveRequest OnEventNotificationRemoveRequest;
public event EventGodDelete OnEventGodDelete;
-
public event ParcelDwellRequest OnParcelDwellRequest;
-
public event UserInfoRequest OnUserInfoRequest;
public event UpdateUserInfo OnUpdateUserInfo;
-
public event RetrieveInstantMessages OnRetrieveInstantMessages;
-
public event PickDelete OnPickDelete;
public event PickGodDelete OnPickGodDelete;
public event PickInfoUpdate OnPickInfoUpdate;
public event AvatarNotesUpdate OnAvatarNotesUpdate;
-
public event MuteListRequest OnMuteListRequest;
-
- //public event AvatarInterestUpdate OnAvatarInterestUpdate;
-
+ public event AvatarInterestUpdate OnAvatarInterestUpdate;
public event PlacesQuery OnPlacesQuery;
+ #endregion Events
+
public void ActivateGesture(UUID assetId, UUID gestureId)
{
}
@@ -2768,7983 +2291,8017 @@ namespace OpenSim.Region.ClientStack.LindenUDP
OutPacket(avatarReply, ThrottleOutPacketType.Task);
}
- #endregion
-
- // Gesture
+ ///
+ /// Send the client an Estate message blue box pop-down with a single OK button
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void SendBlueBoxMessage(UUID FromAvatarID, String FromAvatarName, String Message)
+ {
+ if (!ChildAgentStatus())
+ SendInstantMessage(new GridInstantMessage(null, FromAvatarID, FromAvatarName, AgentId, 1, Message, false, new Vector3()));
- #region Appearance/ Wearables Methods
+ //SendInstantMessage(FromAvatarID, fromSessionID, Message, AgentId, SessionId, FromAvatarName, (byte)21,(uint) Util.UnixTimeSinceEpoch());
+ }
- public void SendWearables(AvatarWearable[] wearables, int serial)
+ public void SendLogoutPacket()
{
- AgentWearablesUpdatePacket aw = (AgentWearablesUpdatePacket)PacketPool.Instance.GetPacket(PacketType.AgentWearablesUpdate);
- aw.AgentData.AgentID = AgentId;
- aw.AgentData.SerialNum = (uint)serial;
- aw.AgentData.SessionID = m_sessionId;
+ // I know this is a bit of a hack, however there are times when you don't
+ // want to send this, but still need to do the rest of the shutdown process
+ // this method gets called from the packet server.. which makes it practically
+ // impossible to do any other way.
- // TODO: don't create new blocks if recycling an old packet
- aw.WearableData = new AgentWearablesUpdatePacket.WearableDataBlock[13];
- AgentWearablesUpdatePacket.WearableDataBlock awb;
- for (int i = 0; i < wearables.Length; i++)
+ if (m_SendLogoutPacketWhenClosing)
{
- awb = new AgentWearablesUpdatePacket.WearableDataBlock();
- awb.WearableType = (byte)i;
- awb.AssetID = wearables[i].AssetID;
- awb.ItemID = wearables[i].ItemID;
- aw.WearableData[i] = awb;
+ LogoutReplyPacket logReply = (LogoutReplyPacket)PacketPool.Instance.GetPacket(PacketType.LogoutReply);
+ // TODO: don't create new blocks if recycling an old packet
+ logReply.AgentData.AgentID = AgentId;
+ logReply.AgentData.SessionID = SessionId;
+ logReply.InventoryData = new LogoutReplyPacket.InventoryDataBlock[1];
+ logReply.InventoryData[0] = new LogoutReplyPacket.InventoryDataBlock();
+ logReply.InventoryData[0].ItemID = UUID.Zero;
-// m_log.DebugFormat(
-// "[APPEARANCE]: Sending wearable item/asset {0} {1} (index {2}) for {3}",
-// awb.ItemID, awb.AssetID, i, Name);
+ OutPacket(logReply, ThrottleOutPacketType.Task);
}
-
- OutPacket(aw, ThrottleOutPacketType.Task);
}
- public void SendAppearance(UUID agentID, byte[] visualParams, byte[] textureEntry)
+ public void SendHealth(float health)
{
- AvatarAppearancePacket avp = (AvatarAppearancePacket)PacketPool.Instance.GetPacket(PacketType.AvatarAppearance);
- // TODO: don't create new blocks if recycling an old packet
- avp.VisualParam = new AvatarAppearancePacket.VisualParamBlock[218];
- avp.ObjectData.TextureEntry = textureEntry;
+ HealthMessagePacket healthpacket = (HealthMessagePacket)PacketPool.Instance.GetPacket(PacketType.HealthMessage);
+ healthpacket.HealthData.Health = health;
+ OutPacket(healthpacket, ThrottleOutPacketType.Task);
+ }
- AvatarAppearancePacket.VisualParamBlock avblock = null;
- for (int i = 0; i < visualParams.Length; i++)
+ public void SendAgentOnline(UUID[] agentIDs)
+ {
+ OnlineNotificationPacket onp = new OnlineNotificationPacket();
+ OnlineNotificationPacket.AgentBlockBlock[] onpb = new OnlineNotificationPacket.AgentBlockBlock[agentIDs.Length];
+ for (int i = 0; i < agentIDs.Length; i++)
{
- avblock = new AvatarAppearancePacket.VisualParamBlock();
- avblock.ParamValue = visualParams[i];
- avp.VisualParam[i] = avblock;
+ OnlineNotificationPacket.AgentBlockBlock onpbl = new OnlineNotificationPacket.AgentBlockBlock();
+ onpbl.AgentID = agentIDs[i];
+ onpb[i] = onpbl;
}
-
- avp.Sender.IsTrial = false;
- avp.Sender.ID = agentID;
- OutPacket(avp, ThrottleOutPacketType.Task);
+ onp.AgentBlock = onpb;
+ onp.Header.Reliable = true;
+ OutPacket(onp, ThrottleOutPacketType.Task);
}
- public void SendAnimations(UUID[] animations, int[] seqs, UUID sourceAgentId, UUID[] objectIDs)
+ public void SendAgentOffline(UUID[] agentIDs)
{
- //m_log.DebugFormat("[CLIENT]: Sending animations to {0}", Name);
-
- AvatarAnimationPacket ani = (AvatarAnimationPacket)PacketPool.Instance.GetPacket(PacketType.AvatarAnimation);
- // TODO: don't create new blocks if recycling an old packet
- ani.AnimationSourceList = new AvatarAnimationPacket.AnimationSourceListBlock[animations.Length];
- ani.Sender = new AvatarAnimationPacket.SenderBlock();
- ani.Sender.ID = sourceAgentId;
- ani.AnimationList = new AvatarAnimationPacket.AnimationListBlock[animations.Length];
- ani.PhysicalAvatarEventList = new AvatarAnimationPacket.PhysicalAvatarEventListBlock[0];
-
- for (int i = 0; i < animations.Length; ++i)
+ OfflineNotificationPacket offp = new OfflineNotificationPacket();
+ OfflineNotificationPacket.AgentBlockBlock[] offpb = new OfflineNotificationPacket.AgentBlockBlock[agentIDs.Length];
+ for (int i = 0; i < agentIDs.Length; i++)
{
- ani.AnimationList[i] = new AvatarAnimationPacket.AnimationListBlock();
- ani.AnimationList[i].AnimID = animations[i];
- ani.AnimationList[i].AnimSequenceID = seqs[i];
-
- ani.AnimationSourceList[i] = new AvatarAnimationPacket.AnimationSourceListBlock();
- ani.AnimationSourceList[i].ObjectID = objectIDs[i];
- if (objectIDs[i] == UUID.Zero)
- ani.AnimationSourceList[i].ObjectID = sourceAgentId;
+ OfflineNotificationPacket.AgentBlockBlock onpbl = new OfflineNotificationPacket.AgentBlockBlock();
+ onpbl.AgentID = agentIDs[i];
+ offpb[i] = onpbl;
}
- ani.Header.Reliable = false;
- OutPacket(ani, ThrottleOutPacketType.Task);
+ offp.AgentBlock = offpb;
+ offp.Header.Reliable = true;
+ OutPacket(offp, ThrottleOutPacketType.Task);
}
- #endregion
-
- #region Avatar Packet/data sending Methods
-
- ///
- /// send a objectupdate packet with information about the clients avatar
- ///
- 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 SendSitResponse(UUID TargetID, Vector3 OffsetPos, Quaternion SitOrientation, bool autopilot,
+ Vector3 CameraAtOffset, Vector3 CameraEyeOffset, bool ForceMouseLook)
{
- ObjectUpdatePacket objupdate = (ObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdate);
- // TODO: don't create new blocks if recycling an old packet
- objupdate.RegionData.RegionHandle = regionHandle;
- objupdate.RegionData.TimeDilation = ushort.MaxValue;
- objupdate.ObjectData = new ObjectUpdatePacket.ObjectDataBlock[1];
- objupdate.ObjectData[0] = CreateDefaultAvatarPacket(textureEntry);
-
- //give this avatar object a local id and assign the user a name
- objupdate.ObjectData[0].ID = avatarLocalID;
- objupdate.ObjectData[0].FullID = avatarID;
- objupdate.ObjectData[0].ParentID = parentID;
- objupdate.ObjectData[0].NameValue =
- Utils.StringToBytes("FirstName STRING RW SV " + firstName + "\nLastName STRING RW SV " + lastName + "\nTitle STRING RW SV " + grouptitle);
-
- Vector3 pos2 = new Vector3(Pos.X, Pos.Y, Pos.Z);
- byte[] pb = pos2.GetBytes();
- Array.Copy(pb, 0, objupdate.ObjectData[0].ObjectData, 16, pb.Length);
-
- byte[] rot = rotation.GetBytes();
- Array.Copy(rot, 0, objupdate.ObjectData[0].ObjectData, 52, rot.Length);
+ AvatarSitResponsePacket avatarSitResponse = new AvatarSitResponsePacket();
+ avatarSitResponse.SitObject.ID = TargetID;
+ if (CameraAtOffset != Vector3.Zero)
+ {
+ avatarSitResponse.SitTransform.CameraAtOffset = CameraAtOffset;
+ avatarSitResponse.SitTransform.CameraEyeOffset = CameraEyeOffset;
+ }
+ avatarSitResponse.SitTransform.ForceMouselook = ForceMouseLook;
+ avatarSitResponse.SitTransform.AutoPilot = autopilot;
+ avatarSitResponse.SitTransform.SitPosition = OffsetPos;
+ avatarSitResponse.SitTransform.SitRotation = SitOrientation;
- objupdate.Header.Zerocoded = true;
- OutPacket(objupdate, ThrottleOutPacketType.Task);
+ OutPacket(avatarSitResponse, ThrottleOutPacketType.Task);
}
- ///
- /// Send a terse positional/rotation/velocity update about an avatar
- /// to the client. This avatar can be that of the client itself.
- ///
- public virtual void SendAvatarTerseUpdate(ulong regionHandle,
- ushort timeDilation, uint localID, Vector3 position,
- Vector3 velocity, Quaternion rotation, UUID agentid)
+ public void SendAdminResponse(UUID Token, uint AdminLevel)
{
- if (rotation.X == rotation.Y &&
- rotation.Y == rotation.Z &&
- rotation.Z == rotation.W && rotation.W == 0)
- rotation = Quaternion.Identity;
-
- ImprovedTerseObjectUpdatePacket.ObjectDataBlock terseBlock =
- CreateAvatarImprovedBlock(localID, position, velocity,rotation);
-
- lock (m_avatarTerseUpdates)
- {
- m_avatarTerseUpdates.Add(terseBlock);
+ GrantGodlikePowersPacket respondPacket = new GrantGodlikePowersPacket();
+ GrantGodlikePowersPacket.GrantDataBlock gdb = new GrantGodlikePowersPacket.GrantDataBlock();
+ GrantGodlikePowersPacket.AgentDataBlock adb = new GrantGodlikePowersPacket.AgentDataBlock();
- // If packet is full or own movement packet, send it.
- if (m_avatarTerseUpdates.Count >= m_avatarTerseUpdatesPerPacket)
- {
- ProcessAvatarTerseUpdates(this, null);
- }
- else if (m_avatarTerseUpdates.Count == 1)
- {
- lock (m_avatarTerseUpdateTimer)
- m_avatarTerseUpdateTimer.Start();
- }
- }
+ adb.AgentID = AgentId;
+ adb.SessionID = SessionId; // More security
+ gdb.GodLevel = (byte)AdminLevel;
+ gdb.Token = Token;
+ //respondPacket.AgentData = (GrantGodlikePowersPacket.AgentDataBlock)ablock;
+ respondPacket.GrantData = gdb;
+ respondPacket.AgentData = adb;
+ OutPacket(respondPacket, ThrottleOutPacketType.Task);
}
- private void ProcessAvatarTerseUpdates(object sender, ElapsedEventArgs e)
+ public void SendGroupMembership(GroupMembershipData[] GroupMembership)
{
- lock (m_avatarTerseUpdates)
- {
- ImprovedTerseObjectUpdatePacket terse = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ImprovedTerseObjectUpdate);
-
- terse.RegionData = new ImprovedTerseObjectUpdatePacket.RegionDataBlock();
-
- terse.RegionData.RegionHandle = Scene.RegionInfo.RegionHandle;
- terse.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
-
- int max = m_avatarTerseUpdatesPerPacket;
- if (max > m_avatarTerseUpdates.Count)
- max = m_avatarTerseUpdates.Count;
-
- int count = 0;
- int size = 0;
-
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ m_groupPowers.Clear();
- for (count = 0 ; count < max ; count++)
- {
- int length = 0;
- m_avatarTerseUpdates[count].ToBytes(blockbuffer, ref length);
- length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
- if (size + length > m_packetMTU)
- break;
- size += length;
- }
+ AgentGroupDataUpdatePacket Groupupdate = new AgentGroupDataUpdatePacket();
+ AgentGroupDataUpdatePacket.GroupDataBlock[] Groups = new AgentGroupDataUpdatePacket.GroupDataBlock[GroupMembership.Length];
+ for (int i = 0; i < GroupMembership.Length; i++)
+ {
+ m_groupPowers[GroupMembership[i].GroupID] = GroupMembership[i].GroupPowers;
- terse.ObjectData = new ImprovedTerseObjectUpdatePacket.ObjectDataBlock[count];
+ AgentGroupDataUpdatePacket.GroupDataBlock Group = new AgentGroupDataUpdatePacket.GroupDataBlock();
+ Group.AcceptNotices = GroupMembership[i].AcceptNotices;
+ Group.Contribution = GroupMembership[i].Contribution;
+ Group.GroupID = GroupMembership[i].GroupID;
+ Group.GroupInsigniaID = GroupMembership[i].GroupPicture;
+ Group.GroupName = Utils.StringToBytes(GroupMembership[i].GroupName);
+ Group.GroupPowers = GroupMembership[i].GroupPowers;
+ Groups[i] = Group;
- for (int i = 0 ; i < count ; i++)
- {
- terse.ObjectData[i] = m_avatarTerseUpdates[0];
- m_avatarTerseUpdates.RemoveAt(0);
- }
- terse.Header.Reliable = false;
- terse.Header.Zerocoded = true;
- OutPacket(terse, ThrottleOutPacketType.Task);
+ }
+ Groupupdate.GroupData = Groups;
+ Groupupdate.AgentData = new AgentGroupDataUpdatePacket.AgentDataBlock();
+ Groupupdate.AgentData.AgentID = AgentId;
+ OutPacket(Groupupdate, ThrottleOutPacketType.Task);
- if (m_avatarTerseUpdates.Count == 0)
+ try
+ {
+ IEventQueue eq = Scene.RequestModuleInterface();
+ if (eq != null)
{
- lock (m_avatarTerseUpdateTimer)
- m_avatarTerseUpdateTimer.Stop();
+ eq.GroupMembership(Groupupdate, this.AgentId);
}
}
- }
-
- public void SendCoarseLocationUpdate(List users, List CoarseLocations)
- {
- if (!IsActive) return; // We don't need to update inactive clients.
-
- CoarseLocationUpdatePacket loc = (CoarseLocationUpdatePacket)PacketPool.Instance.GetPacket(PacketType.CoarseLocationUpdate);
- // TODO: don't create new blocks if recycling an old packet
- int total = CoarseLocations.Count;
- CoarseLocationUpdatePacket.IndexBlock ib =
- new CoarseLocationUpdatePacket.IndexBlock();
- loc.Location = new CoarseLocationUpdatePacket.LocationBlock[total];
- loc.AgentData = new CoarseLocationUpdatePacket.AgentDataBlock[total];
-
- for (int i = 0; i < total; i++)
+ catch (Exception ex)
{
- CoarseLocationUpdatePacket.LocationBlock lb =
- new CoarseLocationUpdatePacket.LocationBlock();
- lb.X = (byte)CoarseLocations[i].X;
- lb.Y = (byte)CoarseLocations[i].Y;
-
- lb.Z = CoarseLocations[i].Z > 1024 ? (byte)0 : (byte)(CoarseLocations[i].Z * 0.25);
- loc.Location[i] = lb;
- loc.AgentData[i] = new CoarseLocationUpdatePacket.AgentDataBlock();
- loc.AgentData[i].AgentID = users[i];
+ m_log.Error("Unable to send group membership data via eventqueue - exception: " + ex.ToString());
+ m_log.Warn("sending group membership data via UDP");
+ OutPacket(Groupupdate, ThrottleOutPacketType.Task);
}
- ib.You = -1;
- ib.Prey = -1;
- loc.Index = ib;
- loc.Header.Reliable = false;
- loc.Header.Zerocoded = true;
-
- OutPacket(loc, ThrottleOutPacketType.Task);
}
- #endregion
- #region Primitive Packet/data Sending Methods
-
- ///
- ///
- ///
- ///
- ///
- ///
- public void AttachObject(uint localID, Quaternion rotation, byte attachPoint, UUID ownerID)
+ public void SendGroupNameReply(UUID groupLLUID, string GroupName)
{
- if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
- return;
-
- ObjectAttachPacket attach = (ObjectAttachPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAttach);
- // TODO: don't create new blocks if recycling an old packet
- attach.AgentData.AgentID = AgentId;
- attach.AgentData.SessionID = m_sessionId;
- attach.AgentData.AttachmentPoint = attachPoint;
- attach.ObjectData = new ObjectAttachPacket.ObjectDataBlock[1];
- attach.ObjectData[0] = new ObjectAttachPacket.ObjectDataBlock();
- attach.ObjectData[0].ObjectLocalID = localID;
- attach.ObjectData[0].Rotation = rotation;
- attach.Header.Zerocoded = true;
- OutPacket(attach, ThrottleOutPacketType.Task);
+ UUIDGroupNameReplyPacket pack = new UUIDGroupNameReplyPacket();
+ UUIDGroupNameReplyPacket.UUIDNameBlockBlock[] uidnameblock = new UUIDGroupNameReplyPacket.UUIDNameBlockBlock[1];
+ UUIDGroupNameReplyPacket.UUIDNameBlockBlock uidnamebloc = new UUIDGroupNameReplyPacket.UUIDNameBlockBlock();
+ uidnamebloc.ID = groupLLUID;
+ uidnamebloc.GroupName = Utils.StringToBytes(GroupName);
+ uidnameblock[0] = uidnamebloc;
+ pack.UUIDNameBlock = uidnameblock;
+ OutPacket(pack, ThrottleOutPacketType.Task);
}
- public void SendPrimitiveToClient(
- ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
- Vector3 pos, Vector3 vel, Vector3 acc, Quaternion rotation, Vector3 rvel,
- uint flags, UUID objectID, UUID ownerID, string text, byte[] color,
- uint parentID, byte[] particleSystem, byte clickAction, byte material)
+ public void SendLandStatReply(uint reportType, uint requestFlags, uint resultCount, LandStatReportItem[] lsrpia)
{
- byte[] textureanim = new byte[0];
-
- SendPrimitiveToClient(regionHandle, timeDilation, localID, primShape, pos, vel,
- acc, rotation, rvel, flags,
- objectID, ownerID, text, color, parentID, particleSystem,
- clickAction, material, textureanim, false, 0, UUID.Zero, UUID.Zero, 0, 0, 0);
+ LandStatReplyPacket lsrp = new LandStatReplyPacket();
+ // LandStatReplyPacket.RequestDataBlock lsreqdpb = new LandStatReplyPacket.RequestDataBlock();
+ LandStatReplyPacket.ReportDataBlock[] lsrepdba = new LandStatReplyPacket.ReportDataBlock[lsrpia.Length];
+ //LandStatReplyPacket.ReportDataBlock lsrepdb = new LandStatReplyPacket.ReportDataBlock();
+ // lsrepdb.
+ lsrp.RequestData.ReportType = reportType;
+ lsrp.RequestData.RequestFlags = requestFlags;
+ lsrp.RequestData.TotalObjectCount = resultCount;
+ for (int i = 0; i < lsrpia.Length; i++)
+ {
+ LandStatReplyPacket.ReportDataBlock lsrepdb = new LandStatReplyPacket.ReportDataBlock();
+ lsrepdb.LocationX = lsrpia[i].LocationX;
+ lsrepdb.LocationY = lsrpia[i].LocationY;
+ lsrepdb.LocationZ = lsrpia[i].LocationZ;
+ lsrepdb.Score = lsrpia[i].Score;
+ lsrepdb.TaskID = lsrpia[i].TaskID;
+ lsrepdb.TaskLocalID = lsrpia[i].TaskLocalID;
+ lsrepdb.TaskName = Utils.StringToBytes(lsrpia[i].TaskName);
+ lsrepdb.OwnerName = Utils.StringToBytes(lsrpia[i].OwnerName);
+ lsrepdba[i] = lsrepdb;
+ }
+ lsrp.ReportData = lsrepdba;
+ OutPacket(lsrp, ThrottleOutPacketType.Task);
}
- public void SendPrimitiveToClient(
- ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
- Vector3 pos, Vector3 velocity, Vector3 acceleration, Quaternion rotation, Vector3 rotational_velocity,
- uint flags,
- UUID objectID, UUID ownerID, string text, byte[] color, uint parentID, byte[] particleSystem,
- byte clickAction, byte material, byte[] textureanim, bool attachment, uint AttachPoint, UUID AssetId, UUID SoundId, double SoundGain, byte SoundFlags, double SoundRadius)
+ public void SendScriptRunningReply(UUID objectID, UUID itemID, bool running)
{
+ ScriptRunningReplyPacket scriptRunningReply = new ScriptRunningReplyPacket();
+ scriptRunningReply.Script.ObjectID = objectID;
+ scriptRunningReply.Script.ItemID = itemID;
+ scriptRunningReply.Script.Running = running;
- if (AttachPoint > 30 && ownerID != AgentId) // Someone else's HUD
- return;
- if (primShape.PCode == 9 && primShape.State != 0 && parentID == 0)
- return;
-
- if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
- rotation = Quaternion.Identity;
-
- ObjectUpdatePacket.ObjectDataBlock objectData = CreatePrimUpdateBlock(primShape, flags);
-
- objectData.ID = localID;
- objectData.FullID = objectID;
- objectData.OwnerID = ownerID;
-
- objectData.Text = LLUtil.StringToPacketBytes(text);
- objectData.TextColor[0] = color[0];
- objectData.TextColor[1] = color[1];
- objectData.TextColor[2] = color[2];
- objectData.TextColor[3] = color[3];
- objectData.ParentID = parentID;
- objectData.PSBlock = particleSystem;
- objectData.ClickAction = clickAction;
- objectData.Material = material;
- objectData.Flags = 0;
+ OutPacket(scriptRunningReply, ThrottleOutPacketType.Task);
+ }
- if (attachment)
+ public void SendAsset(AssetRequestToClient req)
+ {
+ //m_log.Debug("sending asset " + req.RequestAssetID);
+ TransferInfoPacket Transfer = new TransferInfoPacket();
+ Transfer.TransferInfo.ChannelType = 2;
+ Transfer.TransferInfo.Status = 0;
+ Transfer.TransferInfo.TargetType = 0;
+ if (req.AssetRequestSource == 2)
{
- // Necessary???
- objectData.JointAxisOrAnchor = new Vector3(0, 0, 2);
- objectData.JointPivot = new Vector3(0, 0, 0);
-
- // Item from inventory???
- objectData.NameValue =
- Utils.StringToBytes("AttachItemID STRING RW SV " + AssetId.Guid);
- objectData.State = (byte)((AttachPoint % 16) * 16 + (AttachPoint / 16));
+ Transfer.TransferInfo.Params = new byte[20];
+ Array.Copy(req.RequestAssetID.GetBytes(), 0, Transfer.TransferInfo.Params, 0, 16);
+ int assType = req.AssetInf.Type;
+ Array.Copy(Utils.IntToBytes(assType), 0, Transfer.TransferInfo.Params, 16, 4);
+ }
+ else if (req.AssetRequestSource == 3)
+ {
+ Transfer.TransferInfo.Params = req.Params;
+ // Transfer.TransferInfo.Params = new byte[100];
+ //Array.Copy(req.RequestUser.AgentId.GetBytes(), 0, Transfer.TransferInfo.Params, 0, 16);
+ //Array.Copy(req.RequestUser.SessionId.GetBytes(), 0, Transfer.TransferInfo.Params, 16, 16);
}
+ Transfer.TransferInfo.Size = req.AssetInf.Data.Length;
+ Transfer.TransferInfo.TransferID = req.TransferRequestID;
+ Transfer.Header.Zerocoded = true;
+ OutPacket(Transfer, ThrottleOutPacketType.Asset);
- // Xantor 20080528: Send sound info as well
- // Xantor 20080530: Zero out everything if there's no SoundId, so zerocompression will work again
- objectData.Sound = SoundId;
- if (SoundId == UUID.Zero)
+ if (req.NumPackets == 1)
{
- objectData.OwnerID = UUID.Zero;
- objectData.Gain = 0.0f;
- objectData.Radius = 0.0f;
- objectData.Flags = 0;
+ TransferPacketPacket TransferPacket = new TransferPacketPacket();
+ TransferPacket.TransferData.Packet = 0;
+ TransferPacket.TransferData.ChannelType = 2;
+ TransferPacket.TransferData.TransferID = req.TransferRequestID;
+ TransferPacket.TransferData.Data = req.AssetInf.Data;
+ TransferPacket.TransferData.Status = 1;
+ TransferPacket.Header.Zerocoded = true;
+ OutPacket(TransferPacket, ThrottleOutPacketType.Asset);
}
else
{
- objectData.OwnerID = ownerID;
- objectData.Gain = (float)SoundGain;
- objectData.Radius = (float)SoundRadius;
- objectData.Flags = SoundFlags;
- }
+ int processedLength = 0;
+ int maxChunkSize = Settings.MAX_PACKET_SIZE - 100;
+ int packetNumber = 0;
- byte[] pb = pos.GetBytes();
- Array.Copy(pb, 0, objectData.ObjectData, 0, pb.Length);
+ while (processedLength < req.AssetInf.Data.Length)
+ {
+ TransferPacketPacket TransferPacket = new TransferPacketPacket();
+ TransferPacket.TransferData.Packet = packetNumber;
+ TransferPacket.TransferData.ChannelType = 2;
+ TransferPacket.TransferData.TransferID = req.TransferRequestID;
- byte[] vel = velocity.GetBytes();
- Array.Copy(vel, 0, objectData.ObjectData, pb.Length, vel.Length);
+ int chunkSize = Math.Min(req.AssetInf.Data.Length - processedLength, maxChunkSize);
+ byte[] chunk = new byte[chunkSize];
+ Array.Copy(req.AssetInf.Data, processedLength, chunk, 0, chunk.Length);
- byte[] rot = rotation.GetBytes();
- Array.Copy(rot, 0, objectData.ObjectData, 36, rot.Length);
+ TransferPacket.TransferData.Data = chunk;
- byte[] rvel = rotational_velocity.GetBytes();
- Array.Copy(rvel, 0, objectData.ObjectData, 36 + rot.Length, rvel.Length);
+ // 0 indicates more packets to come, 1 indicates last packet
+ if (req.AssetInf.Data.Length - processedLength > maxChunkSize)
+ {
+ TransferPacket.TransferData.Status = 0;
+ }
+ else
+ {
+ TransferPacket.TransferData.Status = 1;
+ }
+ TransferPacket.Header.Zerocoded = true;
+ OutPacket(TransferPacket, ThrottleOutPacketType.Asset);
- if (textureanim.Length > 0)
- {
- objectData.TextureAnim = textureanim;
+ processedLength += chunkSize;
+ packetNumber++;
+ }
}
+ }
- lock (m_primFullUpdates)
- {
- if (m_primFullUpdates.Count == 0)
- m_primFullUpdateTimer.Start();
+ public void SendTexture(AssetBase TextureAsset)
+ {
- m_primFullUpdates.Add(objectData);
+ }
- if (m_primFullUpdates.Count >= m_primFullUpdatesPerPacket)
- ProcessPrimFullUpdates(this, null);
- }
+ public void SendRegionHandle(UUID regionID, ulong handle)
+ {
+ RegionIDAndHandleReplyPacket reply = (RegionIDAndHandleReplyPacket)PacketPool.Instance.GetPacket(PacketType.RegionIDAndHandleReply);
+ reply.ReplyBlock.RegionID = regionID;
+ reply.ReplyBlock.RegionHandle = handle;
+ OutPacket(reply, ThrottleOutPacketType.Land);
}
- void HandleQueueEmpty(ThrottleOutPacketType queue)
+ public void SendParcelInfo(RegionInfo info, LandData land, UUID parcelID, uint x, uint y)
{
- switch (queue)
+ ParcelInfoReplyPacket reply = (ParcelInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelInfoReply);
+ reply.AgentData.AgentID = m_agentId;
+ reply.Data.ParcelID = parcelID;
+ reply.Data.OwnerID = land.OwnerID;
+ reply.Data.Name = Utils.StringToBytes(land.Name);
+ reply.Data.Desc = Utils.StringToBytes(land.Description);
+ reply.Data.ActualArea = land.Area;
+ reply.Data.BillableArea = land.Area; // TODO: what is this?
+
+ // Bit 0: Mature, bit 7: on sale, other bits: no idea
+ reply.Data.Flags = (byte)(
+ ((land.Flags & (uint)ParcelFlags.MaturePublish) != 0 ? (1 << 0) : 0) +
+ ((land.Flags & (uint)ParcelFlags.ForSale) != 0 ? (1 << 7) : 0));
+
+ Vector3 pos = land.UserLocation;
+ if (pos.Equals(Vector3.Zero))
{
- case ThrottleOutPacketType.Texture:
- ProcessTextureRequests();
- break;
+ pos = (land.AABBMax + land.AABBMin) * 0.5f;
}
- }
+ reply.Data.GlobalX = info.RegionLocX * Constants.RegionSize + x;
+ reply.Data.GlobalY = info.RegionLocY * Constants.RegionSize + y;
+ reply.Data.GlobalZ = pos.Z;
+ reply.Data.SimName = Utils.StringToBytes(info.RegionName);
+ reply.Data.SnapshotID = land.SnapshotID;
+ reply.Data.Dwell = land.Dwell;
+ reply.Data.SalePrice = land.SalePrice;
+ reply.Data.AuctionID = (int)land.AuctionID;
- void ProcessTextureRequests()
- {
- if (m_imageManager != null)
- m_imageManager.ProcessImageQueue(m_textureSendLimit, m_textureDataLimit);
+ OutPacket(reply, ThrottleOutPacketType.Land);
}
- void ProcessPrimFullUpdates(object sender, ElapsedEventArgs e)
+ public void SendScriptTeleportRequest(string objName, string simName, Vector3 pos, Vector3 lookAt)
{
- lock (m_primFullUpdates)
- {
- if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
- {
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
-
- return;
- }
+ ScriptTeleportRequestPacket packet = (ScriptTeleportRequestPacket)PacketPool.Instance.GetPacket(PacketType.ScriptTeleportRequest);
- ObjectUpdatePacket outPacket =
- (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
- PacketType.ObjectUpdate);
+ packet.Data.ObjectName = Utils.StringToBytes(objName);
+ packet.Data.SimName = Utils.StringToBytes(simName);
+ packet.Data.SimPosition = pos;
+ packet.Data.LookAt = lookAt;
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
+ OutPacket(packet, ThrottleOutPacketType.Task);
+ }
- int max = m_primFullUpdates.Count;
- if (max > m_primFullUpdatesPerPacket)
- max = m_primFullUpdatesPerPacket;
+ public void SendDirPlacesReply(UUID queryID, DirPlacesReplyData[] data)
+ {
+ DirPlacesReplyPacket packet = (DirPlacesReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPlacesReply);
- int count = 0;
- int size = 0;
+ packet.AgentData = new DirPlacesReplyPacket.AgentDataBlock();
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ packet.QueryData = new DirPlacesReplyPacket.QueryDataBlock[1];
+ packet.QueryData[0] = new DirPlacesReplyPacket.QueryDataBlock();
- for (count = 0 ; count < max ; count++)
- {
- int length = 0;
- m_primFullUpdates[count].ToBytes(blockbuffer, ref length);
- length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
- if (size + length > m_packetMTU)
- break;
- size += length;
- }
+ packet.QueryReplies =
+ new DirPlacesReplyPacket.QueryRepliesBlock[data.Length];
- outPacket.ObjectData =
- new ObjectUpdatePacket.ObjectDataBlock[count];
+ packet.StatusData = new DirPlacesReplyPacket.StatusDataBlock[
+ data.Length];
- for (int index = 0 ; index < count ; index++)
- {
- outPacket.ObjectData[index] = m_primFullUpdates[0];
- m_primFullUpdates.RemoveAt(0);
- }
+ packet.AgentData.AgentID = AgentId;
- outPacket.Header.Zerocoded = true;
- OutPacket(outPacket, ThrottleOutPacketType.Task | ThrottleOutPacketType.LowPriority);
+ packet.QueryData[0].QueryID = queryID;
- if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
+ int i = 0;
+ foreach (DirPlacesReplyData d in data)
+ {
+ packet.QueryReplies[i] =
+ new DirPlacesReplyPacket.QueryRepliesBlock();
+ packet.StatusData[i] = new DirPlacesReplyPacket.StatusDataBlock();
+ packet.QueryReplies[i].ParcelID = d.parcelID;
+ packet.QueryReplies[i].Name = Utils.StringToBytes(d.name);
+ packet.QueryReplies[i].ForSale = d.forSale;
+ packet.QueryReplies[i].Auction = d.auction;
+ packet.QueryReplies[i].Dwell = d.dwell;
+ packet.StatusData[i].Status = d.Status;
+ i++;
}
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- ///
- ///
- ///
- public void SendPrimTerseUpdate(ulong regionHandle, ushort timeDilation, uint localID, Vector3 position,
- Quaternion rotation, Vector3 velocity, Vector3 rotationalvelocity, byte state, UUID AssetId, UUID ownerID, int attachPoint)
+ public void SendDirPeopleReply(UUID queryID, DirPeopleReplyData[] data)
{
- if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
- return;
-
- if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
- rotation = Quaternion.Identity;
+ DirPeopleReplyPacket packet = (DirPeopleReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPeopleReply);
- ImprovedTerseObjectUpdatePacket.ObjectDataBlock objectData =
- CreatePrimImprovedBlock(localID, position, rotation,
- velocity, rotationalvelocity, state);
+ packet.AgentData = new DirPeopleReplyPacket.AgentDataBlock();
+ packet.AgentData.AgentID = AgentId;
- lock (m_primTerseUpdates)
- {
- if (m_primTerseUpdates.Count == 0)
- m_primTerseUpdateTimer.Start();
+ packet.QueryData = new DirPeopleReplyPacket.QueryDataBlock();
+ packet.QueryData.QueryID = queryID;
- m_primTerseUpdates.Add(objectData);
+ packet.QueryReplies = new DirPeopleReplyPacket.QueryRepliesBlock[
+ data.Length];
- if (m_primTerseUpdates.Count >= m_primTerseUpdatesPerPacket)
- ProcessPrimTerseUpdates(this, null);
+ int i = 0;
+ foreach (DirPeopleReplyData d in data)
+ {
+ packet.QueryReplies[i] = new DirPeopleReplyPacket.QueryRepliesBlock();
+ packet.QueryReplies[i].AgentID = d.agentID;
+ packet.QueryReplies[i].FirstName =
+ Utils.StringToBytes(d.firstName);
+ packet.QueryReplies[i].LastName =
+ Utils.StringToBytes(d.lastName);
+ packet.QueryReplies[i].Group =
+ Utils.StringToBytes(d.group);
+ packet.QueryReplies[i].Online = d.online;
+ packet.QueryReplies[i].Reputation = d.reputation;
+ i++;
}
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- void ProcessPrimTerseUpdates(object sender, ElapsedEventArgs e)
+ public void SendDirEventsReply(UUID queryID, DirEventsReplyData[] data)
{
- lock (m_primTerseUpdates)
- {
- if (m_primTerseUpdates.Count == 0)
- {
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
+ DirEventsReplyPacket packet = (DirEventsReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirEventsReply);
- return;
- }
+ packet.AgentData = new DirEventsReplyPacket.AgentDataBlock();
+ packet.AgentData.AgentID = AgentId;
- ImprovedTerseObjectUpdatePacket outPacket =
- (ImprovedTerseObjectUpdatePacket)
- PacketPool.Instance.GetPacket(
- PacketType.ImprovedTerseObjectUpdate);
+ packet.QueryData = new DirEventsReplyPacket.QueryDataBlock();
+ packet.QueryData.QueryID = queryID;
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
+ packet.QueryReplies = new DirEventsReplyPacket.QueryRepliesBlock[
+ data.Length];
- int max = m_primTerseUpdates.Count;
- if (max > m_primTerseUpdatesPerPacket)
- max = m_primTerseUpdatesPerPacket;
+ packet.StatusData = new DirEventsReplyPacket.StatusDataBlock[
+ data.Length];
- int count = 0;
- int size = 0;
+ int i = 0;
+ foreach (DirEventsReplyData d in data)
+ {
+ packet.QueryReplies[i] = new DirEventsReplyPacket.QueryRepliesBlock();
+ packet.StatusData[i] = new DirEventsReplyPacket.StatusDataBlock();
+ packet.QueryReplies[i].OwnerID = d.ownerID;
+ packet.QueryReplies[i].Name =
+ Utils.StringToBytes(d.name);
+ packet.QueryReplies[i].EventID = d.eventID;
+ packet.QueryReplies[i].Date =
+ Utils.StringToBytes(d.date);
+ packet.QueryReplies[i].UnixTime = d.unixTime;
+ packet.QueryReplies[i].EventFlags = d.eventFlags;
+ packet.StatusData[i].Status = d.Status;
+ i++;
+ }
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ OutPacket(packet, ThrottleOutPacketType.Task);
+ }
- for (count = 0 ; count < max ; count++)
- {
- int length = 0;
- m_primTerseUpdates[count].ToBytes(blockbuffer, ref length);
- length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
- if (size + length > m_packetMTU)
- break;
- size += length;
- }
+ public void SendDirGroupsReply(UUID queryID, DirGroupsReplyData[] data)
+ {
+ DirGroupsReplyPacket packet = (DirGroupsReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirGroupsReply);
- outPacket.ObjectData =
- new ImprovedTerseObjectUpdatePacket.
- ObjectDataBlock[count];
+ packet.AgentData = new DirGroupsReplyPacket.AgentDataBlock();
+ packet.AgentData.AgentID = AgentId;
- for (int index = 0 ; index < count ; index++)
- {
- outPacket.ObjectData[index] = m_primTerseUpdates[0];
- m_primTerseUpdates.RemoveAt(0);
- }
+ packet.QueryData = new DirGroupsReplyPacket.QueryDataBlock();
+ packet.QueryData.QueryID = queryID;
- outPacket.Header.Reliable = false;
- outPacket.Header.Zerocoded = true;
- OutPacket(outPacket, ThrottleOutPacketType.Task | ThrottleOutPacketType.LowPriority);
+ packet.QueryReplies = new DirGroupsReplyPacket.QueryRepliesBlock[
+ data.Length];
- if (m_primTerseUpdates.Count == 0)
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
+ int i = 0;
+ foreach (DirGroupsReplyData d in data)
+ {
+ packet.QueryReplies[i] = new DirGroupsReplyPacket.QueryRepliesBlock();
+ packet.QueryReplies[i].GroupID = d.groupID;
+ packet.QueryReplies[i].GroupName =
+ Utils.StringToBytes(d.groupName);
+ packet.QueryReplies[i].Members = d.members;
+ packet.QueryReplies[i].SearchOrder = d.searchOrder;
+ i++;
}
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void FlushPrimUpdates()
+ public void SendDirClassifiedReply(UUID queryID, DirClassifiedReplyData[] data)
{
- while (m_primFullUpdates.Count > 0)
- {
- ProcessPrimFullUpdates(this, null);
- }
- while (m_primTerseUpdates.Count > 0)
- {
- ProcessPrimTerseUpdates(this, null);
- }
- while (m_avatarTerseUpdates.Count > 0)
+ DirClassifiedReplyPacket packet = (DirClassifiedReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirClassifiedReply);
+
+ packet.AgentData = new DirClassifiedReplyPacket.AgentDataBlock();
+ packet.AgentData.AgentID = AgentId;
+
+ packet.QueryData = new DirClassifiedReplyPacket.QueryDataBlock();
+ packet.QueryData.QueryID = queryID;
+
+ packet.QueryReplies = new DirClassifiedReplyPacket.QueryRepliesBlock[
+ data.Length];
+ packet.StatusData = new DirClassifiedReplyPacket.StatusDataBlock[
+ data.Length];
+
+ int i = 0;
+ foreach (DirClassifiedReplyData d in data)
{
- ProcessAvatarTerseUpdates(this, null);
+ packet.QueryReplies[i] = new DirClassifiedReplyPacket.QueryRepliesBlock();
+ packet.StatusData[i] = new DirClassifiedReplyPacket.StatusDataBlock();
+ packet.QueryReplies[i].ClassifiedID = d.classifiedID;
+ packet.QueryReplies[i].Name =
+ Utils.StringToBytes(d.name);
+ packet.QueryReplies[i].ClassifiedFlags = d.classifiedFlags;
+ packet.QueryReplies[i].CreationDate = d.creationDate;
+ packet.QueryReplies[i].ExpirationDate = d.expirationDate;
+ packet.QueryReplies[i].PriceForListing = d.price;
+ packet.StatusData[i].Status = d.Status;
+ i++;
}
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendAssetUploadCompleteMessage(sbyte AssetType, bool Success, UUID AssetFullID)
+ public void SendDirLandReply(UUID queryID, DirLandReplyData[] data)
{
- AssetUploadCompletePacket newPack = new AssetUploadCompletePacket();
- newPack.AssetBlock.Type = AssetType;
- newPack.AssetBlock.Success = Success;
- newPack.AssetBlock.UUID = AssetFullID;
- newPack.Header.Zerocoded = true;
- OutPacket(newPack, ThrottleOutPacketType.Asset);
- }
+ DirLandReplyPacket packet = (DirLandReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirLandReply);
- public void SendXferRequest(ulong XferID, short AssetType, UUID vFileID, byte FilePath, byte[] FileName)
- {
- RequestXferPacket newPack = new RequestXferPacket();
- newPack.XferID.ID = XferID;
- newPack.XferID.VFileType = AssetType;
- newPack.XferID.VFileID = vFileID;
- newPack.XferID.FilePath = FilePath;
- newPack.XferID.Filename = FileName;
- newPack.Header.Zerocoded = true;
- OutPacket(newPack, ThrottleOutPacketType.Asset);
- }
+ packet.AgentData = new DirLandReplyPacket.AgentDataBlock();
+ packet.AgentData.AgentID = AgentId;
- public void SendConfirmXfer(ulong xferID, uint PacketID)
- {
- ConfirmXferPacketPacket newPack = new ConfirmXferPacketPacket();
- newPack.XferID.ID = xferID;
- newPack.XferID.Packet = PacketID;
- newPack.Header.Zerocoded = true;
- OutPacket(newPack, ThrottleOutPacketType.Asset);
+ packet.QueryData = new DirLandReplyPacket.QueryDataBlock();
+ packet.QueryData.QueryID = queryID;
+
+ packet.QueryReplies = new DirLandReplyPacket.QueryRepliesBlock[
+ data.Length];
+
+ int i = 0;
+ foreach (DirLandReplyData d in data)
+ {
+ packet.QueryReplies[i] = new DirLandReplyPacket.QueryRepliesBlock();
+ packet.QueryReplies[i].ParcelID = d.parcelID;
+ packet.QueryReplies[i].Name =
+ Utils.StringToBytes(d.name);
+ packet.QueryReplies[i].Auction = d.auction;
+ packet.QueryReplies[i].ForSale = d.forSale;
+ packet.QueryReplies[i].SalePrice = d.salePrice;
+ packet.QueryReplies[i].ActualArea = d.actualArea;
+ i++;
+ }
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
-
- public void SendInitiateDownload(string simFileName, string clientFileName)
+
+ public void SendDirPopularReply(UUID queryID, DirPopularReplyData[] data)
{
- InitiateDownloadPacket newPack = new InitiateDownloadPacket();
- newPack.AgentData.AgentID = AgentId;
- newPack.FileData.SimFilename = Utils.StringToBytes(simFileName);
- newPack.FileData.ViewerFilename = Utils.StringToBytes(clientFileName);
- OutPacket(newPack, ThrottleOutPacketType.Asset);
+ DirPopularReplyPacket packet = (DirPopularReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPopularReply);
+
+ packet.AgentData = new DirPopularReplyPacket.AgentDataBlock();
+ packet.AgentData.AgentID = AgentId;
+
+ packet.QueryData = new DirPopularReplyPacket.QueryDataBlock();
+ packet.QueryData.QueryID = queryID;
+
+ packet.QueryReplies = new DirPopularReplyPacket.QueryRepliesBlock[
+ data.Length];
+
+ int i = 0;
+ foreach (DirPopularReplyData d in data)
+ {
+ packet.QueryReplies[i] = new DirPopularReplyPacket.QueryRepliesBlock();
+ packet.QueryReplies[i].ParcelID = d.parcelID;
+ packet.QueryReplies[i].Name =
+ Utils.StringToBytes(d.name);
+ packet.QueryReplies[i].Dwell = d.dwell;
+ i++;
+ }
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
-
- public void SendImageFirstPart(
- ushort numParts, UUID ImageUUID, uint ImageSize, byte[] ImageData, byte imageCodec)
+
+ public void SendEventInfoReply(EventData data)
{
- ImageDataPacket im = new ImageDataPacket();
- im.Header.Reliable = false;
- im.ImageID.Packets = numParts;
- im.ImageID.ID = ImageUUID;
+ EventInfoReplyPacket packet = (EventInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.EventInfoReply);
- if (ImageSize > 0)
- im.ImageID.Size = ImageSize;
+ packet.AgentData = new EventInfoReplyPacket.AgentDataBlock();
+ packet.AgentData.AgentID = AgentId;
- im.ImageData.Data = ImageData;
- im.ImageID.Codec = imageCodec;
- im.Header.Zerocoded = true;
- OutPacket(im, ThrottleOutPacketType.Texture);
+ packet.EventData = new EventInfoReplyPacket.EventDataBlock();
+ packet.EventData.EventID = data.eventID;
+ packet.EventData.Creator = Utils.StringToBytes(data.creator);
+ packet.EventData.Name = Utils.StringToBytes(data.name);
+ packet.EventData.Category = Utils.StringToBytes(data.category);
+ packet.EventData.Desc = Utils.StringToBytes(data.description);
+ packet.EventData.Date = Utils.StringToBytes(data.date);
+ packet.EventData.DateUTC = data.dateUTC;
+ packet.EventData.Duration = data.duration;
+ packet.EventData.Cover = data.cover;
+ packet.EventData.Amount = data.amount;
+ packet.EventData.SimName = Utils.StringToBytes(data.simName);
+ packet.EventData.GlobalPos = new Vector3d(data.globalPos);
+ packet.EventData.EventFlags = data.eventFlags;
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendImageNextPart(ushort partNumber, UUID imageUuid, byte[] imageData)
+ public void SendMapItemReply(mapItemReply[] replies, uint mapitemtype, uint flags)
{
- ImagePacketPacket im = new ImagePacketPacket();
- im.Header.Reliable = false;
- im.ImageID.Packet = partNumber;
- im.ImageID.ID = imageUuid;
- im.ImageData.Data = imageData;
+ MapItemReplyPacket mirplk = new MapItemReplyPacket();
+ mirplk.AgentData.AgentID = AgentId;
+ mirplk.RequestData.ItemType = mapitemtype;
+ mirplk.Data = new MapItemReplyPacket.DataBlock[replies.Length];
+ for (int i = 0; i < replies.Length; i++)
+ {
+ MapItemReplyPacket.DataBlock mrdata = new MapItemReplyPacket.DataBlock();
+ mrdata.X = replies[i].x;
+ mrdata.Y = replies[i].y;
+ mrdata.ID = replies[i].id;
+ mrdata.Extra = replies[i].Extra;
+ mrdata.Extra2 = replies[i].Extra2;
+ mrdata.Name = Utils.StringToBytes(replies[i].name);
+ mirplk.Data[i] = mrdata;
+ }
+ //m_log.Debug(mirplk.ToString());
+ OutPacket(mirplk, ThrottleOutPacketType.Task);
- OutPacket(im, ThrottleOutPacketType.Texture);
}
- public void SendImageNotFound(UUID imageid)
+ public void SendOfferCallingCard(UUID srcID, UUID transactionID)
{
- ImageNotInDatabasePacket notFoundPacket
- = (ImageNotInDatabasePacket)PacketPool.Instance.GetPacket(PacketType.ImageNotInDatabase);
+ // a bit special, as this uses AgentID to store the source instead
+ // of the destination. The destination (the receiver) goes into destID
+ OfferCallingCardPacket p = (OfferCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.OfferCallingCard);
+ p.AgentData.AgentID = srcID;
+ p.AgentData.SessionID = UUID.Zero;
+ p.AgentBlock.DestID = AgentId;
+ p.AgentBlock.TransactionID = transactionID;
+ OutPacket(p, ThrottleOutPacketType.Task);
+ }
- notFoundPacket.ImageID.ID = imageid;
+ public void SendAcceptCallingCard(UUID transactionID)
+ {
+ AcceptCallingCardPacket p = (AcceptCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.AcceptCallingCard);
+ p.AgentData.AgentID = AgentId;
+ p.AgentData.SessionID = UUID.Zero;
+ p.FolderData = new AcceptCallingCardPacket.FolderDataBlock[1];
+ p.FolderData[0] = new AcceptCallingCardPacket.FolderDataBlock();
+ p.FolderData[0].FolderID = UUID.Zero;
+ OutPacket(p, ThrottleOutPacketType.Task);
+ }
- OutPacket(notFoundPacket, ThrottleOutPacketType.Texture);
+ public void SendDeclineCallingCard(UUID transactionID)
+ {
+ DeclineCallingCardPacket p = (DeclineCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.DeclineCallingCard);
+ p.AgentData.AgentID = AgentId;
+ p.AgentData.SessionID = UUID.Zero;
+ p.TransactionBlock.TransactionID = transactionID;
+ OutPacket(p, ThrottleOutPacketType.Task);
}
- public void SendShutdownConnectionNotice()
+ public void SendTerminateFriend(UUID exFriendID)
{
- OutPacket(PacketPool.Instance.GetPacket(PacketType.DisableSimulator), ThrottleOutPacketType.Unknown);
+ TerminateFriendshipPacket p = (TerminateFriendshipPacket)PacketPool.Instance.GetPacket(PacketType.TerminateFriendship);
+ p.AgentData.AgentID = AgentId;
+ p.AgentData.SessionID = SessionId;
+ p.ExBlock.OtherID = exFriendID;
+ OutPacket(p, ThrottleOutPacketType.Task);
}
- public void SendSimStats(SimStats stats)
+ public void SendAvatarGroupsReply(UUID avatarID, GroupMembershipData[] data)
{
- SimStatsPacket pack = new SimStatsPacket();
- pack.Region = new SimStatsPacket.RegionBlock();
- pack.Region.RegionX = stats.RegionX;
- pack.Region.RegionY = stats.RegionY;
- pack.Region.RegionFlags = stats.RegionFlags;
- pack.Region.ObjectCapacity = stats.ObjectCapacity;
- //pack.Region = //stats.RegionBlock;
- pack.Stat = stats.StatsBlock;
+ AvatarGroupsReplyPacket p = (AvatarGroupsReplyPacket)PacketPool.Instance.GetPacket(PacketType.AvatarGroupsReply);
- pack.Header.Reliable = false;
+ p.AgentData = new AvatarGroupsReplyPacket.AgentDataBlock();
+ p.AgentData.AgentID = AgentId;
+ p.AgentData.AvatarID = avatarID;
- OutPacket(pack, ThrottleOutPacketType.Task);
+ p.GroupData = new AvatarGroupsReplyPacket.GroupDataBlock[data.Length];
+ int i = 0;
+ foreach (GroupMembershipData m in data)
+ {
+ p.GroupData[i] = new AvatarGroupsReplyPacket.GroupDataBlock();
+ p.GroupData[i].GroupPowers = m.GroupPowers;
+ p.GroupData[i].AcceptNotices = m.AcceptNotices;
+ p.GroupData[i].GroupTitle = Utils.StringToBytes(m.GroupTitle);
+ p.GroupData[i].GroupID = m.GroupID;
+ p.GroupData[i].GroupName = Utils.StringToBytes(m.GroupName);
+ p.GroupData[i].GroupInsigniaID = m.GroupPicture;
+ i++;
+ }
+
+ p.NewGroupData = new AvatarGroupsReplyPacket.NewGroupDataBlock();
+ p.NewGroupData.ListInProfile = true;
+
+ OutPacket(p, ThrottleOutPacketType.Task);
}
- public void SendObjectPropertiesFamilyData(uint RequestFlags, UUID ObjectUUID, UUID OwnerID, UUID GroupID,
- uint BaseMask, uint OwnerMask, uint GroupMask, uint EveryoneMask,
- uint NextOwnerMask, int OwnershipCost, byte SaleType, int SalePrice, uint Category,
- UUID LastOwnerID, string ObjectName, string Description)
+ public void SendJoinGroupReply(UUID groupID, bool success)
{
- ObjectPropertiesFamilyPacket objPropFamilyPack = (ObjectPropertiesFamilyPacket)PacketPool.Instance.GetPacket(PacketType.ObjectPropertiesFamily);
- // TODO: don't create new blocks if recycling an old packet
+ JoinGroupReplyPacket p = (JoinGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.JoinGroupReply);
- ObjectPropertiesFamilyPacket.ObjectDataBlock objPropDB = new ObjectPropertiesFamilyPacket.ObjectDataBlock();
- objPropDB.RequestFlags = RequestFlags;
- objPropDB.ObjectID = ObjectUUID;
- if (OwnerID == GroupID)
- objPropDB.OwnerID = UUID.Zero;
- else
- objPropDB.OwnerID = OwnerID;
- objPropDB.GroupID = GroupID;
- objPropDB.BaseMask = BaseMask;
- objPropDB.OwnerMask = OwnerMask;
- objPropDB.GroupMask = GroupMask;
- objPropDB.EveryoneMask = EveryoneMask;
- objPropDB.NextOwnerMask = NextOwnerMask;
+ p.AgentData = new JoinGroupReplyPacket.AgentDataBlock();
+ p.AgentData.AgentID = AgentId;
- // TODO: More properties are needed in SceneObjectPart!
- objPropDB.OwnershipCost = OwnershipCost;
- objPropDB.SaleType = SaleType;
- objPropDB.SalePrice = SalePrice;
- objPropDB.Category = Category;
- objPropDB.LastOwnerID = LastOwnerID;
- objPropDB.Name = LLUtil.StringToPacketBytes(ObjectName);
- objPropDB.Description = LLUtil.StringToPacketBytes(Description);
- objPropFamilyPack.ObjectData = objPropDB;
- objPropFamilyPack.Header.Zerocoded = true;
- OutPacket(objPropFamilyPack, ThrottleOutPacketType.Task);
+ p.GroupData = new JoinGroupReplyPacket.GroupDataBlock();
+ p.GroupData.GroupID = groupID;
+ p.GroupData.Success = success;
+
+ OutPacket(p, ThrottleOutPacketType.Task);
}
- public void SendObjectPropertiesReply(
- UUID ItemID, ulong CreationDate, UUID CreatorUUID, UUID FolderUUID, UUID FromTaskUUID,
- UUID GroupUUID, short InventorySerial, UUID LastOwnerUUID, UUID ObjectUUID,
- UUID OwnerUUID, string TouchTitle, byte[] TextureID, string SitTitle, string ItemName,
- string ItemDescription, uint OwnerMask, uint NextOwnerMask, uint GroupMask, uint EveryoneMask,
- uint BaseMask, byte saleType, int salePrice)
+ public void SendEjectGroupMemberReply(UUID agentID, UUID groupID, bool success)
{
- ObjectPropertiesPacket proper = (ObjectPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ObjectProperties);
- // TODO: don't create new blocks if recycling an old packet
+ EjectGroupMemberReplyPacket p = (EjectGroupMemberReplyPacket)PacketPool.Instance.GetPacket(PacketType.EjectGroupMemberReply);
- proper.ObjectData = new ObjectPropertiesPacket.ObjectDataBlock[1];
- proper.ObjectData[0] = new ObjectPropertiesPacket.ObjectDataBlock();
- proper.ObjectData[0].ItemID = ItemID;
- proper.ObjectData[0].CreationDate = CreationDate;
- proper.ObjectData[0].CreatorID = CreatorUUID;
- proper.ObjectData[0].FolderID = FolderUUID;
- proper.ObjectData[0].FromTaskID = FromTaskUUID;
- proper.ObjectData[0].GroupID = GroupUUID;
- proper.ObjectData[0].InventorySerial = InventorySerial;
+ p.AgentData = new EjectGroupMemberReplyPacket.AgentDataBlock();
+ p.AgentData.AgentID = agentID;
- proper.ObjectData[0].LastOwnerID = LastOwnerUUID;
- // proper.ObjectData[0].LastOwnerID = UUID.Zero;
+ p.GroupData = new EjectGroupMemberReplyPacket.GroupDataBlock();
+ p.GroupData.GroupID = groupID;
- proper.ObjectData[0].ObjectID = ObjectUUID;
- if (OwnerUUID == GroupUUID)
- proper.ObjectData[0].OwnerID = UUID.Zero;
- else
- proper.ObjectData[0].OwnerID = OwnerUUID;
- proper.ObjectData[0].TouchName = LLUtil.StringToPacketBytes(TouchTitle);
- proper.ObjectData[0].TextureID = TextureID;
- proper.ObjectData[0].SitName = LLUtil.StringToPacketBytes(SitTitle);
- proper.ObjectData[0].Name = LLUtil.StringToPacketBytes(ItemName);
- proper.ObjectData[0].Description = LLUtil.StringToPacketBytes(ItemDescription);
- proper.ObjectData[0].OwnerMask = OwnerMask;
- proper.ObjectData[0].NextOwnerMask = NextOwnerMask;
- proper.ObjectData[0].GroupMask = GroupMask;
- proper.ObjectData[0].EveryoneMask = EveryoneMask;
- proper.ObjectData[0].BaseMask = BaseMask;
- // proper.ObjectData[0].AggregatePerms = 53;
- // proper.ObjectData[0].AggregatePermTextures = 0;
- // proper.ObjectData[0].AggregatePermTexturesOwner = 0;
- proper.ObjectData[0].SaleType = saleType;
- proper.ObjectData[0].SalePrice = salePrice;
- proper.Header.Zerocoded = true;
- OutPacket(proper, ThrottleOutPacketType.Task);
+ p.EjectData = new EjectGroupMemberReplyPacket.EjectDataBlock();
+ p.EjectData.Success = success;
+
+ OutPacket(p, ThrottleOutPacketType.Task);
}
- #endregion
+ public void SendLeaveGroupReply(UUID groupID, bool success)
+ {
+ LeaveGroupReplyPacket p = (LeaveGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.LeaveGroupReply);
- #region Estate Data Sending Methods
+ p.AgentData = new LeaveGroupReplyPacket.AgentDataBlock();
+ p.AgentData.AgentID = AgentId;
- private static bool convertParamStringToBool(byte[] field)
- {
- string s = Utils.BytesToString(field);
- if (s == "1" || s.ToLower() == "y" || s.ToLower() == "yes" || s.ToLower() == "t" || s.ToLower() == "true")
- {
- return true;
- }
- return false;
+ p.GroupData = new LeaveGroupReplyPacket.GroupDataBlock();
+ p.GroupData.GroupID = groupID;
+ p.GroupData.Success = success;
+
+ OutPacket(p, ThrottleOutPacketType.Task);
}
- public void SendEstateManagersList(UUID invoice, UUID[] EstateManagers, uint estateID)
+ public void SendAvatarClassifiedReply(UUID targetID, UUID[] classifiedID, string[] name)
{
- EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
- packet.AgentData.TransactionID = UUID.Random();
- packet.AgentData.AgentID = AgentId;
- packet.AgentData.SessionID = SessionId;
- packet.MethodData.Invoice = invoice;
- packet.MethodData.Method = Utils.StringToBytes("setaccess");
+ if (classifiedID.Length != name.Length)
+ return;
- EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + EstateManagers.Length];
+ AvatarClassifiedReplyPacket ac =
+ (AvatarClassifiedReplyPacket)PacketPool.Instance.GetPacket(
+ PacketType.AvatarClassifiedReply);
- for (int i = 0; i < (6 + EstateManagers.Length); i++)
- {
- returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
- }
- int j = 0;
+ ac.AgentData = new AvatarClassifiedReplyPacket.AgentDataBlock();
+ ac.AgentData.AgentID = AgentId;
+ ac.AgentData.TargetID = targetID;
- returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateManagers).ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes(EstateManagers.Length.ToString()); j++;
- for (int i = 0; i < EstateManagers.Length; i++)
+ ac.Data = new AvatarClassifiedReplyPacket.DataBlock[classifiedID.Length];
+ int i;
+ for (i = 0; i < classifiedID.Length; i++)
{
- returnblock[j].Parameter = EstateManagers[i].GetBytes(); j++;
+ ac.Data[i].ClassifiedID = classifiedID[i];
+ ac.Data[i].Name = Utils.StringToBytes(name[i]);
}
- packet.ParamList = returnblock;
- packet.Header.Reliable = false;
- OutPacket(packet, ThrottleOutPacketType.Task);
+
+ OutPacket(ac, ThrottleOutPacketType.Task);
}
- public void SendBannedUserList(UUID invoice, EstateBan[] bl, uint estateID)
+ public void SendClassifiedInfoReply(UUID classifiedID, UUID creatorID, uint creationDate, uint expirationDate, uint category, string name, string description, UUID parcelID, uint parentEstate, UUID snapshotID, string simName, Vector3 globalPos, string parcelName, byte classifiedFlags, int price)
{
- ListBannedUsers = new List();
+ ClassifiedInfoReplyPacket cr =
+ (ClassifiedInfoReplyPacket)PacketPool.Instance.GetPacket(
+ PacketType.ClassifiedInfoReply);
- for (int i = 0; i < bl.Length; i++)
- {
- if (bl[i] == null)
- continue;
- if (bl[i].BannedUserID == UUID.Zero)
- continue;
- BannedUsers.Add(bl[i].BannedUserID);
- }
+ cr.AgentData = new ClassifiedInfoReplyPacket.AgentDataBlock();
+ cr.AgentData.AgentID = AgentId;
- EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
- packet.AgentData.TransactionID = UUID.Random();
- packet.AgentData.AgentID = AgentId;
- packet.AgentData.SessionID = SessionId;
- packet.MethodData.Invoice = invoice;
- packet.MethodData.Method = Utils.StringToBytes("setaccess");
+ cr.Data = new ClassifiedInfoReplyPacket.DataBlock();
+ cr.Data.ClassifiedID = classifiedID;
+ cr.Data.CreatorID = creatorID;
+ cr.Data.CreationDate = creationDate;
+ cr.Data.ExpirationDate = expirationDate;
+ cr.Data.Category = category;
+ cr.Data.Name = Utils.StringToBytes(name);
+ cr.Data.Desc = Utils.StringToBytes(description);
+ cr.Data.ParcelID = parcelID;
+ cr.Data.ParentEstate = parentEstate;
+ cr.Data.SnapshotID = snapshotID;
+ cr.Data.SimName = Utils.StringToBytes(simName);
+ cr.Data.PosGlobal = new Vector3d(globalPos);
+ cr.Data.ParcelName = Utils.StringToBytes(parcelName);
+ cr.Data.ClassifiedFlags = classifiedFlags;
+ cr.Data.PriceForListing = price;
- EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + BannedUsers.Count];
+ OutPacket(cr, ThrottleOutPacketType.Task);
+ }
- for (int i = 0; i < (6 + BannedUsers.Count); i++)
- {
- returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
- }
- int j = 0;
+ public void SendAgentDropGroup(UUID groupID)
+ {
+ AgentDropGroupPacket dg =
+ (AgentDropGroupPacket)PacketPool.Instance.GetPacket(
+ PacketType.AgentDropGroup);
- returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateBans).ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes(BannedUsers.Count.ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ dg.AgentData = new AgentDropGroupPacket.AgentDataBlock();
+ dg.AgentData.AgentID = AgentId;
+ dg.AgentData.GroupID = groupID;
- foreach (UUID banned in BannedUsers)
- {
- returnblock[j].Parameter = banned.GetBytes(); j++;
- }
- packet.ParamList = returnblock;
- packet.Header.Reliable = false;
- OutPacket(packet, ThrottleOutPacketType.Task);
+ OutPacket(dg, ThrottleOutPacketType.Task);
}
- public void SendRegionInfoToEstateMenu(RegionInfoForEstateMenuArgs args)
+ public void SendAvatarNotesReply(UUID targetID, string text)
{
- RegionInfoPacket rinfopack = new RegionInfoPacket();
- RegionInfoPacket.RegionInfoBlock rinfoblk = new RegionInfoPacket.RegionInfoBlock();
- rinfopack.AgentData.AgentID = AgentId;
- rinfopack.AgentData.SessionID = SessionId;
- rinfoblk.BillableFactor = args.billableFactor;
- rinfoblk.EstateID = args.estateID;
- rinfoblk.MaxAgents = args.maxAgents;
- rinfoblk.ObjectBonusFactor = args.objectBonusFactor;
- rinfoblk.ParentEstateID = args.parentEstateID;
- rinfoblk.PricePerMeter = args.pricePerMeter;
- rinfoblk.RedirectGridX = args.redirectGridX;
- rinfoblk.RedirectGridY = args.redirectGridY;
- rinfoblk.RegionFlags = args.regionFlags;
- rinfoblk.SimAccess = args.simAccess;
- rinfoblk.SunHour = args.sunHour;
- rinfoblk.TerrainLowerLimit = args.terrainLowerLimit;
- rinfoblk.TerrainRaiseLimit = args.terrainRaiseLimit;
- rinfoblk.UseEstateSun = args.useEstateSun;
- rinfoblk.WaterHeight = args.waterHeight;
- rinfoblk.SimName = Utils.StringToBytes(args.simName);
-
- rinfopack.RegionInfo2 = new RegionInfoPacket.RegionInfo2Block();
- rinfopack.RegionInfo2.HardMaxAgents = uint.MaxValue;
- rinfopack.RegionInfo2.HardMaxObjects = uint.MaxValue;
- rinfopack.RegionInfo2.MaxAgents32 = uint.MaxValue;
- rinfopack.RegionInfo2.ProductName = Utils.EmptyBytes;
- rinfopack.RegionInfo2.ProductSKU = Utils.EmptyBytes;
+ AvatarNotesReplyPacket an =
+ (AvatarNotesReplyPacket)PacketPool.Instance.GetPacket(
+ PacketType.AvatarNotesReply);
- rinfopack.HasVariableBlocks = true;
- rinfopack.RegionInfo = rinfoblk;
- rinfopack.AgentData = new RegionInfoPacket.AgentDataBlock();
- rinfopack.AgentData.AgentID = AgentId;
- rinfopack.AgentData.SessionID = SessionId;
+ an.AgentData = new AvatarNotesReplyPacket.AgentDataBlock();
+ an.AgentData.AgentID = AgentId;
+ an.Data = new AvatarNotesReplyPacket.DataBlock();
+ an.Data.TargetID = targetID;
+ an.Data.Notes = Utils.StringToBytes(text);
- OutPacket(rinfopack, ThrottleOutPacketType.Task);
+ OutPacket(an, ThrottleOutPacketType.Task);
}
- public void SendEstateCovenantInformation(UUID covenant)
+ public void SendAvatarPicksReply(UUID targetID, Dictionary picks)
{
- EstateCovenantReplyPacket einfopack = new EstateCovenantReplyPacket();
- EstateCovenantReplyPacket.DataBlock edata = new EstateCovenantReplyPacket.DataBlock();
- edata.CovenantID = covenant;
- edata.CovenantTimestamp = 0;
- if (m_scene.RegionInfo.EstateSettings.EstateOwner != UUID.Zero)
- edata.EstateOwnerID = m_scene.RegionInfo.EstateSettings.EstateOwner;
- else
- edata.EstateOwnerID = m_scene.RegionInfo.MasterAvatarAssignedUUID;
- edata.EstateName = Utils.StringToBytes(m_scene.RegionInfo.EstateSettings.EstateName);
- einfopack.Data = edata;
- OutPacket(einfopack, ThrottleOutPacketType.Task);
- }
+ AvatarPicksReplyPacket ap =
+ (AvatarPicksReplyPacket)PacketPool.Instance.GetPacket(
+ PacketType.AvatarPicksReply);
- public void SendDetailedEstateData(UUID invoice, string estateName, uint estateID, uint parentEstate, uint estateFlags, uint sunPosition, UUID covenant, string abuseEmail, UUID estateOwner)
- {
- EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
- packet.MethodData.Invoice = invoice;
- packet.AgentData.TransactionID = UUID.Random();
- packet.MethodData.Method = Utils.StringToBytes("estateupdateinfo");
- EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[10];
+ ap.AgentData = new AvatarPicksReplyPacket.AgentDataBlock();
+ ap.AgentData.AgentID = AgentId;
+ ap.AgentData.TargetID = targetID;
- for (int i = 0; i < 10; i++)
+ ap.Data = new AvatarPicksReplyPacket.DataBlock[picks.Count];
+
+ int i = 0;
+ foreach (KeyValuePair pick in picks)
{
- returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
+ ap.Data[i] = new AvatarPicksReplyPacket.DataBlock();
+ ap.Data[i].PickID = pick.Key;
+ ap.Data[i].PickName = Utils.StringToBytes(pick.Value);
+ i++;
}
- //Sending Estate Settings
- returnblock[0].Parameter = Utils.StringToBytes(estateName);
- // TODO: remove this cruft once MasterAvatar is fully deprecated
- //
- returnblock[1].Parameter = Utils.StringToBytes(estateOwner.ToString());
- returnblock[2].Parameter = Utils.StringToBytes(estateID.ToString());
+ OutPacket(ap, ThrottleOutPacketType.Task);
+ }
- returnblock[3].Parameter = Utils.StringToBytes(estateFlags.ToString());
- returnblock[4].Parameter = Utils.StringToBytes(sunPosition.ToString());
- returnblock[5].Parameter = Utils.StringToBytes(parentEstate.ToString());
- returnblock[6].Parameter = Utils.StringToBytes(covenant.ToString());
- returnblock[7].Parameter = Utils.StringToBytes("1160895077"); // what is this?
- returnblock[8].Parameter = Utils.StringToBytes("1"); // what is this?
- returnblock[9].Parameter = Utils.StringToBytes(abuseEmail);
+ public void SendAvatarClassifiedReply(UUID targetID, Dictionary classifieds)
+ {
+ AvatarClassifiedReplyPacket ac =
+ (AvatarClassifiedReplyPacket)PacketPool.Instance.GetPacket(
+ PacketType.AvatarClassifiedReply);
- packet.ParamList = returnblock;
- packet.Header.Reliable = false;
- //m_log.Debug("[ESTATE]: SIM--->" + packet.ToString());
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ ac.AgentData = new AvatarClassifiedReplyPacket.AgentDataBlock();
+ ac.AgentData.AgentID = AgentId;
+ ac.AgentData.TargetID = targetID;
- #endregion
+ ac.Data = new AvatarClassifiedReplyPacket.DataBlock[classifieds.Count];
- #region Land Data Sending Methods
+ int i = 0;
+ foreach (KeyValuePair classified in classifieds)
+ {
+ ac.Data[i] = new AvatarClassifiedReplyPacket.DataBlock();
+ ac.Data[i].ClassifiedID = classified.Key;
+ ac.Data[i].Name = Utils.StringToBytes(classified.Value);
+ i++;
+ }
- public void SendLandParcelOverlay(byte[] data, int sequence_id)
- {
- ParcelOverlayPacket packet = (ParcelOverlayPacket)PacketPool.Instance.GetPacket(PacketType.ParcelOverlay);
- packet.ParcelData.Data = data;
- packet.ParcelData.SequenceID = sequence_id;
- packet.Header.Zerocoded = true;
- OutPacket(packet, ThrottleOutPacketType.Task);
+ OutPacket(ac, ThrottleOutPacketType.Task);
}
- public void SendLandProperties(int sequence_id, bool snap_selection, int request_result, LandData landData, float simObjectBonusFactor, int parcelObjectCapacity, int simObjectCapacity, uint regionFlags)
+ public void SendParcelDwellReply(int localID, UUID parcelID, float dwell)
{
- ParcelPropertiesPacket updatePacket = (ParcelPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ParcelProperties);
- // TODO: don't create new blocks if recycling an old packet
+ ParcelDwellReplyPacket pd =
+ (ParcelDwellReplyPacket)PacketPool.Instance.GetPacket(
+ PacketType.ParcelDwellReply);
- updatePacket.ParcelData.AABBMax = landData.AABBMax;
- updatePacket.ParcelData.AABBMin = landData.AABBMin;
- updatePacket.ParcelData.Area = landData.Area;
- updatePacket.ParcelData.AuctionID = landData.AuctionID;
- updatePacket.ParcelData.AuthBuyerID = landData.AuthBuyerID;
+ pd.AgentData = new ParcelDwellReplyPacket.AgentDataBlock();
+ pd.AgentData.AgentID = AgentId;
- updatePacket.ParcelData.Bitmap = landData.Bitmap;
+ pd.Data = new ParcelDwellReplyPacket.DataBlock();
+ pd.Data.LocalID = localID;
+ pd.Data.ParcelID = parcelID;
+ pd.Data.Dwell = dwell;
- updatePacket.ParcelData.Desc = Utils.StringToBytes(landData.Description);
- updatePacket.ParcelData.Category = (byte)landData.Category;
- updatePacket.ParcelData.ClaimDate = landData.ClaimDate;
- updatePacket.ParcelData.ClaimPrice = landData.ClaimPrice;
- updatePacket.ParcelData.GroupID = landData.GroupID;
- updatePacket.ParcelData.GroupPrims = landData.GroupPrims;
- updatePacket.ParcelData.IsGroupOwned = landData.IsGroupOwned;
- updatePacket.ParcelData.LandingType = landData.LandingType;
- updatePacket.ParcelData.LocalID = landData.LocalID;
+ OutPacket(pd, ThrottleOutPacketType.Land);
+ }
- if (landData.Area > 0)
- {
- updatePacket.ParcelData.MaxPrims = parcelObjectCapacity;
- }
- else
- {
- updatePacket.ParcelData.MaxPrims = 0;
- }
+ public void SendUserInfoReply(bool imViaEmail, bool visible, string email)
+ {
+ UserInfoReplyPacket ur =
+ (UserInfoReplyPacket)PacketPool.Instance.GetPacket(
+ PacketType.UserInfoReply);
- updatePacket.ParcelData.MediaAutoScale = landData.MediaAutoScale;
- updatePacket.ParcelData.MediaID = landData.MediaID;
- updatePacket.ParcelData.MediaURL = LLUtil.StringToPacketBytes(landData.MediaURL);
- updatePacket.ParcelData.MusicURL = LLUtil.StringToPacketBytes(landData.MusicURL);
- updatePacket.ParcelData.Name = Utils.StringToBytes(landData.Name);
- updatePacket.ParcelData.OtherCleanTime = landData.OtherCleanTime;
- updatePacket.ParcelData.OtherCount = 0; //unemplemented
- updatePacket.ParcelData.OtherPrims = landData.OtherPrims;
- updatePacket.ParcelData.OwnerID = landData.OwnerID;
- updatePacket.ParcelData.OwnerPrims = landData.OwnerPrims;
- updatePacket.ParcelData.ParcelFlags = landData.Flags;
- updatePacket.ParcelData.ParcelPrimBonus = simObjectBonusFactor;
- updatePacket.ParcelData.PassHours = landData.PassHours;
- updatePacket.ParcelData.PassPrice = landData.PassPrice;
- updatePacket.ParcelData.PublicCount = 0; //unemplemented
+ string Visible = "hidden";
+ if (visible)
+ Visible = "default";
- updatePacket.ParcelData.RegionDenyAnonymous = ((regionFlags & (uint)RegionFlags.DenyAnonymous) >
- 0);
- updatePacket.ParcelData.RegionDenyIdentified = ((regionFlags & (uint)RegionFlags.DenyIdentified) >
- 0);
- updatePacket.ParcelData.RegionDenyTransacted = ((regionFlags & (uint)RegionFlags.DenyTransacted) >
- 0);
- updatePacket.ParcelData.RegionPushOverride = ((regionFlags & (uint)RegionFlags.RestrictPushObject) >
- 0);
+ ur.AgentData = new UserInfoReplyPacket.AgentDataBlock();
+ ur.AgentData.AgentID = AgentId;
- updatePacket.ParcelData.RentPrice = 0;
- updatePacket.ParcelData.RequestResult = request_result;
- updatePacket.ParcelData.SalePrice = landData.SalePrice;
- updatePacket.ParcelData.SelectedPrims = landData.SelectedPrims;
- updatePacket.ParcelData.SelfCount = 0; //unemplemented
- updatePacket.ParcelData.SequenceID = sequence_id;
- if (landData.SimwideArea > 0)
- {
- updatePacket.ParcelData.SimWideMaxPrims = parcelObjectCapacity;
- }
- else
- {
- updatePacket.ParcelData.SimWideMaxPrims = 0;
- }
- updatePacket.ParcelData.SimWideTotalPrims = landData.SimwidePrims;
- updatePacket.ParcelData.SnapSelection = snap_selection;
- updatePacket.ParcelData.SnapshotID = landData.SnapshotID;
- updatePacket.ParcelData.Status = (byte)landData.Status;
- updatePacket.ParcelData.TotalPrims = landData.OwnerPrims + landData.GroupPrims + landData.OtherPrims +
- landData.SelectedPrims;
- updatePacket.ParcelData.UserLocation = landData.UserLocation;
- updatePacket.ParcelData.UserLookAt = landData.UserLookAt;
- updatePacket.Header.Zerocoded = true;
+ ur.UserData = new UserInfoReplyPacket.UserDataBlock();
+ ur.UserData.IMViaEMail = imViaEmail;
+ ur.UserData.DirectoryVisibility = Utils.StringToBytes(Visible);
+ ur.UserData.EMail = Utils.StringToBytes(email);
- try
- {
- IEventQueue eq = Scene.RequestModuleInterface();
- if (eq != null)
- {
- eq.ParcelProperties(updatePacket, this.AgentId);
- }
- }
- catch (Exception ex)
- {
- m_log.Error("Unable to send parcel data via eventqueue - exception: " + ex.ToString());
- m_log.Warn("sending parcel data via UDP");
- OutPacket(updatePacket, ThrottleOutPacketType.Task);
- }
+ OutPacket(ur, ThrottleOutPacketType.Task);
}
- public void SendLandAccessListData(List avatars, uint accessFlag, int localLandID)
+ public void SendCreateGroupReply(UUID groupID, bool success, string message)
{
- ParcelAccessListReplyPacket replyPacket = (ParcelAccessListReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelAccessListReply);
- replyPacket.Data.AgentID = AgentId;
- replyPacket.Data.Flags = accessFlag;
- replyPacket.Data.LocalID = localLandID;
- replyPacket.Data.SequenceID = 0;
+ CreateGroupReplyPacket createGroupReply = (CreateGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.CreateGroupReply);
- List list = new List();
- foreach (UUID avatar in avatars)
- {
- ParcelAccessListReplyPacket.ListBlock block = new ParcelAccessListReplyPacket.ListBlock();
- block.Flags = accessFlag;
- block.ID = avatar;
- block.Time = 0;
- list.Add(block);
- }
+ createGroupReply.AgentData =
+ new CreateGroupReplyPacket.AgentDataBlock();
+ createGroupReply.ReplyData =
+ new CreateGroupReplyPacket.ReplyDataBlock();
- replyPacket.List = list.ToArray();
- replyPacket.Header.Zerocoded = true;
- OutPacket(replyPacket, ThrottleOutPacketType.Task);
+ createGroupReply.AgentData.AgentID = AgentId;
+ createGroupReply.ReplyData.GroupID = groupID;
+
+ createGroupReply.ReplyData.Success = success;
+ createGroupReply.ReplyData.Message = Utils.StringToBytes(message);
+ OutPacket(createGroupReply, ThrottleOutPacketType.Task);
}
- public void SendForceClientSelectObjects(List ObjectIDs)
+ public void SendUseCachedMuteList()
{
- bool firstCall = true;
- const int MAX_OBJECTS_PER_PACKET = 251;
- ForceObjectSelectPacket pack = (ForceObjectSelectPacket)PacketPool.Instance.GetPacket(PacketType.ForceObjectSelect);
- ForceObjectSelectPacket.DataBlock[] data;
- while (ObjectIDs.Count > 0)
- {
- if (firstCall)
- {
- pack._Header.ResetList = true;
- firstCall = false;
- }
- else
- {
- pack._Header.ResetList = false;
- }
+ UseCachedMuteListPacket useCachedMuteList = (UseCachedMuteListPacket)PacketPool.Instance.GetPacket(PacketType.UseCachedMuteList);
- if (ObjectIDs.Count > MAX_OBJECTS_PER_PACKET)
- {
- data = new ForceObjectSelectPacket.DataBlock[MAX_OBJECTS_PER_PACKET];
- }
- else
- {
- data = new ForceObjectSelectPacket.DataBlock[ObjectIDs.Count];
- }
+ useCachedMuteList.AgentData = new UseCachedMuteListPacket.AgentDataBlock();
+ useCachedMuteList.AgentData.AgentID = AgentId;
- int i;
- for (i = 0; i < MAX_OBJECTS_PER_PACKET && ObjectIDs.Count > 0; i++)
- {
- data[i] = new ForceObjectSelectPacket.DataBlock();
- data[i].LocalID = Convert.ToUInt32(ObjectIDs[0]);
- ObjectIDs.RemoveAt(0);
- }
- pack.Data = data;
- pack.Header.Zerocoded = true;
- OutPacket(pack, ThrottleOutPacketType.Task);
- }
+ OutPacket(useCachedMuteList, ThrottleOutPacketType.Task);
}
- public void SendCameraConstraint(Vector4 ConstraintPlane)
+ public void SendMuteListUpdate(string filename)
{
- CameraConstraintPacket cpack = (CameraConstraintPacket)PacketPool.Instance.GetPacket(PacketType.CameraConstraint);
- cpack.CameraCollidePlane = new CameraConstraintPacket.CameraCollidePlaneBlock();
- cpack.CameraCollidePlane.Plane = ConstraintPlane;
- //m_log.DebugFormat("[CLIENTVIEW]: Constraint {0}", ConstraintPlane);
- OutPacket(cpack, ThrottleOutPacketType.Task);
+ MuteListUpdatePacket muteListUpdate = (MuteListUpdatePacket)PacketPool.Instance.GetPacket(PacketType.MuteListUpdate);
+
+ muteListUpdate.MuteData = new MuteListUpdatePacket.MuteDataBlock();
+ muteListUpdate.MuteData.AgentID = AgentId;
+ muteListUpdate.MuteData.Filename = Utils.StringToBytes(filename);
+
+ OutPacket(muteListUpdate, ThrottleOutPacketType.Task);
}
- public void SendLandObjectOwners(LandData land, List groups, Dictionary ownersAndCount)
+ public void SendPickInfoReply(UUID pickID, UUID creatorID, bool topPick, UUID parcelID, string name, string desc, UUID snapshotID, string user, string originalName, string simName, Vector3 posGlobal, int sortOrder, bool enabled)
{
-
+ PickInfoReplyPacket pickInfoReply = (PickInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.PickInfoReply);
- int notifyCount = ownersAndCount.Count;
- ParcelObjectOwnersReplyPacket pack = (ParcelObjectOwnersReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelObjectOwnersReply);
+ pickInfoReply.AgentData = new PickInfoReplyPacket.AgentDataBlock();
+ pickInfoReply.AgentData.AgentID = AgentId;
- if (notifyCount > 0)
- {
- if (notifyCount > 32)
- {
- m_log.InfoFormat(
- "[LAND]: More than {0} avatars own prims on this parcel. Only sending back details of first {0}"
- + " - a developer might want to investigate whether this is a hard limit", 32);
-
- notifyCount = 32;
- }
+ pickInfoReply.Data = new PickInfoReplyPacket.DataBlock();
+ pickInfoReply.Data.PickID = pickID;
+ pickInfoReply.Data.CreatorID = creatorID;
+ pickInfoReply.Data.TopPick = topPick;
+ pickInfoReply.Data.ParcelID = parcelID;
+ pickInfoReply.Data.Name = Utils.StringToBytes(name);
+ pickInfoReply.Data.Desc = Utils.StringToBytes(desc);
+ pickInfoReply.Data.SnapshotID = snapshotID;
+ pickInfoReply.Data.User = Utils.StringToBytes(user);
+ pickInfoReply.Data.OriginalName = Utils.StringToBytes(originalName);
+ pickInfoReply.Data.SimName = Utils.StringToBytes(simName);
+ pickInfoReply.Data.PosGlobal = new Vector3d(posGlobal);
+ pickInfoReply.Data.SortOrder = sortOrder;
+ pickInfoReply.Data.Enabled = enabled;
- ParcelObjectOwnersReplyPacket.DataBlock[] dataBlock
- = new ParcelObjectOwnersReplyPacket.DataBlock[notifyCount];
+ OutPacket(pickInfoReply, ThrottleOutPacketType.Task);
+ }
- int num = 0;
- foreach (UUID owner in ownersAndCount.Keys)
- {
- dataBlock[num] = new ParcelObjectOwnersReplyPacket.DataBlock();
- dataBlock[num].Count = ownersAndCount[owner];
+ #endregion Scene/Avatar to Client
- if (land.GroupID == owner || groups.Contains(owner))
- dataBlock[num].IsGroupOwned = true;
+ // Gesture
- dataBlock[num].OnlineStatus = true; //TODO: fix me later
- dataBlock[num].OwnerID = owner;
+ #region Appearance/ Wearables Methods
- num++;
+ public void SendWearables(AvatarWearable[] wearables, int serial)
+ {
+ AgentWearablesUpdatePacket aw = (AgentWearablesUpdatePacket)PacketPool.Instance.GetPacket(PacketType.AgentWearablesUpdate);
+ aw.AgentData.AgentID = AgentId;
+ aw.AgentData.SerialNum = (uint)serial;
+ aw.AgentData.SessionID = m_sessionId;
- if (num >= notifyCount)
- {
- break;
- }
- }
+ // TODO: don't create new blocks if recycling an old packet
+ aw.WearableData = new AgentWearablesUpdatePacket.WearableDataBlock[13];
+ AgentWearablesUpdatePacket.WearableDataBlock awb;
+ for (int i = 0; i < wearables.Length; i++)
+ {
+ awb = new AgentWearablesUpdatePacket.WearableDataBlock();
+ awb.WearableType = (byte)i;
+ awb.AssetID = wearables[i].AssetID;
+ awb.ItemID = wearables[i].ItemID;
+ aw.WearableData[i] = awb;
- pack.Data = dataBlock;
+// m_log.DebugFormat(
+// "[APPEARANCE]: Sending wearable item/asset {0} {1} (index {2}) for {3}",
+// awb.ItemID, awb.AssetID, i, Name);
}
- pack.Header.Zerocoded = true;
- this.OutPacket(pack, ThrottleOutPacketType.Task);
- }
-
- #endregion
- #region Helper Methods
+ OutPacket(aw, ThrottleOutPacketType.Task);
+ }
- protected ImprovedTerseObjectUpdatePacket.ObjectDataBlock CreateAvatarImprovedBlock(uint localID, Vector3 pos,
- Vector3 velocity,
- Quaternion rotation)
+ public void SendAppearance(UUID agentID, byte[] visualParams, byte[] textureEntry)
{
- byte[] bytes = new byte[60];
- int i = 0;
- ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat = PacketPool.GetDataBlock();
-
- dat.TextureEntry = new byte[0]; // AvatarTemplate.TextureEntry;
+ AvatarAppearancePacket avp = (AvatarAppearancePacket)PacketPool.Instance.GetPacket(PacketType.AvatarAppearance);
+ // TODO: don't create new blocks if recycling an old packet
+ avp.VisualParam = new AvatarAppearancePacket.VisualParamBlock[218];
+ avp.ObjectData.TextureEntry = textureEntry;
- uint ID = localID;
+ AvatarAppearancePacket.VisualParamBlock avblock = null;
+ for (int i = 0; i < visualParams.Length; i++)
+ {
+ avblock = new AvatarAppearancePacket.VisualParamBlock();
+ avblock.ParamValue = visualParams[i];
+ avp.VisualParam[i] = avblock;
+ }
- bytes[i++] = (byte)(ID % 256);
- bytes[i++] = (byte)((ID >> 8) % 256);
- bytes[i++] = (byte)((ID >> 16) % 256);
- bytes[i++] = (byte)((ID >> 24) % 256);
- bytes[i++] = 0;
- bytes[i++] = 1;
- i += 14;
- bytes[i++] = 128;
- bytes[i++] = 63;
+ avp.Sender.IsTrial = false;
+ avp.Sender.ID = agentID;
+ OutPacket(avp, ThrottleOutPacketType.Task);
+ }
- byte[] pb = pos.GetBytes();
- Array.Copy(pb, 0, bytes, i, pb.Length);
- i += 12;
+ public void SendAnimations(UUID[] animations, int[] seqs, UUID sourceAgentId, UUID[] objectIDs)
+ {
+ //m_log.DebugFormat("[CLIENT]: Sending animations to {0}", Name);
- Vector3 internDirec = new Vector3(velocity.X, velocity.Y, velocity.Z);
+ AvatarAnimationPacket ani = (AvatarAnimationPacket)PacketPool.Instance.GetPacket(PacketType.AvatarAnimation);
+ // TODO: don't create new blocks if recycling an old packet
+ ani.AnimationSourceList = new AvatarAnimationPacket.AnimationSourceListBlock[animations.Length];
+ ani.Sender = new AvatarAnimationPacket.SenderBlock();
+ ani.Sender.ID = sourceAgentId;
+ ani.AnimationList = new AvatarAnimationPacket.AnimationListBlock[animations.Length];
+ ani.PhysicalAvatarEventList = new AvatarAnimationPacket.PhysicalAvatarEventListBlock[0];
- internDirec = internDirec / 128.0f;
- internDirec.X += 1;
- internDirec.Y += 1;
- internDirec.Z += 1;
+ for (int i = 0; i < animations.Length; ++i)
+ {
+ ani.AnimationList[i] = new AvatarAnimationPacket.AnimationListBlock();
+ ani.AnimationList[i].AnimID = animations[i];
+ ani.AnimationList[i].AnimSequenceID = seqs[i];
- ushort InternVelocityX = (ushort)(32768 * internDirec.X);
- ushort InternVelocityY = (ushort)(32768 * internDirec.Y);
- ushort InternVelocityZ = (ushort)(32768 * internDirec.Z);
+ ani.AnimationSourceList[i] = new AvatarAnimationPacket.AnimationSourceListBlock();
+ ani.AnimationSourceList[i].ObjectID = objectIDs[i];
+ if (objectIDs[i] == UUID.Zero)
+ ani.AnimationSourceList[i].ObjectID = sourceAgentId;
+ }
+ ani.Header.Reliable = false;
+ OutPacket(ani, ThrottleOutPacketType.Task);
+ }
- ushort ac = 32767;
- bytes[i++] = (byte)(InternVelocityX % 256);
- bytes[i++] = (byte)((InternVelocityX >> 8) % 256);
- bytes[i++] = (byte)(InternVelocityY % 256);
- bytes[i++] = (byte)((InternVelocityY >> 8) % 256);
- bytes[i++] = (byte)(InternVelocityZ % 256);
- bytes[i++] = (byte)((InternVelocityZ >> 8) % 256);
+ #endregion
- //accel
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
+ #region Avatar Packet/data sending Methods
- //rotation
- ushort rw, rx, ry, rz;
- rw = (ushort)(32768 * (rotation.W + 1));
- rx = (ushort)(32768 * (rotation.X + 1));
- ry = (ushort)(32768 * (rotation.Y + 1));
- rz = (ushort)(32768 * (rotation.Z + 1));
+ ///
+ /// send a objectupdate packet with information about the clients avatar
+ ///
+ public void SendAvatarData(ulong regionHandle, string firstName, string lastName, string grouptitle, UUID avatarID,
+ uint avatarLocalID, Vector3 Pos, byte[] textureEntry, uint parentID, Quaternion rotation)
+ {
+ ObjectUpdatePacket objupdate = (ObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdate);
+ // TODO: don't create new blocks if recycling an old packet
+ objupdate.RegionData.RegionHandle = regionHandle;
+ objupdate.RegionData.TimeDilation = ushort.MaxValue;
+ objupdate.ObjectData = new ObjectUpdatePacket.ObjectDataBlock[1];
+ objupdate.ObjectData[0] = CreateDefaultAvatarPacket(textureEntry);
- //rot
- bytes[i++] = (byte)(rx % 256);
- bytes[i++] = (byte)((rx >> 8) % 256);
- bytes[i++] = (byte)(ry % 256);
- bytes[i++] = (byte)((ry >> 8) % 256);
- bytes[i++] = (byte)(rz % 256);
- bytes[i++] = (byte)((rz >> 8) % 256);
- bytes[i++] = (byte)(rw % 256);
- bytes[i++] = (byte)((rw >> 8) % 256);
+ //give this avatar object a local id and assign the user a name
+ objupdate.ObjectData[0].ID = avatarLocalID;
+ objupdate.ObjectData[0].FullID = avatarID;
+ objupdate.ObjectData[0].ParentID = parentID;
+ objupdate.ObjectData[0].NameValue =
+ Utils.StringToBytes("FirstName STRING RW SV " + firstName + "\nLastName STRING RW SV " + lastName + "\nTitle STRING RW SV " + grouptitle);
- //rotation vel
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
+ Vector3 pos2 = new Vector3(Pos.X, Pos.Y, Pos.Z);
+ byte[] pb = pos2.GetBytes();
+ Array.Copy(pb, 0, objupdate.ObjectData[0].ObjectData, 16, pb.Length);
- dat.Data = bytes;
+ byte[] rot = rotation.GetBytes();
+ Array.Copy(rot, 0, objupdate.ObjectData[0].ObjectData, 52, rot.Length);
- return (dat);
+ objupdate.Header.Zerocoded = true;
+ OutPacket(objupdate, ThrottleOutPacketType.Task);
}
///
- ///
+ /// Send a terse positional/rotation/velocity update about an avatar
+ /// to the client. This avatar can be that of the client itself.
///
- ///
- ///
- ///
- ///
- protected ImprovedTerseObjectUpdatePacket.ObjectDataBlock CreatePrimImprovedBlock(uint localID,
- Vector3 position,
- Quaternion rotation,
- Vector3 velocity,
- Vector3 rotationalvelocity,
- byte state)
+ public virtual void SendAvatarTerseUpdate(ulong regionHandle,
+ ushort timeDilation, uint localID, Vector3 position,
+ Vector3 velocity, Quaternion rotation, UUID agentid)
{
- uint ID = localID;
- byte[] bytes = new byte[60];
-
- int i = 0;
- ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat = PacketPool.GetDataBlock();
- dat.TextureEntry = new byte[0];
- bytes[i++] = (byte)(ID % 256);
- bytes[i++] = (byte)((ID >> 8) % 256);
- bytes[i++] = (byte)((ID >> 16) % 256);
- bytes[i++] = (byte)((ID >> 24) % 256);
- bytes[i++] = (byte)(((state & 0xf0) >> 4) | ((state & 0x0f) << 4));
- bytes[i++] = 0;
+ if (rotation.X == rotation.Y &&
+ rotation.Y == rotation.Z &&
+ rotation.Z == rotation.W && rotation.W == 0)
+ rotation = Quaternion.Identity;
- byte[] pb = position.GetBytes();
- Array.Copy(pb, 0, bytes, i, pb.Length);
- i += 12;
- ushort ac = 32767;
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock terseBlock =
+ CreateAvatarImprovedBlock(localID, position, velocity,rotation);
+
+ lock (m_avatarTerseUpdates)
+ {
+ m_avatarTerseUpdates.Add(terseBlock);
- ushort velx, vely, velz;
- Vector3 vel = new Vector3(velocity.X, velocity.Y, velocity.Z);
+ // If packet is full or own movement packet, send it.
+ if (m_avatarTerseUpdates.Count >= m_avatarTerseUpdatesPerPacket)
+ {
+ ProcessAvatarTerseUpdates(this, null);
+ }
+ else if (m_avatarTerseUpdates.Count == 1)
+ {
+ lock (m_avatarTerseUpdateTimer)
+ m_avatarTerseUpdateTimer.Start();
+ }
+ }
+ }
- vel = vel / 128.0f;
- vel.X += 1;
- vel.Y += 1;
- vel.Z += 1;
- //vel
- velx = (ushort)(32768 * (vel.X));
- vely = (ushort)(32768 * (vel.Y));
- velz = (ushort)(32768 * (vel.Z));
+ private void ProcessAvatarTerseUpdates(object sender, ElapsedEventArgs e)
+ {
+ lock (m_avatarTerseUpdates)
+ {
+ ImprovedTerseObjectUpdatePacket terse = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ImprovedTerseObjectUpdate);
- bytes[i++] = (byte)(velx % 256);
- bytes[i++] = (byte)((velx >> 8) % 256);
- bytes[i++] = (byte)(vely % 256);
- bytes[i++] = (byte)((vely >> 8) % 256);
- bytes[i++] = (byte)(velz % 256);
- bytes[i++] = (byte)((velz >> 8) % 256);
+ terse.RegionData = new ImprovedTerseObjectUpdatePacket.RegionDataBlock();
- //accel
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
- bytes[i++] = (byte)(ac % 256);
- bytes[i++] = (byte)((ac >> 8) % 256);
+ terse.RegionData.RegionHandle = Scene.RegionInfo.RegionHandle;
+ terse.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- ushort rw, rx, ry, rz;
- rw = (ushort)(32768 * (rotation.W + 1));
- rx = (ushort)(32768 * (rotation.X + 1));
- ry = (ushort)(32768 * (rotation.Y + 1));
- rz = (ushort)(32768 * (rotation.Z + 1));
+ int max = m_avatarTerseUpdatesPerPacket;
+ if (max > m_avatarTerseUpdates.Count)
+ max = m_avatarTerseUpdates.Count;
- //rot
- bytes[i++] = (byte)(rx % 256);
- bytes[i++] = (byte)((rx >> 8) % 256);
- bytes[i++] = (byte)(ry % 256);
- bytes[i++] = (byte)((ry >> 8) % 256);
- bytes[i++] = (byte)(rz % 256);
- bytes[i++] = (byte)((rz >> 8) % 256);
- bytes[i++] = (byte)(rw % 256);
- bytes[i++] = (byte)((rw >> 8) % 256);
+ int count = 0;
+ int size = 0;
- //rotation vel
- Vector3 rvel = new Vector3(rotationalvelocity.X, rotationalvelocity.Y, rotationalvelocity.Z);
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
- rvel = rvel / 128.0f;
- rvel.X += 1;
- rvel.Y += 1;
- rvel.Z += 1;
- //vel
- ushort rvelx = (ushort)(32768 * (rvel.X));
- ushort rvely = (ushort)(32768 * (rvel.Y));
- ushort rvelz = (ushort)(32768 * (rvel.Z));
+ for (count = 0 ; count < max ; count++)
+ {
+ int length = 0;
+ m_avatarTerseUpdates[count].ToBytes(blockbuffer, ref length);
+ length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
+ if (size + length > m_packetMTU)
+ break;
+ size += length;
+ }
- bytes[i++] = (byte)(rvelx % 256);
- bytes[i++] = (byte)((rvelx >> 8) % 256);
- bytes[i++] = (byte)(rvely % 256);
- bytes[i++] = (byte)((rvely >> 8) % 256);
- bytes[i++] = (byte)(rvelz % 256);
- bytes[i++] = (byte)((rvelz >> 8) % 256);
- dat.Data = bytes;
+ terse.ObjectData = new ImprovedTerseObjectUpdatePacket.ObjectDataBlock[count];
- return dat;
+ for (int i = 0 ; i < count ; i++)
+ {
+ terse.ObjectData[i] = m_avatarTerseUpdates[0];
+ m_avatarTerseUpdates.RemoveAt(0);
+ }
+
+ terse.Header.Reliable = false;
+ terse.Header.Zerocoded = true;
+ OutPacket(terse, ThrottleOutPacketType.Task);
+
+ if (m_avatarTerseUpdates.Count == 0)
+ {
+ lock (m_avatarTerseUpdateTimer)
+ m_avatarTerseUpdateTimer.Stop();
+ }
+ }
}
- ///
- /// Create the ObjectDataBlock for a ObjectUpdatePacket (for a Primitive)
- ///
- ///
- ///
- protected ObjectUpdatePacket.ObjectDataBlock CreatePrimUpdateBlock(PrimitiveBaseShape primShape, uint flags)
+ public void SendCoarseLocationUpdate(List users, List CoarseLocations)
{
- ObjectUpdatePacket.ObjectDataBlock objupdate = PacketPool.GetDataBlock();
- SetDefaultPrimPacketValues(objupdate);
- objupdate.UpdateFlags = flags;
- SetPrimPacketShapeData(objupdate, primShape);
+ if (!IsActive) return; // We don't need to update inactive clients.
- if ((primShape.PCode == (byte)PCode.NewTree) || (primShape.PCode == (byte)PCode.Tree) || (primShape.PCode == (byte)PCode.Grass))
+ CoarseLocationUpdatePacket loc = (CoarseLocationUpdatePacket)PacketPool.Instance.GetPacket(PacketType.CoarseLocationUpdate);
+ // TODO: don't create new blocks if recycling an old packet
+ int total = CoarseLocations.Count;
+ CoarseLocationUpdatePacket.IndexBlock ib =
+ new CoarseLocationUpdatePacket.IndexBlock();
+ loc.Location = new CoarseLocationUpdatePacket.LocationBlock[total];
+ loc.AgentData = new CoarseLocationUpdatePacket.AgentDataBlock[total];
+
+ for (int i = 0; i < total; i++)
{
- objupdate.Data = new byte[1];
- objupdate.Data[0] = primShape.State;
+ CoarseLocationUpdatePacket.LocationBlock lb =
+ new CoarseLocationUpdatePacket.LocationBlock();
+ lb.X = (byte)CoarseLocations[i].X;
+ lb.Y = (byte)CoarseLocations[i].Y;
+
+ lb.Z = CoarseLocations[i].Z > 1024 ? (byte)0 : (byte)(CoarseLocations[i].Z * 0.25);
+ loc.Location[i] = lb;
+ loc.AgentData[i] = new CoarseLocationUpdatePacket.AgentDataBlock();
+ loc.AgentData[i].AgentID = users[i];
}
- return objupdate;
- }
+ ib.You = -1;
+ ib.Prey = -1;
+ loc.Index = ib;
+ loc.Header.Reliable = false;
+ loc.Header.Zerocoded = true;
- protected void SetPrimPacketShapeData(ObjectUpdatePacket.ObjectDataBlock objectData, PrimitiveBaseShape primData)
- {
- objectData.TextureEntry = primData.TextureEntry;
- objectData.PCode = primData.PCode;
- objectData.State = primData.State;
- objectData.PathBegin = primData.PathBegin;
- objectData.PathEnd = primData.PathEnd;
- objectData.PathScaleX = primData.PathScaleX;
- objectData.PathScaleY = primData.PathScaleY;
- objectData.PathShearX = primData.PathShearX;
- objectData.PathShearY = primData.PathShearY;
- objectData.PathSkew = primData.PathSkew;
- objectData.ProfileBegin = primData.ProfileBegin;
- objectData.ProfileEnd = primData.ProfileEnd;
- objectData.Scale = primData.Scale;
- objectData.PathCurve = primData.PathCurve;
- objectData.ProfileCurve = primData.ProfileCurve;
- objectData.ProfileHollow = primData.ProfileHollow;
- objectData.PathRadiusOffset = primData.PathRadiusOffset;
- objectData.PathRevolutions = primData.PathRevolutions;
- objectData.PathTaperX = primData.PathTaperX;
- objectData.PathTaperY = primData.PathTaperY;
- objectData.PathTwist = primData.PathTwist;
- objectData.PathTwistBegin = primData.PathTwistBegin;
- objectData.ExtraParams = primData.ExtraParams;
+ OutPacket(loc, ThrottleOutPacketType.Task);
}
- ///
- /// Set some default values in a ObjectUpdatePacket
- ///
- ///
- protected void SetDefaultPrimPacketValues(ObjectUpdatePacket.ObjectDataBlock objdata)
- {
- objdata.PSBlock = new byte[0];
- objdata.ExtraParams = new byte[1];
- objdata.MediaURL = new byte[0];
- objdata.NameValue = new byte[0];
- objdata.Text = new byte[0];
- objdata.TextColor = new byte[4];
- objdata.JointAxisOrAnchor = new Vector3(0, 0, 0);
- objdata.JointPivot = new Vector3(0, 0, 0);
- objdata.Material = 3;
- objdata.TextureAnim = new byte[0];
- objdata.Sound = UUID.Zero;
- objdata.State = 0;
- objdata.Data = new byte[0];
+ #endregion
- objdata.ObjectData = new byte[60];
- objdata.ObjectData[46] = 128;
- objdata.ObjectData[47] = 63;
- }
+ #region Primitive Packet/data Sending Methods
///
///
///
- ///
- public ObjectUpdatePacket.ObjectDataBlock CreateDefaultAvatarPacket(byte[] textureEntry)
+ ///
+ ///
+ ///
+ public void AttachObject(uint localID, Quaternion rotation, byte attachPoint, UUID ownerID)
{
- ObjectUpdatePacket.ObjectDataBlock objdata = PacketPool.GetDataBlock();
- // new OpenMetaverse.Packets.ObjectUpdatePacket.ObjectDataBlock(data1, ref i);
-
- SetDefaultAvatarPacketValues(ref objdata);
- objdata.UpdateFlags = 61 + (9 << 8) + (130 << 16) + (16 << 24);
- objdata.PathCurve = 16;
- objdata.ProfileCurve = 1;
- objdata.PathScaleX = 100;
- objdata.PathScaleY = 100;
- objdata.ParentID = 0;
- objdata.OwnerID = UUID.Zero;
- objdata.Scale = new Vector3(1, 1, 1);
- objdata.PCode = (byte)PCode.Avatar;
- if (textureEntry != null)
- {
- objdata.TextureEntry = textureEntry;
- }
- Vector3 pos = new Vector3(objdata.ObjectData, 16);
- pos.X = 100f;
- objdata.ID = 8880000;
- objdata.NameValue = Utils.StringToBytes("FirstName STRING RW SV Test \nLastName STRING RW SV User ");
- //Vector3 pos2 = new Vector3(100f, 100f, 23f);
- //objdata.FullID=user.AgentId;
- byte[] pb = pos.GetBytes();
- Array.Copy(pb, 0, objdata.ObjectData, 16, pb.Length);
+ if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
+ return;
- return objdata;
+ ObjectAttachPacket attach = (ObjectAttachPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAttach);
+ // TODO: don't create new blocks if recycling an old packet
+ attach.AgentData.AgentID = AgentId;
+ attach.AgentData.SessionID = m_sessionId;
+ attach.AgentData.AttachmentPoint = attachPoint;
+ attach.ObjectData = new ObjectAttachPacket.ObjectDataBlock[1];
+ attach.ObjectData[0] = new ObjectAttachPacket.ObjectDataBlock();
+ attach.ObjectData[0].ObjectLocalID = localID;
+ attach.ObjectData[0].Rotation = rotation;
+ attach.Header.Zerocoded = true;
+ OutPacket(attach, ThrottleOutPacketType.Task);
}
- ///
- ///
- ///
- ///
- protected void SetDefaultAvatarPacketValues(ref ObjectUpdatePacket.ObjectDataBlock objdata)
+ public void SendPrimitiveToClient(
+ ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
+ Vector3 pos, Vector3 vel, Vector3 acc, Quaternion rotation, Vector3 rvel,
+ uint flags, UUID objectID, UUID ownerID, string text, byte[] color,
+ uint parentID, byte[] particleSystem, byte clickAction, byte material)
{
- objdata.PSBlock = new byte[0];
- objdata.ExtraParams = new byte[1];
- objdata.MediaURL = new byte[0];
- objdata.NameValue = new byte[0];
- objdata.Text = new byte[0];
- objdata.TextColor = new byte[4];
- objdata.JointAxisOrAnchor = new Vector3(0, 0, 0);
- objdata.JointPivot = new Vector3(0, 0, 0);
- objdata.Material = 4;
- objdata.TextureAnim = new byte[0];
- objdata.Sound = UUID.Zero;
- Primitive.TextureEntry ntex = new Primitive.TextureEntry(new UUID("00000000-0000-0000-5005-000000000005"));
- objdata.TextureEntry = ntex.GetBytes();
+ byte[] textureanim = new byte[0];
- objdata.State = 0;
- objdata.Data = new byte[0];
-
- objdata.ObjectData = new byte[76];
- objdata.ObjectData[15] = 128;
- objdata.ObjectData[16] = 63;
- objdata.ObjectData[56] = 128;
- objdata.ObjectData[61] = 102;
- objdata.ObjectData[62] = 40;
- objdata.ObjectData[63] = 61;
- objdata.ObjectData[64] = 189;
+ SendPrimitiveToClient(regionHandle, timeDilation, localID, primShape, pos, vel,
+ acc, rotation, rvel, flags,
+ objectID, ownerID, text, color, parentID, particleSystem,
+ clickAction, material, textureanim, false, 0, UUID.Zero, UUID.Zero, 0, 0, 0);
}
- public void SendNameReply(UUID profileId, string firstname, string lastname)
+ public void SendPrimitiveToClient(
+ ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
+ Vector3 pos, Vector3 velocity, Vector3 acceleration, Quaternion rotation, Vector3 rotational_velocity,
+ uint flags,
+ UUID objectID, UUID ownerID, string text, byte[] color, uint parentID, byte[] particleSystem,
+ byte clickAction, byte material, byte[] textureanim, bool attachment, uint AttachPoint, UUID AssetId, UUID SoundId, double SoundGain, byte SoundFlags, double SoundRadius)
{
- UUIDNameReplyPacket packet = (UUIDNameReplyPacket)PacketPool.Instance.GetPacket(PacketType.UUIDNameReply);
- // TODO: don't create new blocks if recycling an old packet
- packet.UUIDNameBlock = new UUIDNameReplyPacket.UUIDNameBlockBlock[1];
- packet.UUIDNameBlock[0] = new UUIDNameReplyPacket.UUIDNameBlockBlock();
- packet.UUIDNameBlock[0].ID = profileId;
- packet.UUIDNameBlock[0].FirstName = Utils.StringToBytes(firstname);
- packet.UUIDNameBlock[0].LastName = Utils.StringToBytes(lastname);
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ if (AttachPoint > 30 && ownerID != AgentId) // Someone else's HUD
+ return;
+ if (primShape.PCode == 9 && primShape.State != 0 && parentID == 0)
+ return;
- #endregion
+ if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
+ rotation = Quaternion.Identity;
- ///
- /// This is a different way of processing packets then ProcessInPacket
- ///
- protected virtual void RegisterLocalPacketHandlers()
- {
- AddLocalPacketHandler(PacketType.LogoutRequest, Logout);
- AddLocalPacketHandler(PacketType.ViewerEffect, HandleViewerEffect);
- AddLocalPacketHandler(PacketType.AgentCachedTexture, AgentTextureCached);
- AddLocalPacketHandler(PacketType.MultipleObjectUpdate, MultipleObjUpdate);
- AddLocalPacketHandler(PacketType.MoneyTransferRequest, HandleMoneyTransferRequest);
- AddLocalPacketHandler(PacketType.ParcelBuy, HandleParcelBuyRequest);
- AddLocalPacketHandler(PacketType.UUIDGroupNameRequest, HandleUUIDGroupNameRequest);
- AddLocalPacketHandler(PacketType.ObjectGroup, HandleObjectGroupRequest);
- AddLocalPacketHandler(PacketType.GenericMessage, HandleGenericMessage);
- }
+ ObjectUpdatePacket.ObjectDataBlock objectData = CreatePrimUpdateBlock(primShape, flags);
- private bool HandleMoneyTransferRequest(IClientAPI sender, Packet Pack)
- {
- MoneyTransferRequestPacket money = (MoneyTransferRequestPacket) Pack;
- // validate the agent owns the agentID and sessionID
- if (money.MoneyData.SourceID == sender.AgentId && money.AgentData.AgentID == sender.AgentId &&
- money.AgentData.SessionID == sender.SessionId)
+ objectData.ID = localID;
+ objectData.FullID = objectID;
+ objectData.OwnerID = ownerID;
+
+ objectData.Text = LLUtil.StringToPacketBytes(text);
+ objectData.TextColor[0] = color[0];
+ objectData.TextColor[1] = color[1];
+ objectData.TextColor[2] = color[2];
+ objectData.TextColor[3] = color[3];
+ objectData.ParentID = parentID;
+ objectData.PSBlock = particleSystem;
+ objectData.ClickAction = clickAction;
+ objectData.Material = material;
+ objectData.Flags = 0;
+
+ if (attachment)
{
- handlerMoneyTransferRequest = OnMoneyTransferRequest;
- if (handlerMoneyTransferRequest != null)
- {
- handlerMoneyTransferRequest(money.MoneyData.SourceID, money.MoneyData.DestID,
- money.MoneyData.Amount, money.MoneyData.TransactionType,
- Util.FieldToString(money.MoneyData.Description));
- }
+ // Necessary???
+ objectData.JointAxisOrAnchor = new Vector3(0, 0, 2);
+ objectData.JointPivot = new Vector3(0, 0, 0);
- return true;
+ // Item from inventory???
+ objectData.NameValue =
+ Utils.StringToBytes("AttachItemID STRING RW SV " + AssetId.Guid);
+ objectData.State = (byte)((AttachPoint % 16) * 16 + (AttachPoint / 16));
}
- return false;
+ // Xantor 20080528: Send sound info as well
+ // Xantor 20080530: Zero out everything if there's no SoundId, so zerocompression will work again
+ objectData.Sound = SoundId;
+ if (SoundId == UUID.Zero)
+ {
+ objectData.OwnerID = UUID.Zero;
+ objectData.Gain = 0.0f;
+ objectData.Radius = 0.0f;
+ objectData.Flags = 0;
+ }
+ else
+ {
+ objectData.OwnerID = ownerID;
+ objectData.Gain = (float)SoundGain;
+ objectData.Radius = (float)SoundRadius;
+ objectData.Flags = SoundFlags;
+ }
+
+ byte[] pb = pos.GetBytes();
+ Array.Copy(pb, 0, objectData.ObjectData, 0, pb.Length);
+
+ byte[] vel = velocity.GetBytes();
+ Array.Copy(vel, 0, objectData.ObjectData, pb.Length, vel.Length);
+
+ byte[] rot = rotation.GetBytes();
+ Array.Copy(rot, 0, objectData.ObjectData, 36, rot.Length);
+
+ byte[] rvel = rotational_velocity.GetBytes();
+ Array.Copy(rvel, 0, objectData.ObjectData, 36 + rot.Length, rvel.Length);
+
+ if (textureanim.Length > 0)
+ {
+ objectData.TextureAnim = textureanim;
+ }
+
+ lock (m_primFullUpdates)
+ {
+ if (m_primFullUpdates.Count == 0)
+ m_primFullUpdateTimer.Start();
+
+ m_primFullUpdates.Add(objectData);
+
+ if (m_primFullUpdates.Count >= m_primFullUpdatesPerPacket)
+ ProcessPrimFullUpdates(this, null);
+ }
}
- private bool HandleParcelBuyRequest(IClientAPI sender, Packet Pack)
+ void HandleQueueEmpty(ThrottleOutPacketType queue)
{
- ParcelBuyPacket parcel = (ParcelBuyPacket) Pack;
- if (parcel.AgentData.AgentID == AgentId && parcel.AgentData.SessionID == SessionId)
+ switch (queue)
{
- handlerParcelBuy = OnParcelBuy;
- if (handlerParcelBuy != null)
- {
- handlerParcelBuy(parcel.AgentData.AgentID, parcel.Data.GroupID, parcel.Data.Final,
- parcel.Data.IsGroupOwned,
- parcel.Data.RemoveContribution, parcel.Data.LocalID, parcel.ParcelData.Area,
- parcel.ParcelData.Price,
- false);
- }
- return true;
+ case ThrottleOutPacketType.Texture:
+ ProcessTextureRequests();
+ break;
}
- return false;
}
- private bool HandleUUIDGroupNameRequest(IClientAPI sender, Packet Pack)
+ void ProcessTextureRequests()
{
- UUIDGroupNameRequestPacket upack = (UUIDGroupNameRequestPacket)Pack;
-
+ if (m_imageManager != null)
+ m_imageManager.ProcessImageQueue(m_textureSendLimit, m_textureDataLimit);
+ }
- for (int i = 0; i < upack.UUIDNameBlock.Length; i++)
+ void ProcessPrimFullUpdates(object sender, ElapsedEventArgs e)
+ {
+ lock (m_primFullUpdates)
{
- handlerUUIDGroupNameRequest = OnUUIDGroupNameRequest;
- if (handlerUUIDGroupNameRequest != null)
+ if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
{
- handlerUUIDGroupNameRequest(upack.UUIDNameBlock[i].ID, this);
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
+
+ return;
}
- }
- return true;
- }
+ ObjectUpdatePacket outPacket =
+ (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
+ PacketType.ObjectUpdate);
- public bool HandleGenericMessage(IClientAPI sender, Packet pack)
- {
- GenericMessagePacket gmpack = (GenericMessagePacket) pack;
- if (m_genericPacketHandlers.Count == 0) return false;
- if (gmpack.AgentData.SessionID != SessionId) return false;
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- handlerGenericMessage = null;
+ int max = m_primFullUpdates.Count;
+ if (max > m_primFullUpdatesPerPacket)
+ max = m_primFullUpdatesPerPacket;
- string method = Util.FieldToString(gmpack.MethodData.Method).ToLower().Trim();
+ int count = 0;
+ int size = 0;
- if (m_genericPacketHandlers.TryGetValue(method, out handlerGenericMessage))
- {
- List msg = new List();
- List msgBytes = new List();
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
- if (handlerGenericMessage != null)
+ for (count = 0 ; count < max ; count++)
{
- foreach (GenericMessagePacket.ParamListBlock block in gmpack.ParamList)
- {
- msg.Add(Util.FieldToString(block.Parameter));
- msgBytes.Add(block.Parameter);
- }
- try
- {
- if (OnBinaryGenericMessage != null)
- {
- OnBinaryGenericMessage(this, method, msgBytes.ToArray());
- }
- handlerGenericMessage(sender, method, msg);
- return true;
- }
- catch (Exception e)
- {
- m_log.Error("[GENERICMESSAGE] " + e);
- }
+ int length = 0;
+ m_primFullUpdates[count].ToBytes(blockbuffer, ref length);
+ length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
+ if (size + length > m_packetMTU)
+ break;
+ size += length;
}
- }
- m_log.Error("[GENERICMESSAGE] Not handling GenericMessage with method-type of: " + method);
- return false;
- }
-
- public bool HandleObjectGroupRequest(IClientAPI sender, Packet Pack)
- {
- ObjectGroupPacket ogpack = (ObjectGroupPacket)Pack;
- if (ogpack.AgentData.SessionID != SessionId) return false;
+ outPacket.ObjectData =
+ new ObjectUpdatePacket.ObjectDataBlock[count];
- handlerObjectGroupRequest = OnObjectGroupRequest;
- if (handlerObjectGroupRequest != null)
- {
- for (int i = 0; i < ogpack.ObjectData.Length; i++)
+ for (int index = 0 ; index < count ; index++)
{
- handlerObjectGroupRequest(this, ogpack.AgentData.GroupID, ogpack.ObjectData[i].ObjectLocalID, UUID.Zero);
+ outPacket.ObjectData[index] = m_primFullUpdates[0];
+ m_primFullUpdates.RemoveAt(0);
}
+
+ outPacket.Header.Zerocoded = true;
+ OutPacket(outPacket, ThrottleOutPacketType.Task);
+
+ if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
}
- return true;
}
- private bool HandleViewerEffect(IClientAPI sender, Packet Pack)
+ ///
+ ///
+ ///
+ public void SendPrimTerseUpdate(ulong regionHandle, ushort timeDilation, uint localID, Vector3 position,
+ Quaternion rotation, Vector3 velocity, Vector3 rotationalvelocity, byte state, UUID AssetId, UUID ownerID, int attachPoint)
{
- ViewerEffectPacket viewer = (ViewerEffectPacket)Pack;
- if (viewer.AgentData.SessionID != SessionId) return false;
- handlerViewerEffect = OnViewerEffect;
- if (handlerViewerEffect != null)
+ if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
+ return;
+
+ if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
+ rotation = Quaternion.Identity;
+
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock objectData =
+ CreatePrimImprovedBlock(localID, position, rotation,
+ velocity, rotationalvelocity, state);
+
+ lock (m_primTerseUpdates)
{
- int length = viewer.Effect.Length;
- List args = new List(length);
- for (int i = 0; i < length; i++)
- {
- //copy the effects block arguments into the event handler arg.
- ViewerEffectEventHandlerArg argument = new ViewerEffectEventHandlerArg();
- argument.AgentID = viewer.Effect[i].AgentID;
- argument.Color = viewer.Effect[i].Color;
- argument.Duration = viewer.Effect[i].Duration;
- argument.ID = viewer.Effect[i].ID;
- argument.Type = viewer.Effect[i].Type;
- argument.TypeData = viewer.Effect[i].TypeData;
- args.Add(argument);
- }
+ if (m_primTerseUpdates.Count == 0)
+ m_primTerseUpdateTimer.Start();
- handlerViewerEffect(sender, args);
- }
+ m_primTerseUpdates.Add(objectData);
- return true;
+ if (m_primTerseUpdates.Count >= m_primTerseUpdatesPerPacket)
+ ProcessPrimTerseUpdates(this, null);
+ }
}
- public void SendScriptQuestion(UUID taskID, string taskName, string ownerName, UUID itemID, int question)
+ void ProcessPrimTerseUpdates(object sender, ElapsedEventArgs e)
{
- ScriptQuestionPacket scriptQuestion = (ScriptQuestionPacket)PacketPool.Instance.GetPacket(PacketType.ScriptQuestion);
- scriptQuestion.Data = new ScriptQuestionPacket.DataBlock();
- // TODO: don't create new blocks if recycling an old packet
- scriptQuestion.Data.TaskID = taskID;
- scriptQuestion.Data.ItemID = itemID;
- scriptQuestion.Data.Questions = question;
- scriptQuestion.Data.ObjectName = Utils.StringToBytes(taskName);
- scriptQuestion.Data.ObjectOwner = Utils.StringToBytes(ownerName);
+ lock (m_primTerseUpdates)
+ {
+ if (m_primTerseUpdates.Count == 0)
+ {
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
- OutPacket(scriptQuestion, ThrottleOutPacketType.Task);
+ return;
+ }
+
+ ImprovedTerseObjectUpdatePacket outPacket =
+ (ImprovedTerseObjectUpdatePacket)
+ PacketPool.Instance.GetPacket(
+ PacketType.ImprovedTerseObjectUpdate);
+
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
+
+ int max = m_primTerseUpdates.Count;
+ if (max > m_primTerseUpdatesPerPacket)
+ max = m_primTerseUpdatesPerPacket;
+
+ int count = 0;
+ int size = 0;
+
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
+
+ for (count = 0 ; count < max ; count++)
+ {
+ int length = 0;
+ m_primTerseUpdates[count].ToBytes(blockbuffer, ref length);
+ length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
+ if (size + length > m_packetMTU)
+ break;
+ size += length;
+ }
+
+ outPacket.ObjectData =
+ new ImprovedTerseObjectUpdatePacket.
+ ObjectDataBlock[count];
+
+ for (int index = 0 ; index < count ; index++)
+ {
+ outPacket.ObjectData[index] = m_primTerseUpdates[0];
+ m_primTerseUpdates.RemoveAt(0);
+ }
+
+ outPacket.Header.Reliable = false;
+ outPacket.Header.Zerocoded = true;
+ OutPacket(outPacket, ThrottleOutPacketType.Task);
+
+ if (m_primTerseUpdates.Count == 0)
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
+ }
}
- private void InitDefaultAnimations()
+ public void FlushPrimUpdates()
{
- using (XmlTextReader reader = new XmlTextReader("data/avataranimations.xml"))
+ while (m_primFullUpdates.Count > 0)
{
- XmlDocument doc = new XmlDocument();
- doc.Load(reader);
- if (doc.DocumentElement != null)
- foreach (XmlNode nod in doc.DocumentElement.ChildNodes)
- {
- if (nod.Attributes["name"] != null)
- {
- string name = nod.Attributes["name"].Value.ToLower();
- string id = nod.InnerText;
- m_defaultAnimations.Add(name, (UUID)id);
- }
- }
+ ProcessPrimFullUpdates(this, null);
+ }
+ while (m_primTerseUpdates.Count > 0)
+ {
+ ProcessPrimTerseUpdates(this, null);
+ }
+ while (m_avatarTerseUpdates.Count > 0)
+ {
+ ProcessAvatarTerseUpdates(this, null);
}
}
- public UUID GetDefaultAnimation(string name)
+ public void SendAssetUploadCompleteMessage(sbyte AssetType, bool Success, UUID AssetFullID)
{
- if (m_defaultAnimations.ContainsKey(name))
- return m_defaultAnimations[name];
- return UUID.Zero;
+ AssetUploadCompletePacket newPack = new AssetUploadCompletePacket();
+ newPack.AssetBlock.Type = AssetType;
+ newPack.AssetBlock.Success = Success;
+ newPack.AssetBlock.UUID = AssetFullID;
+ newPack.Header.Zerocoded = true;
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
}
- ///
- /// Handler called when we receive a logout packet.
- ///
- ///
- ///
- ///
- protected virtual bool Logout(IClientAPI client, Packet packet)
+ public void SendXferRequest(ulong XferID, short AssetType, UUID vFileID, byte FilePath, byte[] FileName)
{
- if (packet.Type == PacketType.LogoutRequest)
- {
- if (((LogoutRequestPacket)packet).AgentData.SessionID != SessionId) return false;
- }
-
- return Logout(client);
+ RequestXferPacket newPack = new RequestXferPacket();
+ newPack.XferID.ID = XferID;
+ newPack.XferID.VFileType = AssetType;
+ newPack.XferID.VFileID = vFileID;
+ newPack.XferID.FilePath = FilePath;
+ newPack.XferID.Filename = FileName;
+ newPack.Header.Zerocoded = true;
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
}
- ///
- ///
- ///
- ///
- ///
- protected virtual bool Logout(IClientAPI client)
+ public void SendConfirmXfer(ulong xferID, uint PacketID)
{
- m_log.InfoFormat("[CLIENT]: Got a logout request for {0} in {1}", Name, Scene.RegionInfo.RegionName);
-
- handlerLogout = OnLogout;
+ ConfirmXferPacketPacket newPack = new ConfirmXferPacketPacket();
+ newPack.XferID.ID = xferID;
+ newPack.XferID.Packet = PacketID;
+ newPack.Header.Zerocoded = true;
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
+ }
+
+ public void SendInitiateDownload(string simFileName, string clientFileName)
+ {
+ InitiateDownloadPacket newPack = new InitiateDownloadPacket();
+ newPack.AgentData.AgentID = AgentId;
+ newPack.FileData.SimFilename = Utils.StringToBytes(simFileName);
+ newPack.FileData.ViewerFilename = Utils.StringToBytes(clientFileName);
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
+ }
+
+ public void SendImageFirstPart(
+ ushort numParts, UUID ImageUUID, uint ImageSize, byte[] ImageData, byte imageCodec)
+ {
+ ImageDataPacket im = new ImageDataPacket();
+ im.Header.Reliable = false;
+ im.ImageID.Packets = numParts;
+ im.ImageID.ID = ImageUUID;
- if (handlerLogout != null)
- {
- handlerLogout(client);
- }
+ if (ImageSize > 0)
+ im.ImageID.Size = ImageSize;
- return true;
+ im.ImageData.Data = ImageData;
+ im.ImageID.Codec = imageCodec;
+ im.Header.Zerocoded = true;
+ OutPacket(im, ThrottleOutPacketType.Texture);
}
- ///
- /// Send a response back to a client when it asks the asset server (via the region server) if it has
- /// its appearance texture cached.
- ///
- /// At the moment, we always reply that there is no cached texture.
- ///
- ///
- ///
- ///
- protected bool AgentTextureCached(IClientAPI simclient, Packet packet)
+ public void SendImageNextPart(ushort partNumber, UUID imageUuid, byte[] imageData)
{
- //m_log.Debug("texture cached: " + packet.ToString());
- AgentCachedTexturePacket cachedtex = (AgentCachedTexturePacket)packet;
- AgentCachedTextureResponsePacket cachedresp = (AgentCachedTextureResponsePacket)PacketPool.Instance.GetPacket(PacketType.AgentCachedTextureResponse);
+ ImagePacketPacket im = new ImagePacketPacket();
+ im.Header.Reliable = false;
+ im.ImageID.Packet = partNumber;
+ im.ImageID.ID = imageUuid;
+ im.ImageData.Data = imageData;
- if (cachedtex.AgentData.SessionID != SessionId) return false;
+ OutPacket(im, ThrottleOutPacketType.Texture);
+ }
- // TODO: don't create new blocks if recycling an old packet
- cachedresp.AgentData.AgentID = AgentId;
- cachedresp.AgentData.SessionID = m_sessionId;
- cachedresp.AgentData.SerialNum = m_cachedTextureSerial;
- m_cachedTextureSerial++;
- cachedresp.WearableData =
- new AgentCachedTextureResponsePacket.WearableDataBlock[cachedtex.WearableData.Length];
+ public void SendImageNotFound(UUID imageid)
+ {
+ ImageNotInDatabasePacket notFoundPacket
+ = (ImageNotInDatabasePacket)PacketPool.Instance.GetPacket(PacketType.ImageNotInDatabase);
- for (int i = 0; i < cachedtex.WearableData.Length; i++)
- {
- cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
- cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
- cachedresp.WearableData[i].TextureID = UUID.Zero;
- cachedresp.WearableData[i].HostName = new byte[0];
- }
+ notFoundPacket.ImageID.ID = imageid;
- cachedresp.Header.Zerocoded = true;
- OutPacket(cachedresp, ThrottleOutPacketType.Task);
-
- return true;
+ OutPacket(notFoundPacket, ThrottleOutPacketType.Texture);
}
- protected bool MultipleObjUpdate(IClientAPI simClient, Packet packet)
+ public void SendShutdownConnectionNotice()
{
- MultipleObjectUpdatePacket multipleupdate = (MultipleObjectUpdatePacket)packet;
- if (multipleupdate.AgentData.SessionID != SessionId) return false;
- // m_log.Debug("new multi update packet " + multipleupdate.ToString());
- Scene tScene = (Scene)m_scene;
-
- for (int i = 0; i < multipleupdate.ObjectData.Length; i++)
- {
- MultipleObjectUpdatePacket.ObjectDataBlock block = multipleupdate.ObjectData[i];
+ OutPacket(PacketPool.Instance.GetPacket(PacketType.DisableSimulator), ThrottleOutPacketType.Unknown);
+ }
- // Can't act on Null Data
- if (block.Data != null)
- {
- uint localId = block.ObjectLocalID;
- SceneObjectPart part = tScene.GetSceneObjectPart(localId);
+ public void SendSimStats(SimStats stats)
+ {
+ SimStatsPacket pack = new SimStatsPacket();
+ pack.Region = new SimStatsPacket.RegionBlock();
+ pack.Region.RegionX = stats.RegionX;
+ pack.Region.RegionY = stats.RegionY;
+ pack.Region.RegionFlags = stats.RegionFlags;
+ pack.Region.ObjectCapacity = stats.ObjectCapacity;
+ //pack.Region = //stats.RegionBlock;
+ pack.Stat = stats.StatsBlock;
- if (part == null)
- {
- // It's a ghost! tell the client to delete it from view.
- simClient.SendKillObject(Scene.RegionInfo.RegionHandle,
- localId);
- }
- else
- {
- // UUID partId = part.UUID;
- UpdatePrimGroupRotation handlerUpdatePrimGroupRotation;
+ pack.Header.Reliable = false;
- switch (block.Type)
- {
- case 1:
- Vector3 pos1 = new Vector3(block.Data, 0);
+ OutPacket(pack, ThrottleOutPacketType.Task);
+ }
- handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
- if (handlerUpdatePrimSinglePosition != null)
- {
- // m_log.Debug("new movement position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
- handlerUpdatePrimSinglePosition(localId, pos1, this);
- }
- break;
- case 2:
- Quaternion rot1 = new Quaternion(block.Data, 0, true);
+ public void SendObjectPropertiesFamilyData(uint RequestFlags, UUID ObjectUUID, UUID OwnerID, UUID GroupID,
+ uint BaseMask, uint OwnerMask, uint GroupMask, uint EveryoneMask,
+ uint NextOwnerMask, int OwnershipCost, byte SaleType, int SalePrice, uint Category,
+ UUID LastOwnerID, string ObjectName, string Description)
+ {
+ ObjectPropertiesFamilyPacket objPropFamilyPack = (ObjectPropertiesFamilyPacket)PacketPool.Instance.GetPacket(PacketType.ObjectPropertiesFamily);
+ // TODO: don't create new blocks if recycling an old packet
- handlerUpdatePrimSingleRotation = OnUpdatePrimSingleRotation;
- if (handlerUpdatePrimSingleRotation != null)
- {
- // m_log.Info("new tab rotation is " + rot1.X + " , " + rot1.Y + " , " + rot1.Z + " , " + rot1.W);
- handlerUpdatePrimSingleRotation(localId, rot1, this);
- }
- break;
- case 3:
- Vector3 rotPos = new Vector3(block.Data, 0);
- Quaternion rot2 = new Quaternion(block.Data, 12, true);
+ ObjectPropertiesFamilyPacket.ObjectDataBlock objPropDB = new ObjectPropertiesFamilyPacket.ObjectDataBlock();
+ objPropDB.RequestFlags = RequestFlags;
+ objPropDB.ObjectID = ObjectUUID;
+ if (OwnerID == GroupID)
+ objPropDB.OwnerID = UUID.Zero;
+ else
+ objPropDB.OwnerID = OwnerID;
+ objPropDB.GroupID = GroupID;
+ objPropDB.BaseMask = BaseMask;
+ objPropDB.OwnerMask = OwnerMask;
+ objPropDB.GroupMask = GroupMask;
+ objPropDB.EveryoneMask = EveryoneMask;
+ objPropDB.NextOwnerMask = NextOwnerMask;
- handlerUpdatePrimSingleRotationPosition = OnUpdatePrimSingleRotationPosition;
- if (handlerUpdatePrimSingleRotationPosition != null)
- {
- // m_log.Debug("new mouse rotation position is " + rotPos.X + " , " + rotPos.Y + " , " + rotPos.Z);
- // m_log.Info("new mouse rotation is " + rot2.X + " , " + rot2.Y + " , " + rot2.Z + " , " + rot2.W);
- handlerUpdatePrimSingleRotationPosition(localId, rot2, rotPos, this);
- }
- break;
- case 4:
- case 20:
- Vector3 scale4 = new Vector3(block.Data, 0);
+ // TODO: More properties are needed in SceneObjectPart!
+ objPropDB.OwnershipCost = OwnershipCost;
+ objPropDB.SaleType = SaleType;
+ objPropDB.SalePrice = SalePrice;
+ objPropDB.Category = Category;
+ objPropDB.LastOwnerID = LastOwnerID;
+ objPropDB.Name = LLUtil.StringToPacketBytes(ObjectName);
+ objPropDB.Description = LLUtil.StringToPacketBytes(Description);
+ objPropFamilyPack.ObjectData = objPropDB;
+ objPropFamilyPack.Header.Zerocoded = true;
+ OutPacket(objPropFamilyPack, ThrottleOutPacketType.Task);
+ }
- handlerUpdatePrimScale = OnUpdatePrimScale;
- if (handlerUpdatePrimScale != null)
- {
-// m_log.Debug("new scale is " + scale4.X + " , " + scale4.Y + " , " + scale4.Z);
- handlerUpdatePrimScale(localId, scale4, this);
- }
- break;
- case 5:
+ public void SendObjectPropertiesReply(
+ UUID ItemID, ulong CreationDate, UUID CreatorUUID, UUID FolderUUID, UUID FromTaskUUID,
+ UUID GroupUUID, short InventorySerial, UUID LastOwnerUUID, UUID ObjectUUID,
+ UUID OwnerUUID, string TouchTitle, byte[] TextureID, string SitTitle, string ItemName,
+ string ItemDescription, uint OwnerMask, uint NextOwnerMask, uint GroupMask, uint EveryoneMask,
+ uint BaseMask, byte saleType, int salePrice)
+ {
+ ObjectPropertiesPacket proper = (ObjectPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ObjectProperties);
+ // TODO: don't create new blocks if recycling an old packet
- Vector3 scale1 = new Vector3(block.Data, 12);
- Vector3 pos11 = new Vector3(block.Data, 0);
+ proper.ObjectData = new ObjectPropertiesPacket.ObjectDataBlock[1];
+ proper.ObjectData[0] = new ObjectPropertiesPacket.ObjectDataBlock();
+ proper.ObjectData[0].ItemID = ItemID;
+ proper.ObjectData[0].CreationDate = CreationDate;
+ proper.ObjectData[0].CreatorID = CreatorUUID;
+ proper.ObjectData[0].FolderID = FolderUUID;
+ proper.ObjectData[0].FromTaskID = FromTaskUUID;
+ proper.ObjectData[0].GroupID = GroupUUID;
+ proper.ObjectData[0].InventorySerial = InventorySerial;
- handlerUpdatePrimScale = OnUpdatePrimScale;
- if (handlerUpdatePrimScale != null)
- {
- // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
- handlerUpdatePrimScale(localId, scale1, this);
+ proper.ObjectData[0].LastOwnerID = LastOwnerUUID;
+ // proper.ObjectData[0].LastOwnerID = UUID.Zero;
- handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
- if (handlerUpdatePrimSinglePosition != null)
- {
- handlerUpdatePrimSinglePosition(localId, pos11, this);
- }
- }
- break;
- case 9:
- Vector3 pos2 = new Vector3(block.Data, 0);
+ proper.ObjectData[0].ObjectID = ObjectUUID;
+ if (OwnerUUID == GroupUUID)
+ proper.ObjectData[0].OwnerID = UUID.Zero;
+ else
+ proper.ObjectData[0].OwnerID = OwnerUUID;
+ proper.ObjectData[0].TouchName = LLUtil.StringToPacketBytes(TouchTitle);
+ proper.ObjectData[0].TextureID = TextureID;
+ proper.ObjectData[0].SitName = LLUtil.StringToPacketBytes(SitTitle);
+ proper.ObjectData[0].Name = LLUtil.StringToPacketBytes(ItemName);
+ proper.ObjectData[0].Description = LLUtil.StringToPacketBytes(ItemDescription);
+ proper.ObjectData[0].OwnerMask = OwnerMask;
+ proper.ObjectData[0].NextOwnerMask = NextOwnerMask;
+ proper.ObjectData[0].GroupMask = GroupMask;
+ proper.ObjectData[0].EveryoneMask = EveryoneMask;
+ proper.ObjectData[0].BaseMask = BaseMask;
+ // proper.ObjectData[0].AggregatePerms = 53;
+ // proper.ObjectData[0].AggregatePermTextures = 0;
+ // proper.ObjectData[0].AggregatePermTexturesOwner = 0;
+ proper.ObjectData[0].SaleType = saleType;
+ proper.ObjectData[0].SalePrice = salePrice;
+ proper.Header.Zerocoded = true;
+ OutPacket(proper, ThrottleOutPacketType.Task);
+ }
- handlerUpdateVector = OnUpdatePrimGroupPosition;
+ #endregion
- if (handlerUpdateVector != null)
- {
+ #region Estate Data Sending Methods
- handlerUpdateVector(localId, pos2, this);
- }
- break;
- case 10:
- Quaternion rot3 = new Quaternion(block.Data, 0, true);
+ private static bool convertParamStringToBool(byte[] field)
+ {
+ string s = Utils.BytesToString(field);
+ if (s == "1" || s.ToLower() == "y" || s.ToLower() == "yes" || s.ToLower() == "t" || s.ToLower() == "true")
+ {
+ return true;
+ }
+ return false;
+ }
- handlerUpdatePrimRotation = OnUpdatePrimGroupRotation;
- if (handlerUpdatePrimRotation != null)
- {
- // Console.WriteLine("new rotation is " + rot3.X + " , " + rot3.Y + " , " + rot3.Z + " , " + rot3.W);
- handlerUpdatePrimRotation(localId, rot3, this);
- }
- break;
- case 11:
- Vector3 pos3 = new Vector3(block.Data, 0);
- Quaternion rot4 = new Quaternion(block.Data, 12, true);
+ public void SendEstateManagersList(UUID invoice, UUID[] EstateManagers, uint estateID)
+ {
+ EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
+ packet.AgentData.TransactionID = UUID.Random();
+ packet.AgentData.AgentID = AgentId;
+ packet.AgentData.SessionID = SessionId;
+ packet.MethodData.Invoice = invoice;
+ packet.MethodData.Method = Utils.StringToBytes("setaccess");
- handlerUpdatePrimGroupRotation = OnUpdatePrimGroupMouseRotation;
- if (handlerUpdatePrimGroupRotation != null)
- {
- // m_log.Debug("new rotation position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
- // m_log.Debug("new group mouse rotation is " + rot4.X + " , " + rot4.Y + " , " + rot4.Z + " , " + rot4.W);
- handlerUpdatePrimGroupRotation(localId, pos3, rot4, this);
- }
- break;
- case 12:
- case 28:
- Vector3 scale7 = new Vector3(block.Data, 0);
+ EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + EstateManagers.Length];
- handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
- if (handlerUpdatePrimGroupScale != null)
- {
-// m_log.Debug("new scale is " + scale7.X + " , " + scale7.Y + " , " + scale7.Z);
- handlerUpdatePrimGroupScale(localId, scale7, this);
- }
- break;
- case 13:
- Vector3 scale2 = new Vector3(block.Data, 12);
- Vector3 pos4 = new Vector3(block.Data, 0);
+ for (int i = 0; i < (6 + EstateManagers.Length); i++)
+ {
+ returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
+ }
+ int j = 0;
- handlerUpdatePrimScale = OnUpdatePrimScale;
- if (handlerUpdatePrimScale != null)
- {
- //m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
- handlerUpdatePrimScale(localId, scale2, this);
+ returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateManagers).ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(EstateManagers.Length.ToString()); j++;
+ for (int i = 0; i < EstateManagers.Length; i++)
+ {
+ returnblock[j].Parameter = EstateManagers[i].GetBytes(); j++;
+ }
+ packet.ParamList = returnblock;
+ packet.Header.Reliable = false;
+ OutPacket(packet, ThrottleOutPacketType.Task);
+ }
- // Change the position based on scale (for bug number 246)
- handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
- // m_log.Debug("new movement position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
- if (handlerUpdatePrimSinglePosition != null)
- {
- handlerUpdatePrimSinglePosition(localId, pos4, this);
- }
- }
- break;
- case 29:
- Vector3 scale5 = new Vector3(block.Data, 12);
- Vector3 pos5 = new Vector3(block.Data, 0);
-
- handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
- if (handlerUpdatePrimGroupScale != null)
- {
- // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
- handlerUpdatePrimGroupScale(localId, scale5, this);
- handlerUpdateVector = OnUpdatePrimGroupPosition;
-
- if (handlerUpdateVector != null)
- {
- handlerUpdateVector(localId, pos5, this);
- }
- }
- break;
- case 21:
- Vector3 scale6 = new Vector3(block.Data, 12);
- Vector3 pos6 = new Vector3(block.Data, 0);
+ public void SendBannedUserList(UUID invoice, EstateBan[] bl, uint estateID)
+ {
+ ListBannedUsers = new List();
- handlerUpdatePrimScale = OnUpdatePrimScale;
- if (handlerUpdatePrimScale != null)
- {
- // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
- handlerUpdatePrimScale(localId, scale6, this);
- handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
- if (handlerUpdatePrimSinglePosition != null)
- {
- handlerUpdatePrimSinglePosition(localId, pos6, this);
- }
- }
- break;
- default:
- m_log.Debug("[CLIENT] MultipleObjUpdate recieved an unknown packet type: " + (block.Type));
- break;
- }
- }
- }
+ for (int i = 0; i < bl.Length; i++)
+ {
+ if (bl[i] == null)
+ continue;
+ if (bl[i].BannedUserID == UUID.Zero)
+ continue;
+ BannedUsers.Add(bl[i].BannedUserID);
}
- return true;
- }
- public void RequestMapLayer()
- {
- //should be getting the map layer from the grid server
- //send a layer covering the 800,800 - 1200,1200 area (should be covering the requested area)
- MapLayerReplyPacket mapReply = (MapLayerReplyPacket)PacketPool.Instance.GetPacket(PacketType.MapLayerReply);
- // TODO: don't create new blocks if recycling an old packet
- mapReply.AgentData.AgentID = AgentId;
- mapReply.AgentData.Flags = 0;
- mapReply.LayerData = new MapLayerReplyPacket.LayerDataBlock[1];
- mapReply.LayerData[0] = new MapLayerReplyPacket.LayerDataBlock();
- mapReply.LayerData[0].Bottom = 0;
- mapReply.LayerData[0].Left = 0;
- mapReply.LayerData[0].Top = 30000;
- mapReply.LayerData[0].Right = 30000;
- mapReply.LayerData[0].ImageID = new UUID("00000000-0000-1111-9999-000000000006");
- mapReply.Header.Zerocoded = true;
- OutPacket(mapReply, ThrottleOutPacketType.Land);
- }
+ EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
+ packet.AgentData.TransactionID = UUID.Random();
+ packet.AgentData.AgentID = AgentId;
+ packet.AgentData.SessionID = SessionId;
+ packet.MethodData.Invoice = invoice;
+ packet.MethodData.Method = Utils.StringToBytes("setaccess");
- public void RequestMapBlocksX(int minX, int minY, int maxX, int maxY)
- {
- /*
- IList simMapProfiles = m_gridServer.RequestMapBlocks(minX, minY, maxX, maxY);
- MapBlockReplyPacket mbReply = new MapBlockReplyPacket();
- mbReply.AgentData.AgentId = AgentId;
- int len;
- if (simMapProfiles == null)
- len = 0;
- else
- len = simMapProfiles.Count;
+ EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + BannedUsers.Count];
- mbReply.Data = new MapBlockReplyPacket.DataBlock[len];
- int iii;
- for (iii = 0; iii < len; iii++)
+ for (int i = 0; i < (6 + BannedUsers.Count); i++)
{
- Hashtable mp = (Hashtable)simMapProfiles[iii];
- mbReply.Data[iii] = new MapBlockReplyPacket.DataBlock();
- mbReply.Data[iii].Name = Util.UTF8.GetBytes((string)mp["name"]);
- mbReply.Data[iii].Access = System.Convert.ToByte(mp["access"]);
- mbReply.Data[iii].Agents = System.Convert.ToByte(mp["agents"]);
- mbReply.Data[iii].MapImageID = new UUID((string)mp["map-image-id"]);
- mbReply.Data[iii].RegionFlags = System.Convert.ToUInt32(mp["region-flags"]);
- mbReply.Data[iii].WaterHeight = System.Convert.ToByte(mp["water-height"]);
- mbReply.Data[iii].X = System.Convert.ToUInt16(mp["x"]);
- mbReply.Data[iii].Y = System.Convert.ToUInt16(mp["y"]);
+ returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
}
- this.OutPacket(mbReply, ThrottleOutPacketType.Land);
- */
- }
-
- ///
- /// returns a byte array of the client set throttles Gets multiplied by the multiplier
- ///
- ///
- /// non 1 multiplier for subdividing the throttles between individual regions
- ///
- public byte[] GetThrottlesPacked(float multiplier)
- {
- return m_PacketHandler.PacketQueue.GetThrottlesPacked(multiplier);
- }
- ///
- /// sets the throttles from values supplied by the client
- ///
- ///
- public void SetChildAgentThrottle(byte[] throttles)
- {
- m_PacketHandler.PacketQueue.SetThrottleFromClient(throttles);
- }
-
- ///
- /// Method gets called when a new packet has arrived from the UDP
- /// server. This happens after it's been decoded into a libsl object.
- ///
- /// object containing the packet.
- public virtual void InPacket(object NewPack)
- {
- // Cast NewPack to Packet.
- m_PacketHandler.InPacket((Packet) NewPack);
- }
+ int j = 0;
- ///
- /// This is the starting point for sending a simulator packet out to the client.
- ///
- /// Please do not call this from outside the LindenUDP client stack.
- ///
- ///
- /// Corresponds to the type of data that is going out. Enum
- public void OutPacket(Packet NewPack, ThrottleOutPacketType throttlePacketType)
- {
- m_PacketHandler.OutPacket(NewPack, throttlePacketType);
- }
+ returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateBans).ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(BannedUsers.Count.ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- public bool AddMoney(int debit)
- {
- if (m_moneyBalance + debit >= 0)
+ foreach (UUID banned in BannedUsers)
{
- m_moneyBalance += debit;
- SendMoneyBalance(UUID.Zero, true, Utils.StringToBytes("Poof Poof!"), m_moneyBalance);
- return true;
+ returnblock[j].Parameter = banned.GetBytes(); j++;
}
- return false;
+ packet.ParamList = returnblock;
+ packet.Header.Reliable = false;
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- ///
- /// Breaks down the genericMessagePacket into specific events
- ///
- ///
- ///
- ///
- public void DecipherGenericMessage(string gmMethod, UUID gmInvoice, GenericMessagePacket.ParamListBlock[] gmParams)
+ public void SendRegionInfoToEstateMenu(RegionInfoForEstateMenuArgs args)
{
- switch (gmMethod)
- {
- case "autopilot":
- float locx;
- float locy;
- float locz;
-
- try
- {
- uint regionX;
- uint regionY;
- Utils.LongToUInts(Scene.RegionInfo.RegionHandle, out regionX, out regionY);
- locx = Convert.ToSingle(Utils.BytesToString(gmParams[0].Parameter)) - regionX;
- locy = Convert.ToSingle(Utils.BytesToString(gmParams[1].Parameter)) - regionY;
- locz = Convert.ToSingle(Utils.BytesToString(gmParams[2].Parameter));
- }
- catch (InvalidCastException)
- {
- m_log.Error("[CLIENT]: Invalid autopilot request");
- return;
- }
+ RegionInfoPacket rinfopack = new RegionInfoPacket();
+ RegionInfoPacket.RegionInfoBlock rinfoblk = new RegionInfoPacket.RegionInfoBlock();
+ rinfopack.AgentData.AgentID = AgentId;
+ rinfopack.AgentData.SessionID = SessionId;
+ rinfoblk.BillableFactor = args.billableFactor;
+ rinfoblk.EstateID = args.estateID;
+ rinfoblk.MaxAgents = args.maxAgents;
+ rinfoblk.ObjectBonusFactor = args.objectBonusFactor;
+ rinfoblk.ParentEstateID = args.parentEstateID;
+ rinfoblk.PricePerMeter = args.pricePerMeter;
+ rinfoblk.RedirectGridX = args.redirectGridX;
+ rinfoblk.RedirectGridY = args.redirectGridY;
+ rinfoblk.RegionFlags = args.regionFlags;
+ rinfoblk.SimAccess = args.simAccess;
+ rinfoblk.SunHour = args.sunHour;
+ rinfoblk.TerrainLowerLimit = args.terrainLowerLimit;
+ rinfoblk.TerrainRaiseLimit = args.terrainRaiseLimit;
+ rinfoblk.UseEstateSun = args.useEstateSun;
+ rinfoblk.WaterHeight = args.waterHeight;
+ rinfoblk.SimName = Utils.StringToBytes(args.simName);
+
+ rinfopack.RegionInfo2 = new RegionInfoPacket.RegionInfo2Block();
+ rinfopack.RegionInfo2.HardMaxAgents = uint.MaxValue;
+ rinfopack.RegionInfo2.HardMaxObjects = uint.MaxValue;
+ rinfopack.RegionInfo2.MaxAgents32 = uint.MaxValue;
+ rinfopack.RegionInfo2.ProductName = Utils.EmptyBytes;
+ rinfopack.RegionInfo2.ProductSKU = Utils.EmptyBytes;
- handlerAutoPilotGo = OnAutoPilotGo;
- if (handlerAutoPilotGo != null)
- {
- handlerAutoPilotGo(0, new Vector3(locx, locy, locz), this);
- }
- m_log.InfoFormat("[CLIENT]: Client Requests autopilot to position <{0},{1},{2}>", locx, locy, locz);
+ rinfopack.HasVariableBlocks = true;
+ rinfopack.RegionInfo = rinfoblk;
+ rinfopack.AgentData = new RegionInfoPacket.AgentDataBlock();
+ rinfopack.AgentData.AgentID = AgentId;
+ rinfopack.AgentData.SessionID = SessionId;
- break;
- default:
- m_log.Debug("[CLIENT]: Unknown Generic Message, Method: " + gmMethod + ". Invoice: " + gmInvoice + ". Dumping Params:");
- for (int hi = 0; hi < gmParams.Length; hi++)
- {
- Console.WriteLine(gmParams[hi].ToString());
- }
- //gmpack.MethodData.
- break;
+ OutPacket(rinfopack, ThrottleOutPacketType.Task);
+ }
- }
+ public void SendEstateCovenantInformation(UUID covenant)
+ {
+ EstateCovenantReplyPacket einfopack = new EstateCovenantReplyPacket();
+ EstateCovenantReplyPacket.DataBlock edata = new EstateCovenantReplyPacket.DataBlock();
+ edata.CovenantID = covenant;
+ edata.CovenantTimestamp = 0;
+ if (m_scene.RegionInfo.EstateSettings.EstateOwner != UUID.Zero)
+ edata.EstateOwnerID = m_scene.RegionInfo.EstateSettings.EstateOwner;
+ else
+ edata.EstateOwnerID = m_scene.RegionInfo.MasterAvatarAssignedUUID;
+ edata.EstateName = Utils.StringToBytes(m_scene.RegionInfo.EstateSettings.EstateName);
+ einfopack.Data = edata;
+ OutPacket(einfopack, ThrottleOutPacketType.Task);
}
- ///
- /// Entryway from the client to the simulator. All UDP packets from the client will end up here
- ///
- /// OpenMetaverse.packet
- public void ProcessInPacket(Packet Pack)
+ public void SendDetailedEstateData(UUID invoice, string estateName, uint estateID, uint parentEstate, uint estateFlags, uint sunPosition, UUID covenant, string abuseEmail, UUID estateOwner)
{
+ EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
+ packet.MethodData.Invoice = invoice;
+ packet.AgentData.TransactionID = UUID.Random();
+ packet.MethodData.Method = Utils.StringToBytes("estateupdateinfo");
+ EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[10];
- if (ProcessPacketMethod(Pack))
+ for (int i = 0; i < 10; i++)
{
- return;
+ returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
}
- const bool m_checkPackets = true;
-
- // Main packet processing conditional
- switch (Pack.Type)
- {
- #region Scene/Avatar
-
- case PacketType.AvatarPropertiesRequest:
- AvatarPropertiesRequestPacket avatarProperties = (AvatarPropertiesRequestPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (avatarProperties.AgentData.SessionID != SessionId ||
- avatarProperties.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ //Sending Estate Settings
+ returnblock[0].Parameter = Utils.StringToBytes(estateName);
+ // TODO: remove this cruft once MasterAvatar is fully deprecated
+ //
+ returnblock[1].Parameter = Utils.StringToBytes(estateOwner.ToString());
+ returnblock[2].Parameter = Utils.StringToBytes(estateID.ToString());
- handlerRequestAvatarProperties = OnRequestAvatarProperties;
- if (handlerRequestAvatarProperties != null)
- {
- handlerRequestAvatarProperties(this, avatarProperties.AgentData.AvatarID);
- }
+ returnblock[3].Parameter = Utils.StringToBytes(estateFlags.ToString());
+ returnblock[4].Parameter = Utils.StringToBytes(sunPosition.ToString());
+ returnblock[5].Parameter = Utils.StringToBytes(parentEstate.ToString());
+ returnblock[6].Parameter = Utils.StringToBytes(covenant.ToString());
+ returnblock[7].Parameter = Utils.StringToBytes("1160895077"); // what is this?
+ returnblock[8].Parameter = Utils.StringToBytes("1"); // what is this?
+ returnblock[9].Parameter = Utils.StringToBytes(abuseEmail);
- break;
+ packet.ParamList = returnblock;
+ packet.Header.Reliable = false;
+ //m_log.Debug("[ESTATE]: SIM--->" + packet.ToString());
+ OutPacket(packet, ThrottleOutPacketType.Task);
+ }
- case PacketType.ChatFromViewer:
- ChatFromViewerPacket inchatpack = (ChatFromViewerPacket)Pack;
+ #endregion
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (inchatpack.AgentData.SessionID != SessionId ||
- inchatpack.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ #region Land Data Sending Methods
- string fromName = String.Empty; //ClientAvatar.firstname + " " + ClientAvatar.lastname;
- byte[] message = inchatpack.ChatData.Message;
- byte type = inchatpack.ChatData.Type;
- Vector3 fromPos = new Vector3(); // ClientAvatar.Pos;
- // UUID fromAgentID = AgentId;
+ public void SendLandParcelOverlay(byte[] data, int sequence_id)
+ {
+ ParcelOverlayPacket packet = (ParcelOverlayPacket)PacketPool.Instance.GetPacket(PacketType.ParcelOverlay);
+ packet.ParcelData.Data = data;
+ packet.ParcelData.SequenceID = sequence_id;
+ packet.Header.Zerocoded = true;
+ OutPacket(packet, ThrottleOutPacketType.Task);
+ }
- int channel = inchatpack.ChatData.Channel;
+ public void SendLandProperties(int sequence_id, bool snap_selection, int request_result, LandData landData, float simObjectBonusFactor, int parcelObjectCapacity, int simObjectCapacity, uint regionFlags)
+ {
+ ParcelPropertiesPacket updatePacket = (ParcelPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ParcelProperties);
+ // TODO: don't create new blocks if recycling an old packet
- if (OnChatFromClient != null)
- {
- OSChatMessage args = new OSChatMessage();
- args.Channel = channel;
- args.From = fromName;
- args.Message = Utils.BytesToString(message);
- args.Type = (ChatTypeEnum)type;
- args.Position = fromPos;
+ updatePacket.ParcelData.AABBMax = landData.AABBMax;
+ updatePacket.ParcelData.AABBMin = landData.AABBMin;
+ updatePacket.ParcelData.Area = landData.Area;
+ updatePacket.ParcelData.AuctionID = landData.AuctionID;
+ updatePacket.ParcelData.AuthBuyerID = landData.AuthBuyerID;
- args.Scene = Scene;
- args.Sender = this;
- args.SenderUUID = this.AgentId;
+ updatePacket.ParcelData.Bitmap = landData.Bitmap;
- handlerChatFromClient = OnChatFromClient;
- if (handlerChatFromClient != null)
- handlerChatFromClient(this, args);
- }
- break;
+ updatePacket.ParcelData.Desc = Utils.StringToBytes(landData.Description);
+ updatePacket.ParcelData.Category = (byte)landData.Category;
+ updatePacket.ParcelData.ClaimDate = landData.ClaimDate;
+ updatePacket.ParcelData.ClaimPrice = landData.ClaimPrice;
+ updatePacket.ParcelData.GroupID = landData.GroupID;
+ updatePacket.ParcelData.GroupPrims = landData.GroupPrims;
+ updatePacket.ParcelData.IsGroupOwned = landData.IsGroupOwned;
+ updatePacket.ParcelData.LandingType = landData.LandingType;
+ updatePacket.ParcelData.LocalID = landData.LocalID;
- case PacketType.AvatarPropertiesUpdate:
- AvatarPropertiesUpdatePacket avatarProps = (AvatarPropertiesUpdatePacket)Pack;
+ if (landData.Area > 0)
+ {
+ updatePacket.ParcelData.MaxPrims = parcelObjectCapacity;
+ }
+ else
+ {
+ updatePacket.ParcelData.MaxPrims = 0;
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (avatarProps.AgentData.SessionID != SessionId ||
- avatarProps.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ updatePacket.ParcelData.MediaAutoScale = landData.MediaAutoScale;
+ updatePacket.ParcelData.MediaID = landData.MediaID;
+ updatePacket.ParcelData.MediaURL = LLUtil.StringToPacketBytes(landData.MediaURL);
+ updatePacket.ParcelData.MusicURL = LLUtil.StringToPacketBytes(landData.MusicURL);
+ updatePacket.ParcelData.Name = Utils.StringToBytes(landData.Name);
+ updatePacket.ParcelData.OtherCleanTime = landData.OtherCleanTime;
+ updatePacket.ParcelData.OtherCount = 0; //unemplemented
+ updatePacket.ParcelData.OtherPrims = landData.OtherPrims;
+ updatePacket.ParcelData.OwnerID = landData.OwnerID;
+ updatePacket.ParcelData.OwnerPrims = landData.OwnerPrims;
+ updatePacket.ParcelData.ParcelFlags = landData.Flags;
+ updatePacket.ParcelData.ParcelPrimBonus = simObjectBonusFactor;
+ updatePacket.ParcelData.PassHours = landData.PassHours;
+ updatePacket.ParcelData.PassPrice = landData.PassPrice;
+ updatePacket.ParcelData.PublicCount = 0; //unemplemented
- handlerUpdateAvatarProperties = OnUpdateAvatarProperties;
- if (handlerUpdateAvatarProperties != null)
- {
- AvatarPropertiesUpdatePacket.PropertiesDataBlock Properties = avatarProps.PropertiesData;
- UserProfileData UserProfile = new UserProfileData();
- UserProfile.ID = AgentId;
- UserProfile.AboutText = Utils.BytesToString(Properties.AboutText);
- UserProfile.FirstLifeAboutText = Utils.BytesToString(Properties.FLAboutText);
- UserProfile.FirstLifeImage = Properties.FLImageID;
- UserProfile.Image = Properties.ImageID;
- UserProfile.ProfileUrl = Utils.BytesToString(Properties.ProfileURL);
+ updatePacket.ParcelData.RegionDenyAnonymous = ((regionFlags & (uint)RegionFlags.DenyAnonymous) >
+ 0);
+ updatePacket.ParcelData.RegionDenyIdentified = ((regionFlags & (uint)RegionFlags.DenyIdentified) >
+ 0);
+ updatePacket.ParcelData.RegionDenyTransacted = ((regionFlags & (uint)RegionFlags.DenyTransacted) >
+ 0);
+ updatePacket.ParcelData.RegionPushOverride = ((regionFlags & (uint)RegionFlags.RestrictPushObject) >
+ 0);
- handlerUpdateAvatarProperties(this, UserProfile);
- }
- break;
+ updatePacket.ParcelData.RentPrice = 0;
+ updatePacket.ParcelData.RequestResult = request_result;
+ updatePacket.ParcelData.SalePrice = landData.SalePrice;
+ updatePacket.ParcelData.SelectedPrims = landData.SelectedPrims;
+ updatePacket.ParcelData.SelfCount = 0; //unemplemented
+ updatePacket.ParcelData.SequenceID = sequence_id;
+ if (landData.SimwideArea > 0)
+ {
+ updatePacket.ParcelData.SimWideMaxPrims = parcelObjectCapacity;
+ }
+ else
+ {
+ updatePacket.ParcelData.SimWideMaxPrims = 0;
+ }
+ updatePacket.ParcelData.SimWideTotalPrims = landData.SimwidePrims;
+ updatePacket.ParcelData.SnapSelection = snap_selection;
+ updatePacket.ParcelData.SnapshotID = landData.SnapshotID;
+ updatePacket.ParcelData.Status = (byte)landData.Status;
+ updatePacket.ParcelData.TotalPrims = landData.OwnerPrims + landData.GroupPrims + landData.OtherPrims +
+ landData.SelectedPrims;
+ updatePacket.ParcelData.UserLocation = landData.UserLocation;
+ updatePacket.ParcelData.UserLookAt = landData.UserLookAt;
+ updatePacket.Header.Zerocoded = true;
- case PacketType.ScriptDialogReply:
- ScriptDialogReplyPacket rdialog = (ScriptDialogReplyPacket)Pack;
+ try
+ {
+ IEventQueue eq = Scene.RequestModuleInterface();
+ if (eq != null)
+ {
+ eq.ParcelProperties(updatePacket, this.AgentId);
+ }
+ }
+ catch (Exception ex)
+ {
+ m_log.Error("Unable to send parcel data via eventqueue - exception: " + ex.ToString());
+ m_log.Warn("sending parcel data via UDP");
+ OutPacket(updatePacket, ThrottleOutPacketType.Task);
+ }
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (rdialog.AgentData.SessionID != SessionId ||
- rdialog.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ public void SendLandAccessListData(List avatars, uint accessFlag, int localLandID)
+ {
+ ParcelAccessListReplyPacket replyPacket = (ParcelAccessListReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelAccessListReply);
+ replyPacket.Data.AgentID = AgentId;
+ replyPacket.Data.Flags = accessFlag;
+ replyPacket.Data.LocalID = localLandID;
+ replyPacket.Data.SequenceID = 0;
- int ch = rdialog.Data.ChatChannel;
- byte[] msg = rdialog.Data.ButtonLabel;
- if (OnChatFromClient != null)
- {
- OSChatMessage args = new OSChatMessage();
- args.Channel = ch;
- args.From = String.Empty;
- args.Message = Utils.BytesToString(msg);
- args.Type = ChatTypeEnum.Shout;
- args.Position = new Vector3();
- args.Scene = Scene;
- args.Sender = this;
- handlerChatFromClient2 = OnChatFromClient;
- if (handlerChatFromClient2 != null)
- handlerChatFromClient2(this, args);
- }
+ List list = new List();
+ foreach (UUID avatar in avatars)
+ {
+ ParcelAccessListReplyPacket.ListBlock block = new ParcelAccessListReplyPacket.ListBlock();
+ block.Flags = accessFlag;
+ block.ID = avatar;
+ block.Time = 0;
+ list.Add(block);
+ }
- break;
+ replyPacket.List = list.ToArray();
+ replyPacket.Header.Zerocoded = true;
+ OutPacket(replyPacket, ThrottleOutPacketType.Task);
+ }
- case PacketType.ImprovedInstantMessage:
- ImprovedInstantMessagePacket msgpack = (ImprovedInstantMessagePacket)Pack;
+ public void SendForceClientSelectObjects(List ObjectIDs)
+ {
+ bool firstCall = true;
+ const int MAX_OBJECTS_PER_PACKET = 251;
+ ForceObjectSelectPacket pack = (ForceObjectSelectPacket)PacketPool.Instance.GetPacket(PacketType.ForceObjectSelect);
+ ForceObjectSelectPacket.DataBlock[] data;
+ while (ObjectIDs.Count > 0)
+ {
+ if (firstCall)
+ {
+ pack._Header.ResetList = true;
+ firstCall = false;
+ }
+ else
+ {
+ pack._Header.ResetList = false;
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (msgpack.AgentData.SessionID != SessionId ||
- msgpack.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ if (ObjectIDs.Count > MAX_OBJECTS_PER_PACKET)
+ {
+ data = new ForceObjectSelectPacket.DataBlock[MAX_OBJECTS_PER_PACKET];
+ }
+ else
+ {
+ data = new ForceObjectSelectPacket.DataBlock[ObjectIDs.Count];
+ }
- string IMfromName = Util.FieldToString(msgpack.MessageBlock.FromAgentName);
- string IMmessage = Utils.BytesToString(msgpack.MessageBlock.Message);
- handlerInstantMessage = OnInstantMessage;
+ int i;
+ for (i = 0; i < MAX_OBJECTS_PER_PACKET && ObjectIDs.Count > 0; i++)
+ {
+ data[i] = new ForceObjectSelectPacket.DataBlock();
+ data[i].LocalID = Convert.ToUInt32(ObjectIDs[0]);
+ ObjectIDs.RemoveAt(0);
+ }
+ pack.Data = data;
+ pack.Header.Zerocoded = true;
+ OutPacket(pack, ThrottleOutPacketType.Task);
+ }
+ }
- if (handlerInstantMessage != null)
- {
- GridInstantMessage im = new GridInstantMessage(Scene,
- msgpack.AgentData.AgentID,
- IMfromName,
- msgpack.MessageBlock.ToAgentID,
- msgpack.MessageBlock.Dialog,
- msgpack.MessageBlock.FromGroup,
- IMmessage,
- msgpack.MessageBlock.ID,
- msgpack.MessageBlock.Offline != 0 ? true : false,
- msgpack.MessageBlock.Position,
- msgpack.MessageBlock.BinaryBucket);
+ public void SendCameraConstraint(Vector4 ConstraintPlane)
+ {
+ CameraConstraintPacket cpack = (CameraConstraintPacket)PacketPool.Instance.GetPacket(PacketType.CameraConstraint);
+ cpack.CameraCollidePlane = new CameraConstraintPacket.CameraCollidePlaneBlock();
+ cpack.CameraCollidePlane.Plane = ConstraintPlane;
+ //m_log.DebugFormat("[CLIENTVIEW]: Constraint {0}", ConstraintPlane);
+ OutPacket(cpack, ThrottleOutPacketType.Task);
+ }
- handlerInstantMessage(this, im);
- }
- break;
+ public void SendLandObjectOwners(LandData land, List groups, Dictionary ownersAndCount)
+ {
+
- case PacketType.AcceptFriendship:
- AcceptFriendshipPacket afriendpack = (AcceptFriendshipPacket)Pack;
+ int notifyCount = ownersAndCount.Count;
+ ParcelObjectOwnersReplyPacket pack = (ParcelObjectOwnersReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelObjectOwnersReply);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (afriendpack.AgentData.SessionID != SessionId ||
- afriendpack.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ if (notifyCount > 0)
+ {
+ if (notifyCount > 32)
+ {
+ m_log.InfoFormat(
+ "[LAND]: More than {0} avatars own prims on this parcel. Only sending back details of first {0}"
+ + " - a developer might want to investigate whether this is a hard limit", 32);
- // My guess is this is the folder to stick the calling card into
- List callingCardFolders = new List();
+ notifyCount = 32;
+ }
- UUID agentID = afriendpack.AgentData.AgentID;
- UUID transactionID = afriendpack.TransactionBlock.TransactionID;
+ ParcelObjectOwnersReplyPacket.DataBlock[] dataBlock
+ = new ParcelObjectOwnersReplyPacket.DataBlock[notifyCount];
- for (int fi = 0; fi < afriendpack.FolderData.Length; fi++)
- {
- callingCardFolders.Add(afriendpack.FolderData[fi].FolderID);
- }
+ int num = 0;
+ foreach (UUID owner in ownersAndCount.Keys)
+ {
+ dataBlock[num] = new ParcelObjectOwnersReplyPacket.DataBlock();
+ dataBlock[num].Count = ownersAndCount[owner];
- handlerApproveFriendRequest = OnApproveFriendRequest;
- if (handlerApproveFriendRequest != null)
- {
- handlerApproveFriendRequest(this, agentID, transactionID, callingCardFolders);
- }
- break;
+ if (land.GroupID == owner || groups.Contains(owner))
+ dataBlock[num].IsGroupOwned = true;
- case PacketType.DeclineFriendship:
- DeclineFriendshipPacket dfriendpack = (DeclineFriendshipPacket)Pack;
+ dataBlock[num].OnlineStatus = true; //TODO: fix me later
+ dataBlock[num].OwnerID = owner;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (dfriendpack.AgentData.SessionID != SessionId ||
- dfriendpack.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ num++;
- if (OnDenyFriendRequest != null)
+ if (num >= notifyCount)
{
- OnDenyFriendRequest(this,
- dfriendpack.AgentData.AgentID,
- dfriendpack.TransactionBlock.TransactionID,
- null);
+ break;
}
- break;
+ }
- case PacketType.TerminateFriendship:
- TerminateFriendshipPacket tfriendpack = (TerminateFriendshipPacket)Pack;
+ pack.Data = dataBlock;
+ }
+ pack.Header.Zerocoded = true;
+ this.OutPacket(pack, ThrottleOutPacketType.Task);
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (tfriendpack.AgentData.SessionID != SessionId ||
- tfriendpack.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ #endregion
- UUID listOwnerAgentID = tfriendpack.AgentData.AgentID;
- UUID exFriendID = tfriendpack.ExBlock.OtherID;
+ #region Helper Methods
- handlerTerminateFriendship = OnTerminateFriendship;
- if (handlerTerminateFriendship != null)
- {
- handlerTerminateFriendship(this, listOwnerAgentID, exFriendID);
- }
- break;
+ protected ImprovedTerseObjectUpdatePacket.ObjectDataBlock CreateAvatarImprovedBlock(uint localID, Vector3 pos,
+ Vector3 velocity,
+ Quaternion rotation)
+ {
+ byte[] bytes = new byte[60];
+ int i = 0;
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat = PacketPool.GetDataBlock();
- case PacketType.RezObject:
- RezObjectPacket rezPacket = (RezObjectPacket)Pack;
+ dat.TextureEntry = new byte[0]; // AvatarTemplate.TextureEntry;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (rezPacket.AgentData.SessionID != SessionId ||
- rezPacket.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ uint ID = localID;
- handlerRezObject = OnRezObject;
- if (handlerRezObject != null)
- {
- handlerRezObject(this, rezPacket.InventoryData.ItemID, rezPacket.RezData.RayEnd,
- rezPacket.RezData.RayStart, rezPacket.RezData.RayTargetID,
- rezPacket.RezData.BypassRaycast, rezPacket.RezData.RayEndIsIntersection,
- rezPacket.RezData.RezSelected, rezPacket.RezData.RemoveItem,
- rezPacket.RezData.FromTaskID);
- }
- break;
+ bytes[i++] = (byte)(ID % 256);
+ bytes[i++] = (byte)((ID >> 8) % 256);
+ bytes[i++] = (byte)((ID >> 16) % 256);
+ bytes[i++] = (byte)((ID >> 24) % 256);
+ bytes[i++] = 0;
+ bytes[i++] = 1;
+ i += 14;
+ bytes[i++] = 128;
+ bytes[i++] = 63;
- case PacketType.DeRezObject:
- DeRezObjectPacket DeRezPacket = (DeRezObjectPacket) Pack;
+ byte[] pb = pos.GetBytes();
+ Array.Copy(pb, 0, bytes, i, pb.Length);
+ i += 12;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (DeRezPacket.AgentData.SessionID != SessionId ||
- DeRezPacket.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ Vector3 internDirec = new Vector3(velocity.X, velocity.Y, velocity.Z);
- handlerDeRezObject = OnDeRezObject;
- if (handlerDeRezObject != null)
- {
- List deRezIDs = new List();
+ internDirec = internDirec / 128.0f;
+ internDirec.X += 1;
+ internDirec.Y += 1;
+ internDirec.Z += 1;
- foreach (DeRezObjectPacket.ObjectDataBlock data in
- DeRezPacket.ObjectData)
- {
- deRezIDs.Add(data.ObjectLocalID);
- }
- // It just so happens that the values on the DeRezAction enumerator match the Destination
- // values given by a Second Life client
- handlerDeRezObject(this, deRezIDs,
- DeRezPacket.AgentBlock.GroupID,
- (DeRezAction)DeRezPacket.AgentBlock.Destination,
- DeRezPacket.AgentBlock.DestinationID);
-
- }
- break;
+ ushort InternVelocityX = (ushort)(32768 * internDirec.X);
+ ushort InternVelocityY = (ushort)(32768 * internDirec.Y);
+ ushort InternVelocityZ = (ushort)(32768 * internDirec.Z);
- case PacketType.ModifyLand:
- ModifyLandPacket modify = (ModifyLandPacket)Pack;
+ ushort ac = 32767;
+ bytes[i++] = (byte)(InternVelocityX % 256);
+ bytes[i++] = (byte)((InternVelocityX >> 8) % 256);
+ bytes[i++] = (byte)(InternVelocityY % 256);
+ bytes[i++] = (byte)((InternVelocityY >> 8) % 256);
+ bytes[i++] = (byte)(InternVelocityZ % 256);
+ bytes[i++] = (byte)((InternVelocityZ >> 8) % 256);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (modify.AgentData.SessionID != SessionId ||
- modify.AgentData.AgentID != AgentId)
- break;
- }
+ //accel
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
- #endregion
- //m_log.Info("[LAND]: LAND:" + modify.ToString());
- if (modify.ParcelData.Length > 0)
- {
- if (OnModifyTerrain != null)
- {
- for (int i = 0; i < modify.ParcelData.Length; i++)
- {
- handlerModifyTerrain = OnModifyTerrain;
- if (handlerModifyTerrain != null)
- {
- handlerModifyTerrain(AgentId, modify.ModifyBlock.Height, modify.ModifyBlock.Seconds,
- modify.ModifyBlock.BrushSize,
- modify.ModifyBlock.Action, modify.ParcelData[i].North,
- modify.ParcelData[i].West, modify.ParcelData[i].South,
- modify.ParcelData[i].East, AgentId);
- }
- }
- }
- }
-
- break;
-
- case PacketType.RegionHandshakeReply:
+ //rotation
+ ushort rw, rx, ry, rz;
+ rw = (ushort)(32768 * (rotation.W + 1));
+ rx = (ushort)(32768 * (rotation.X + 1));
+ ry = (ushort)(32768 * (rotation.Y + 1));
+ rz = (ushort)(32768 * (rotation.Z + 1));
- handlerRegionHandShakeReply = OnRegionHandShakeReply;
- if (handlerRegionHandShakeReply != null)
- {
- handlerRegionHandShakeReply(this);
- }
+ //rot
+ bytes[i++] = (byte)(rx % 256);
+ bytes[i++] = (byte)((rx >> 8) % 256);
+ bytes[i++] = (byte)(ry % 256);
+ bytes[i++] = (byte)((ry >> 8) % 256);
+ bytes[i++] = (byte)(rz % 256);
+ bytes[i++] = (byte)((rz >> 8) % 256);
+ bytes[i++] = (byte)(rw % 256);
+ bytes[i++] = (byte)((rw >> 8) % 256);
- break;
+ //rotation vel
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
- case PacketType.AgentWearablesRequest:
- handlerRequestWearables = OnRequestWearables;
+ dat.Data = bytes;
- if (handlerRequestWearables != null)
- {
- handlerRequestWearables();
- }
+ return (dat);
+ }
- handlerRequestAvatarsData = OnRequestAvatarsData;
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ protected ImprovedTerseObjectUpdatePacket.ObjectDataBlock CreatePrimImprovedBlock(uint localID,
+ Vector3 position,
+ Quaternion rotation,
+ Vector3 velocity,
+ Vector3 rotationalvelocity,
+ byte state)
+ {
+ uint ID = localID;
+ byte[] bytes = new byte[60];
- if (handlerRequestAvatarsData != null)
- {
- handlerRequestAvatarsData(this);
- }
+ int i = 0;
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat = PacketPool.GetDataBlock();
+ dat.TextureEntry = new byte[0];
+ bytes[i++] = (byte)(ID % 256);
+ bytes[i++] = (byte)((ID >> 8) % 256);
+ bytes[i++] = (byte)((ID >> 16) % 256);
+ bytes[i++] = (byte)((ID >> 24) % 256);
+ bytes[i++] = (byte)(((state & 0xf0) >> 4) | ((state & 0x0f) << 4));
+ bytes[i++] = 0;
- break;
+ byte[] pb = position.GetBytes();
+ Array.Copy(pb, 0, bytes, i, pb.Length);
+ i += 12;
+ ushort ac = 32767;
- case PacketType.AgentSetAppearance:
- AgentSetAppearancePacket appear = (AgentSetAppearancePacket)Pack;
+ ushort velx, vely, velz;
+ Vector3 vel = new Vector3(velocity.X, velocity.Y, velocity.Z);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (appear.AgentData.SessionID != SessionId ||
- appear.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ vel = vel / 128.0f;
+ vel.X += 1;
+ vel.Y += 1;
+ vel.Z += 1;
+ //vel
+ velx = (ushort)(32768 * (vel.X));
+ vely = (ushort)(32768 * (vel.Y));
+ velz = (ushort)(32768 * (vel.Z));
- handlerSetAppearance = OnSetAppearance;
- if (handlerSetAppearance != null)
- {
- // Temporarily protect ourselves from the mantis #951 failure.
- // However, we could do this for several other handlers where a failure isn't terminal
- // for the client session anyway, in order to protect ourselves against bad code in plugins
- try
- {
- byte[] visualparams = new byte[appear.VisualParam.Length];
- for (int i = 0; i < appear.VisualParam.Length; i++)
- visualparams[i] = appear.VisualParam[i].ParamValue;
+ bytes[i++] = (byte)(velx % 256);
+ bytes[i++] = (byte)((velx >> 8) % 256);
+ bytes[i++] = (byte)(vely % 256);
+ bytes[i++] = (byte)((vely >> 8) % 256);
+ bytes[i++] = (byte)(velz % 256);
+ bytes[i++] = (byte)((velz >> 8) % 256);
- Primitive.TextureEntry te = null;
- if (appear.ObjectData.TextureEntry.Length > 1)
- te = new Primitive.TextureEntry(appear.ObjectData.TextureEntry, 0, appear.ObjectData.TextureEntry.Length);
+ //accel
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
- handlerSetAppearance(te, visualparams);
- }
- catch (Exception e)
- {
- m_log.ErrorFormat(
- "[CLIENT VIEW]: AgentSetApperance packet handler threw an exception, {0}",
- e);
- }
- }
+ ushort rw, rx, ry, rz;
+ rw = (ushort)(32768 * (rotation.W + 1));
+ rx = (ushort)(32768 * (rotation.X + 1));
+ ry = (ushort)(32768 * (rotation.Y + 1));
+ rz = (ushort)(32768 * (rotation.Z + 1));
- break;
-
- case PacketType.AgentIsNowWearing:
- if (OnAvatarNowWearing != null)
- {
- AgentIsNowWearingPacket nowWearing = (AgentIsNowWearingPacket)Pack;
+ //rot
+ bytes[i++] = (byte)(rx % 256);
+ bytes[i++] = (byte)((rx >> 8) % 256);
+ bytes[i++] = (byte)(ry % 256);
+ bytes[i++] = (byte)((ry >> 8) % 256);
+ bytes[i++] = (byte)(rz % 256);
+ bytes[i++] = (byte)((rz >> 8) % 256);
+ bytes[i++] = (byte)(rw % 256);
+ bytes[i++] = (byte)((rw >> 8) % 256);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (nowWearing.AgentData.SessionID != SessionId ||
- nowWearing.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ //rotation vel
+ Vector3 rvel = new Vector3(rotationalvelocity.X, rotationalvelocity.Y, rotationalvelocity.Z);
- AvatarWearingArgs wearingArgs = new AvatarWearingArgs();
- for (int i = 0; i < nowWearing.WearableData.Length; i++)
- {
- AvatarWearingArgs.Wearable wearable =
- new AvatarWearingArgs.Wearable(nowWearing.WearableData[i].ItemID,
- nowWearing.WearableData[i].WearableType);
- wearingArgs.NowWearing.Add(wearable);
- }
+ rvel = rvel / 128.0f;
+ rvel.X += 1;
+ rvel.Y += 1;
+ rvel.Z += 1;
+ //vel
+ ushort rvelx = (ushort)(32768 * (rvel.X));
+ ushort rvely = (ushort)(32768 * (rvel.Y));
+ ushort rvelz = (ushort)(32768 * (rvel.Z));
- handlerAvatarNowWearing = OnAvatarNowWearing;
- if (handlerAvatarNowWearing != null)
- {
- handlerAvatarNowWearing(this, wearingArgs);
- }
- }
- break;
+ bytes[i++] = (byte)(rvelx % 256);
+ bytes[i++] = (byte)((rvelx >> 8) % 256);
+ bytes[i++] = (byte)(rvely % 256);
+ bytes[i++] = (byte)((rvely >> 8) % 256);
+ bytes[i++] = (byte)(rvelz % 256);
+ bytes[i++] = (byte)((rvelz >> 8) % 256);
+ dat.Data = bytes;
- case PacketType.RezSingleAttachmentFromInv:
- handlerRezSingleAttachment = OnRezSingleAttachmentFromInv;
- if (handlerRezSingleAttachment != null)
- {
- RezSingleAttachmentFromInvPacket rez = (RezSingleAttachmentFromInvPacket)Pack;
+ return dat;
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (rez.AgentData.SessionID != SessionId ||
- rez.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ ///
+ /// Create the ObjectDataBlock for a ObjectUpdatePacket (for a Primitive)
+ ///
+ ///
+ ///
+ protected ObjectUpdatePacket.ObjectDataBlock CreatePrimUpdateBlock(PrimitiveBaseShape primShape, uint flags)
+ {
+ ObjectUpdatePacket.ObjectDataBlock objupdate = PacketPool.GetDataBlock();
+ SetDefaultPrimPacketValues(objupdate);
+ objupdate.UpdateFlags = flags;
+ SetPrimPacketShapeData(objupdate, primShape);
- handlerRezSingleAttachment(this, rez.ObjectData.ItemID,
- rez.ObjectData.AttachmentPt);
- }
+ if ((primShape.PCode == (byte)PCode.NewTree) || (primShape.PCode == (byte)PCode.Tree) || (primShape.PCode == (byte)PCode.Grass))
+ {
+ objupdate.Data = new byte[1];
+ objupdate.Data[0] = primShape.State;
+ }
+ return objupdate;
+ }
- break;
+ protected void SetPrimPacketShapeData(ObjectUpdatePacket.ObjectDataBlock objectData, PrimitiveBaseShape primData)
+ {
+ objectData.TextureEntry = primData.TextureEntry;
+ objectData.PCode = primData.PCode;
+ objectData.State = primData.State;
+ objectData.PathBegin = primData.PathBegin;
+ objectData.PathEnd = primData.PathEnd;
+ objectData.PathScaleX = primData.PathScaleX;
+ objectData.PathScaleY = primData.PathScaleY;
+ objectData.PathShearX = primData.PathShearX;
+ objectData.PathShearY = primData.PathShearY;
+ objectData.PathSkew = primData.PathSkew;
+ objectData.ProfileBegin = primData.ProfileBegin;
+ objectData.ProfileEnd = primData.ProfileEnd;
+ objectData.Scale = primData.Scale;
+ objectData.PathCurve = primData.PathCurve;
+ objectData.ProfileCurve = primData.ProfileCurve;
+ objectData.ProfileHollow = primData.ProfileHollow;
+ objectData.PathRadiusOffset = primData.PathRadiusOffset;
+ objectData.PathRevolutions = primData.PathRevolutions;
+ objectData.PathTaperX = primData.PathTaperX;
+ objectData.PathTaperY = primData.PathTaperY;
+ objectData.PathTwist = primData.PathTwist;
+ objectData.PathTwistBegin = primData.PathTwistBegin;
+ objectData.ExtraParams = primData.ExtraParams;
+ }
- case PacketType.RezMultipleAttachmentsFromInv:
- handlerRezMultipleAttachments = OnRezMultipleAttachmentsFromInv;
- if (handlerRezMultipleAttachments != null)
- {
- RezMultipleAttachmentsFromInvPacket rez = (RezMultipleAttachmentsFromInvPacket)Pack;
- handlerRezMultipleAttachments(this, rez.HeaderData,
- rez.ObjectData);
- }
+ ///
+ /// Set some default values in a ObjectUpdatePacket
+ ///
+ ///
+ protected void SetDefaultPrimPacketValues(ObjectUpdatePacket.ObjectDataBlock objdata)
+ {
+ objdata.PSBlock = new byte[0];
+ objdata.ExtraParams = new byte[1];
+ objdata.MediaURL = new byte[0];
+ objdata.NameValue = new byte[0];
+ objdata.Text = new byte[0];
+ objdata.TextColor = new byte[4];
+ objdata.JointAxisOrAnchor = new Vector3(0, 0, 0);
+ objdata.JointPivot = new Vector3(0, 0, 0);
+ objdata.Material = 3;
+ objdata.TextureAnim = new byte[0];
+ objdata.Sound = UUID.Zero;
+ objdata.State = 0;
+ objdata.Data = new byte[0];
- break;
+ objdata.ObjectData = new byte[60];
+ objdata.ObjectData[46] = 128;
+ objdata.ObjectData[47] = 63;
+ }
- case PacketType.DetachAttachmentIntoInv:
- handlerDetachAttachmentIntoInv = OnDetachAttachmentIntoInv;
- if (handlerDetachAttachmentIntoInv != null)
- {
- DetachAttachmentIntoInvPacket detachtoInv = (DetachAttachmentIntoInvPacket)Pack;
+ ///
+ ///
+ ///
+ ///
+ public ObjectUpdatePacket.ObjectDataBlock CreateDefaultAvatarPacket(byte[] textureEntry)
+ {
+ ObjectUpdatePacket.ObjectDataBlock objdata = PacketPool.GetDataBlock();
+ // new OpenMetaverse.Packets.ObjectUpdatePacket.ObjectDataBlock(data1, ref i);
- #region Packet Session and User Check
- // UNSUPPORTED ON THIS PACKET
- #endregion
+ SetDefaultAvatarPacketValues(ref objdata);
+ objdata.UpdateFlags = 61 + (9 << 8) + (130 << 16) + (16 << 24);
+ objdata.PathCurve = 16;
+ objdata.ProfileCurve = 1;
+ objdata.PathScaleX = 100;
+ objdata.PathScaleY = 100;
+ objdata.ParentID = 0;
+ objdata.OwnerID = UUID.Zero;
+ objdata.Scale = new Vector3(1, 1, 1);
+ objdata.PCode = (byte)PCode.Avatar;
+ if (textureEntry != null)
+ {
+ objdata.TextureEntry = textureEntry;
+ }
+ Vector3 pos = new Vector3(objdata.ObjectData, 16);
+ pos.X = 100f;
+ objdata.ID = 8880000;
+ objdata.NameValue = Utils.StringToBytes("FirstName STRING RW SV Test \nLastName STRING RW SV User ");
+ //Vector3 pos2 = new Vector3(100f, 100f, 23f);
+ //objdata.FullID=user.AgentId;
+ byte[] pb = pos.GetBytes();
+ Array.Copy(pb, 0, objdata.ObjectData, 16, pb.Length);
- UUID itemID = detachtoInv.ObjectData.ItemID;
- // UUID ATTACH_agentID = detachtoInv.ObjectData.AgentID;
+ return objdata;
+ }
- handlerDetachAttachmentIntoInv(itemID, this);
- }
- break;
+ ///
+ ///
+ ///
+ ///
+ protected void SetDefaultAvatarPacketValues(ref ObjectUpdatePacket.ObjectDataBlock objdata)
+ {
+ objdata.PSBlock = new byte[0];
+ objdata.ExtraParams = new byte[1];
+ objdata.MediaURL = new byte[0];
+ objdata.NameValue = new byte[0];
+ objdata.Text = new byte[0];
+ objdata.TextColor = new byte[4];
+ objdata.JointAxisOrAnchor = new Vector3(0, 0, 0);
+ objdata.JointPivot = new Vector3(0, 0, 0);
+ objdata.Material = 4;
+ objdata.TextureAnim = new byte[0];
+ objdata.Sound = UUID.Zero;
+ Primitive.TextureEntry ntex = new Primitive.TextureEntry(new UUID("00000000-0000-0000-5005-000000000005"));
+ objdata.TextureEntry = ntex.GetBytes();
- case PacketType.ObjectAttach:
- if (OnObjectAttach != null)
- {
- ObjectAttachPacket att = (ObjectAttachPacket)Pack;
+ objdata.State = 0;
+ objdata.Data = new byte[0];
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (att.AgentData.SessionID != SessionId ||
- att.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ objdata.ObjectData = new byte[76];
+ objdata.ObjectData[15] = 128;
+ objdata.ObjectData[16] = 63;
+ objdata.ObjectData[56] = 128;
+ objdata.ObjectData[61] = 102;
+ objdata.ObjectData[62] = 40;
+ objdata.ObjectData[63] = 61;
+ objdata.ObjectData[64] = 189;
+ }
- handlerObjectAttach = OnObjectAttach;
+ public void SendNameReply(UUID profileId, string firstname, string lastname)
+ {
+ UUIDNameReplyPacket packet = (UUIDNameReplyPacket)PacketPool.Instance.GetPacket(PacketType.UUIDNameReply);
+ // TODO: don't create new blocks if recycling an old packet
+ packet.UUIDNameBlock = new UUIDNameReplyPacket.UUIDNameBlockBlock[1];
+ packet.UUIDNameBlock[0] = new UUIDNameReplyPacket.UUIDNameBlockBlock();
+ packet.UUIDNameBlock[0].ID = profileId;
+ packet.UUIDNameBlock[0].FirstName = Utils.StringToBytes(firstname);
+ packet.UUIDNameBlock[0].LastName = Utils.StringToBytes(lastname);
- if (handlerObjectAttach != null)
- {
- if (att.ObjectData.Length > 0)
- {
- handlerObjectAttach(this, att.ObjectData[0].ObjectLocalID, att.AgentData.AttachmentPoint, att.ObjectData[0].Rotation, false);
- }
- }
- }
- break;
+ OutPacket(packet, ThrottleOutPacketType.Task);
+ }
- case PacketType.ObjectDetach:
- ObjectDetachPacket dett = (ObjectDetachPacket)Pack;
+ public ulong GetGroupPowers(UUID groupID)
+ {
+ if (groupID == m_activeGroupID)
+ return m_activeGroupPowers;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (dett.AgentData.SessionID != SessionId ||
- dett.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ if (m_groupPowers.ContainsKey(groupID))
+ return m_groupPowers[groupID];
- for (int j = 0; j < dett.ObjectData.Length; j++)
- {
- uint obj = dett.ObjectData[j].ObjectLocalID;
- handlerObjectDetach = OnObjectDetach;
- if (handlerObjectDetach != null)
- {
- handlerObjectDetach(obj, this);
- }
+ return 0;
+ }
- }
- break;
+ ///
+ /// This is a utility method used by single states to not duplicate kicks and blue card of death messages.
+ ///
+ public bool ChildAgentStatus()
+ {
+ return m_scene.PresenceChildStatus(AgentId);
+ }
- case PacketType.ObjectDrop:
- ObjectDropPacket dropp = (ObjectDropPacket)Pack;
+ #endregion
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (dropp.AgentData.SessionID != SessionId ||
- dropp.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ ///
+ /// This is a different way of processing packets then ProcessInPacket
+ ///
+ protected virtual void RegisterLocalPacketHandlers()
+ {
+ AddLocalPacketHandler(PacketType.LogoutRequest, Logout);
+ AddLocalPacketHandler(PacketType.ViewerEffect, HandleViewerEffect);
+ AddLocalPacketHandler(PacketType.AgentCachedTexture, AgentTextureCached);
+ AddLocalPacketHandler(PacketType.MultipleObjectUpdate, MultipleObjUpdate);
+ AddLocalPacketHandler(PacketType.MoneyTransferRequest, HandleMoneyTransferRequest);
+ AddLocalPacketHandler(PacketType.ParcelBuy, HandleParcelBuyRequest);
+ AddLocalPacketHandler(PacketType.UUIDGroupNameRequest, HandleUUIDGroupNameRequest);
+ AddLocalPacketHandler(PacketType.ObjectGroup, HandleObjectGroupRequest);
+ AddLocalPacketHandler(PacketType.GenericMessage, HandleGenericMessage);
+ }
- for (int j = 0; j < dropp.ObjectData.Length; j++)
- {
- uint obj = dropp.ObjectData[j].ObjectLocalID;
- handlerObjectDrop = OnObjectDrop;
- if (handlerObjectDrop != null)
- {
- handlerObjectDrop(obj, this);
- }
- }
- break;
+ #region Packet Handlers
- case PacketType.SetAlwaysRun:
- SetAlwaysRunPacket run = (SetAlwaysRunPacket)Pack;
+ private bool HandleMoneyTransferRequest(IClientAPI sender, Packet Pack)
+ {
+ MoneyTransferRequestPacket money = (MoneyTransferRequestPacket) Pack;
+ // validate the agent owns the agentID and sessionID
+ if (money.MoneyData.SourceID == sender.AgentId && money.AgentData.AgentID == sender.AgentId &&
+ money.AgentData.SessionID == sender.SessionId)
+ {
+ MoneyTransferRequest handlerMoneyTransferRequest = OnMoneyTransferRequest;
+ if (handlerMoneyTransferRequest != null)
+ {
+ handlerMoneyTransferRequest(money.MoneyData.SourceID, money.MoneyData.DestID,
+ money.MoneyData.Amount, money.MoneyData.TransactionType,
+ Util.FieldToString(money.MoneyData.Description));
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (run.AgentData.SessionID != SessionId ||
- run.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ return true;
+ }
- handlerSetAlwaysRun = OnSetAlwaysRun;
- if (handlerSetAlwaysRun != null)
- handlerSetAlwaysRun(this, run.AgentData.AlwaysRun);
+ return false;
+ }
- break;
+ private bool HandleParcelBuyRequest(IClientAPI sender, Packet Pack)
+ {
+ ParcelBuyPacket parcel = (ParcelBuyPacket) Pack;
+ if (parcel.AgentData.AgentID == AgentId && parcel.AgentData.SessionID == SessionId)
+ {
+ ParcelBuy handlerParcelBuy = OnParcelBuy;
+ if (handlerParcelBuy != null)
+ {
+ handlerParcelBuy(parcel.AgentData.AgentID, parcel.Data.GroupID, parcel.Data.Final,
+ parcel.Data.IsGroupOwned,
+ parcel.Data.RemoveContribution, parcel.Data.LocalID, parcel.ParcelData.Area,
+ parcel.ParcelData.Price,
+ false);
+ }
+ return true;
+ }
+ return false;
+ }
- case PacketType.CompleteAgentMovement:
- handlerCompleteMovementToRegion = OnCompleteMovementToRegion;
- if (handlerCompleteMovementToRegion != null)
- {
- handlerCompleteMovementToRegion();
- }
- handlerCompleteMovementToRegion = null;
-
- break;
-
- case PacketType.AgentUpdate:
- if (OnAgentUpdate != null)
- {
- bool update = false;
- AgentUpdatePacket agenUpdate = (AgentUpdatePacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (agenUpdate.AgentData.SessionID != SessionId ||
- agenUpdate.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
-
- AgentUpdatePacket.AgentDataBlock x = agenUpdate.AgentData;
-
- // We can only check when we have something to check
- // against.
+ private bool HandleUUIDGroupNameRequest(IClientAPI sender, Packet Pack)
+ {
+ UUIDGroupNameRequestPacket upack = (UUIDGroupNameRequestPacket)Pack;
+
- if (lastarg != null)
- {
- update =
- (
- (x.BodyRotation != lastarg.BodyRotation) ||
- (x.CameraAtAxis != lastarg.CameraAtAxis) ||
- (x.CameraCenter != lastarg.CameraCenter) ||
- (x.CameraLeftAxis != lastarg.CameraLeftAxis) ||
- (x.CameraUpAxis != lastarg.CameraUpAxis) ||
- (x.ControlFlags != lastarg.ControlFlags) ||
- (x.Far != lastarg.Far) ||
- (x.Flags != lastarg.Flags) ||
- (x.State != lastarg.State) ||
- (x.HeadRotation != lastarg.HeadRotation) ||
- (x.SessionID != lastarg.SessionID) ||
- (x.AgentID != lastarg.AgentID)
- );
- }
- else
- update = true;
+ for (int i = 0; i < upack.UUIDNameBlock.Length; i++)
+ {
+ UUIDNameRequest handlerUUIDGroupNameRequest = OnUUIDGroupNameRequest;
+ if (handlerUUIDGroupNameRequest != null)
+ {
+ handlerUUIDGroupNameRequest(upack.UUIDNameBlock[i].ID, this);
+ }
+ }
- // These should be ordered from most-likely to
- // least likely to change. I've made an initial
- // guess at that.
+ return true;
+ }
- if (update)
- {
- AgentUpdateArgs arg = new AgentUpdateArgs();
- arg.AgentID = x.AgentID;
- arg.BodyRotation = x.BodyRotation;
- arg.CameraAtAxis = x.CameraAtAxis;
- arg.CameraCenter = x.CameraCenter;
- arg.CameraLeftAxis = x.CameraLeftAxis;
- arg.CameraUpAxis = x.CameraUpAxis;
- arg.ControlFlags = x.ControlFlags;
- arg.Far = x.Far;
- arg.Flags = x.Flags;
- arg.HeadRotation = x.HeadRotation;
- arg.SessionID = x.SessionID;
- arg.State = x.State;
- handlerAgentUpdate = OnAgentUpdate;
- lastarg = arg; // save this set of arguments for nexttime
- if (handlerAgentUpdate != null)
- OnAgentUpdate(this, arg);
+ public bool HandleGenericMessage(IClientAPI sender, Packet pack)
+ {
+ GenericMessagePacket gmpack = (GenericMessagePacket) pack;
+ if (m_genericPacketHandlers.Count == 0) return false;
+ if (gmpack.AgentData.SessionID != SessionId) return false;
- handlerAgentUpdate = null;
- }
+ GenericMessage handlerGenericMessage = null;
- }
- break;
+ string method = Util.FieldToString(gmpack.MethodData.Method).ToLower().Trim();
- case PacketType.AgentAnimation:
- AgentAnimationPacket AgentAni = (AgentAnimationPacket)Pack;
+ if (m_genericPacketHandlers.TryGetValue(method, out handlerGenericMessage))
+ {
+ List msg = new List();
+ List msgBytes = new List();
- #region Packet Session and User Check
- if (m_checkPackets)
+ if (handlerGenericMessage != null)
+ {
+ foreach (GenericMessagePacket.ParamListBlock block in gmpack.ParamList)
{
- if (AgentAni.AgentData.SessionID != SessionId ||
- AgentAni.AgentData.AgentID != AgentId)
- break;
+ msg.Add(Util.FieldToString(block.Parameter));
+ msgBytes.Add(block.Parameter);
}
- #endregion
-
- handlerStartAnim = null;
- handlerStopAnim = null;
-
- for (int i = 0; i < AgentAni.AnimationList.Length; i++)
+ try
{
- if (AgentAni.AnimationList[i].StartAnim)
- {
- handlerStartAnim = OnStartAnim;
- if (handlerStartAnim != null)
- {
- handlerStartAnim(this, AgentAni.AnimationList[i].AnimID);
- }
- }
- else
+ if (OnBinaryGenericMessage != null)
{
- handlerStopAnim = OnStopAnim;
- if (handlerStopAnim != null)
- {
- handlerStopAnim(this, AgentAni.AnimationList[i].AnimID);
- }
+ OnBinaryGenericMessage(this, method, msgBytes.ToArray());
}
+ handlerGenericMessage(sender, method, msg);
+ return true;
}
- break;
-
- case PacketType.AgentRequestSit:
- if (OnAgentRequestSit != null)
+ catch (Exception e)
{
- AgentRequestSitPacket agentRequestSit = (AgentRequestSitPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (agentRequestSit.AgentData.SessionID != SessionId ||
- agentRequestSit.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
-
- handlerAgentRequestSit = OnAgentRequestSit;
- if (handlerAgentRequestSit != null)
- handlerAgentRequestSit(this, agentRequestSit.AgentData.AgentID,
- agentRequestSit.TargetObject.TargetID, agentRequestSit.TargetObject.Offset);
+ m_log.Error("[GENERICMESSAGE] " + e);
}
- break;
+ }
+ }
+ m_log.Error("[GENERICMESSAGE] Not handling GenericMessage with method-type of: " + method);
+ return false;
+ }
- case PacketType.AgentSit:
- if (OnAgentSit != null)
- {
- AgentSitPacket agentSit = (AgentSitPacket)Pack;
+ public bool HandleObjectGroupRequest(IClientAPI sender, Packet Pack)
+ {
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (agentSit.AgentData.SessionID != SessionId ||
- agentSit.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ ObjectGroupPacket ogpack = (ObjectGroupPacket)Pack;
+ if (ogpack.AgentData.SessionID != SessionId) return false;
- handlerAgentSit = OnAgentSit;
- if (handlerAgentSit != null)
- {
- OnAgentSit(this, agentSit.AgentData.AgentID);
- }
- }
- break;
+ RequestObjectPropertiesFamily handlerObjectGroupRequest = OnObjectGroupRequest;
+ if (handlerObjectGroupRequest != null)
+ {
+ for (int i = 0; i < ogpack.ObjectData.Length; i++)
+ {
+ handlerObjectGroupRequest(this, ogpack.AgentData.GroupID, ogpack.ObjectData[i].ObjectLocalID, UUID.Zero);
+ }
+ }
+ return true;
+ }
- case PacketType.SoundTrigger:
- SoundTriggerPacket soundTriggerPacket = (SoundTriggerPacket)Pack;
+ private bool HandleViewerEffect(IClientAPI sender, Packet Pack)
+ {
+ ViewerEffectPacket viewer = (ViewerEffectPacket)Pack;
+ if (viewer.AgentData.SessionID != SessionId) return false;
+ ViewerEffectEventHandler handlerViewerEffect = OnViewerEffect;
+ if (handlerViewerEffect != null)
+ {
+ int length = viewer.Effect.Length;
+ List args = new List(length);
+ for (int i = 0; i < length; i++)
+ {
+ //copy the effects block arguments into the event handler arg.
+ ViewerEffectEventHandlerArg argument = new ViewerEffectEventHandlerArg();
+ argument.AgentID = viewer.Effect[i].AgentID;
+ argument.Color = viewer.Effect[i].Color;
+ argument.Duration = viewer.Effect[i].Duration;
+ argument.ID = viewer.Effect[i].ID;
+ argument.Type = viewer.Effect[i].Type;
+ argument.TypeData = viewer.Effect[i].TypeData;
+ args.Add(argument);
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- // UNSUPPORTED ON THIS PACKET
- }
- #endregion
+ handlerViewerEffect(sender, args);
+ }
- handlerSoundTrigger = OnSoundTrigger;
- if (handlerSoundTrigger != null)
- {
- handlerSoundTrigger(soundTriggerPacket.SoundData.SoundID, soundTriggerPacket.SoundData.OwnerID,
- soundTriggerPacket.SoundData.ObjectID, soundTriggerPacket.SoundData.ParentID,
- soundTriggerPacket.SoundData.Gain, soundTriggerPacket.SoundData.Position,
- soundTriggerPacket.SoundData.Handle);
+ return true;
+ }
- }
- break;
+ #endregion Packet Handlers
- case PacketType.AvatarPickerRequest:
- AvatarPickerRequestPacket avRequestQuery = (AvatarPickerRequestPacket)Pack;
+ public void SendScriptQuestion(UUID taskID, string taskName, string ownerName, UUID itemID, int question)
+ {
+ ScriptQuestionPacket scriptQuestion = (ScriptQuestionPacket)PacketPool.Instance.GetPacket(PacketType.ScriptQuestion);
+ scriptQuestion.Data = new ScriptQuestionPacket.DataBlock();
+ // TODO: don't create new blocks if recycling an old packet
+ scriptQuestion.Data.TaskID = taskID;
+ scriptQuestion.Data.ItemID = itemID;
+ scriptQuestion.Data.Questions = question;
+ scriptQuestion.Data.ObjectName = Utils.StringToBytes(taskName);
+ scriptQuestion.Data.ObjectOwner = Utils.StringToBytes(ownerName);
- #region Packet Session and User Check
- if (m_checkPackets)
+ OutPacket(scriptQuestion, ThrottleOutPacketType.Task);
+ }
+
+ private void InitDefaultAnimations()
+ {
+ using (XmlTextReader reader = new XmlTextReader("data/avataranimations.xml"))
+ {
+ XmlDocument doc = new XmlDocument();
+ doc.Load(reader);
+ if (doc.DocumentElement != null)
+ foreach (XmlNode nod in doc.DocumentElement.ChildNodes)
{
- if (avRequestQuery.AgentData.SessionID != SessionId ||
- avRequestQuery.AgentData.AgentID != AgentId)
- break;
+ if (nod.Attributes["name"] != null)
+ {
+ string name = nod.Attributes["name"].Value.ToLower();
+ string id = nod.InnerText;
+ m_defaultAnimations.Add(name, (UUID)id);
+ }
}
- #endregion
+ }
+ }
- AvatarPickerRequestPacket.AgentDataBlock Requestdata = avRequestQuery.AgentData;
- AvatarPickerRequestPacket.DataBlock querydata = avRequestQuery.Data;
- //m_log.Debug("Agent Sends:" + Utils.BytesToString(querydata.Name));
+ public UUID GetDefaultAnimation(string name)
+ {
+ if (m_defaultAnimations.ContainsKey(name))
+ return m_defaultAnimations[name];
+ return UUID.Zero;
+ }
- handlerAvatarPickerRequest = OnAvatarPickerRequest;
- if (handlerAvatarPickerRequest != null)
- {
- handlerAvatarPickerRequest(this, Requestdata.AgentID, Requestdata.QueryID,
- Utils.BytesToString(querydata.Name));
- }
- break;
+ ///
+ /// Handler called when we receive a logout packet.
+ ///
+ ///
+ ///
+ ///
+ protected virtual bool Logout(IClientAPI client, Packet packet)
+ {
+ if (packet.Type == PacketType.LogoutRequest)
+ {
+ if (((LogoutRequestPacket)packet).AgentData.SessionID != SessionId) return false;
+ }
+
+ return Logout(client);
+ }
- case PacketType.AgentDataUpdateRequest:
- AgentDataUpdateRequestPacket avRequestDataUpdatePacket = (AgentDataUpdateRequestPacket)Pack;
+ ///
+ ///
+ ///
+ ///
+ ///
+ protected virtual bool Logout(IClientAPI client)
+ {
+ m_log.InfoFormat("[CLIENT]: Got a logout request for {0} in {1}", Name, Scene.RegionInfo.RegionName);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (avRequestDataUpdatePacket.AgentData.SessionID != SessionId ||
- avRequestDataUpdatePacket.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ Action handlerLogout = OnLogout;
- handlerAgentDataUpdateRequest = OnAgentDataUpdateRequest;
+ if (handlerLogout != null)
+ {
+ handlerLogout(client);
+ }
- if (handlerAgentDataUpdateRequest != null)
- {
- handlerAgentDataUpdateRequest(this, avRequestDataUpdatePacket.AgentData.AgentID, avRequestDataUpdatePacket.AgentData.SessionID);
- }
+ return true;
+ }
- break;
-
- case PacketType.UserInfoRequest:
- handlerUserInfoRequest = OnUserInfoRequest;
- if (handlerUserInfoRequest != null)
- {
- handlerUserInfoRequest(this);
- }
- else
- {
- SendUserInfoReply(false, true, "");
- }
- break;
-
- case PacketType.UpdateUserInfo:
- UpdateUserInfoPacket updateUserInfo = (UpdateUserInfoPacket)Pack;
+ ///
+ /// Send a response back to a client when it asks the asset server (via the region server) if it has
+ /// its appearance texture cached.
+ ///
+ /// At the moment, we always reply that there is no cached texture.
+ ///
+ ///
+ ///
+ ///
+ protected bool AgentTextureCached(IClientAPI simclient, Packet packet)
+ {
+ //m_log.Debug("texture cached: " + packet.ToString());
+ AgentCachedTexturePacket cachedtex = (AgentCachedTexturePacket)packet;
+ AgentCachedTextureResponsePacket cachedresp = (AgentCachedTextureResponsePacket)PacketPool.Instance.GetPacket(PacketType.AgentCachedTextureResponse);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (updateUserInfo.AgentData.SessionID != SessionId ||
- updateUserInfo.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ if (cachedtex.AgentData.SessionID != SessionId) return false;
- handlerUpdateUserInfo = OnUpdateUserInfo;
- if (handlerUpdateUserInfo != null)
- {
- bool visible = true;
- string DirectoryVisibility =
- Utils.BytesToString(updateUserInfo.UserData.DirectoryVisibility);
- if (DirectoryVisibility == "hidden")
- visible = false;
+ // TODO: don't create new blocks if recycling an old packet
+ cachedresp.AgentData.AgentID = AgentId;
+ cachedresp.AgentData.SessionID = m_sessionId;
+ cachedresp.AgentData.SerialNum = m_cachedTextureSerial;
+ m_cachedTextureSerial++;
+ cachedresp.WearableData =
+ new AgentCachedTextureResponsePacket.WearableDataBlock[cachedtex.WearableData.Length];
- handlerUpdateUserInfo(
- updateUserInfo.UserData.IMViaEMail,
- visible, this);
- }
- break;
-
- case PacketType.SetStartLocationRequest:
- SetStartLocationRequestPacket avSetStartLocationRequestPacket = (SetStartLocationRequestPacket)Pack;
+ for (int i = 0; i < cachedtex.WearableData.Length; i++)
+ {
+ cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
+ cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
+ cachedresp.WearableData[i].TextureID = UUID.Zero;
+ cachedresp.WearableData[i].HostName = new byte[0];
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (avSetStartLocationRequestPacket.AgentData.SessionID != SessionId ||
- avSetStartLocationRequestPacket.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ cachedresp.Header.Zerocoded = true;
+ OutPacket(cachedresp, ThrottleOutPacketType.Task);
+
+ return true;
+ }
- if (avSetStartLocationRequestPacket.AgentData.AgentID == AgentId && avSetStartLocationRequestPacket.AgentData.SessionID == SessionId)
- {
- handlerSetStartLocationRequest = OnSetStartLocationRequest;
- if (handlerSetStartLocationRequest != null)
- {
- handlerSetStartLocationRequest(this, 0, avSetStartLocationRequestPacket.StartLocationData.LocationPos,
- avSetStartLocationRequestPacket.StartLocationData.LocationLookAt,
- avSetStartLocationRequestPacket.StartLocationData.LocationID);
- }
- }
- break;
+ protected bool MultipleObjUpdate(IClientAPI simClient, Packet packet)
+ {
+ MultipleObjectUpdatePacket multipleupdate = (MultipleObjectUpdatePacket)packet;
+ if (multipleupdate.AgentData.SessionID != SessionId) return false;
+ // m_log.Debug("new multi update packet " + multipleupdate.ToString());
+ Scene tScene = (Scene)m_scene;
- case PacketType.AgentThrottle:
- AgentThrottlePacket atpack = (AgentThrottlePacket)Pack;
+ for (int i = 0; i < multipleupdate.ObjectData.Length; i++)
+ {
+ MultipleObjectUpdatePacket.ObjectDataBlock block = multipleupdate.ObjectData[i];
- #region Packet Session and User Check
- if (m_checkPackets)
+ // Can't act on Null Data
+ if (block.Data != null)
+ {
+ uint localId = block.ObjectLocalID;
+ SceneObjectPart part = tScene.GetSceneObjectPart(localId);
+
+ if (part == null)
{
- if (atpack.AgentData.SessionID != SessionId ||
- atpack.AgentData.AgentID != AgentId)
- break;
+ // It's a ghost! tell the client to delete it from view.
+ simClient.SendKillObject(Scene.RegionInfo.RegionHandle,
+ localId);
}
- #endregion
+ else
+ {
+ // UUID partId = part.UUID;
+ UpdatePrimGroupRotation handlerUpdatePrimGroupRotation;
- m_PacketHandler.PacketQueue.SetThrottleFromClient(atpack.Throttle.Throttles);
- break;
+ switch (block.Type)
+ {
+ case 1:
+ Vector3 pos1 = new Vector3(block.Data, 0);
- case PacketType.AgentPause:
- m_probesWithNoIngressPackets = 0;
- m_clientBlocked = true;
- break;
+ UpdateVector handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ // m_log.Debug("new movement position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
+ handlerUpdatePrimSinglePosition(localId, pos1, this);
+ }
+ break;
+ case 2:
+ Quaternion rot1 = new Quaternion(block.Data, 0, true);
- case PacketType.AgentResume:
- m_probesWithNoIngressPackets = 0;
- m_clientBlocked = false;
- SendStartPingCheck(0);
+ UpdatePrimSingleRotation handlerUpdatePrimSingleRotation = OnUpdatePrimSingleRotation;
+ if (handlerUpdatePrimSingleRotation != null)
+ {
+ // m_log.Info("new tab rotation is " + rot1.X + " , " + rot1.Y + " , " + rot1.Z + " , " + rot1.W);
+ handlerUpdatePrimSingleRotation(localId, rot1, this);
+ }
+ break;
+ case 3:
+ Vector3 rotPos = new Vector3(block.Data, 0);
+ Quaternion rot2 = new Quaternion(block.Data, 12, true);
- break;
+ UpdatePrimSingleRotationPosition handlerUpdatePrimSingleRotationPosition = OnUpdatePrimSingleRotationPosition;
+ if (handlerUpdatePrimSingleRotationPosition != null)
+ {
+ // m_log.Debug("new mouse rotation position is " + rotPos.X + " , " + rotPos.Y + " , " + rotPos.Z);
+ // m_log.Info("new mouse rotation is " + rot2.X + " , " + rot2.Y + " , " + rot2.Z + " , " + rot2.W);
+ handlerUpdatePrimSingleRotationPosition(localId, rot2, rotPos, this);
+ }
+ break;
+ case 4:
+ case 20:
+ Vector3 scale4 = new Vector3(block.Data, 0);
- case PacketType.ForceScriptControlRelease:
- handlerForceReleaseControls = OnForceReleaseControls;
- if (handlerForceReleaseControls != null)
- {
- handlerForceReleaseControls(this, AgentId);
- }
- break;
+ UpdateVector handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+// m_log.Debug("new scale is " + scale4.X + " , " + scale4.Y + " , " + scale4.Z);
+ handlerUpdatePrimScale(localId, scale4, this);
+ }
+ break;
+ case 5:
- #endregion
+ Vector3 scale1 = new Vector3(block.Data, 12);
+ Vector3 pos11 = new Vector3(block.Data, 0);
- #region Objects/m_sceneObjects
+ handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+ // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimScale(localId, scale1, this);
- case PacketType.ObjectLink:
- ObjectLinkPacket link = (ObjectLinkPacket)Pack;
+ handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ handlerUpdatePrimSinglePosition(localId, pos11, this);
+ }
+ }
+ break;
+ case 9:
+ Vector3 pos2 = new Vector3(block.Data, 0);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (link.AgentData.SessionID != SessionId ||
- link.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
-
- uint parentprimid = 0;
- List childrenprims = new List();
- if (link.ObjectData.Length > 1)
- {
- parentprimid = link.ObjectData[0].ObjectLocalID;
-
- for (int i = 1; i < link.ObjectData.Length; i++)
- {
- childrenprims.Add(link.ObjectData[i].ObjectLocalID);
- }
- }
- handlerLinkObjects = OnLinkObjects;
- if (handlerLinkObjects != null)
- {
- handlerLinkObjects(this, parentprimid, childrenprims);
- }
- break;
-
- case PacketType.ObjectDelink:
- ObjectDelinkPacket delink = (ObjectDelinkPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (delink.AgentData.SessionID != SessionId ||
- delink.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ UpdateVector handlerUpdateVector = OnUpdatePrimGroupPosition;
- // It appears the prim at index 0 is not always the root prim (for
- // instance, when one prim of a link set has been edited independently
- // of the others). Therefore, we'll pass all the ids onto the delink
- // method for it to decide which is the root.
- List prims = new List();
- for (int i = 0; i < delink.ObjectData.Length; i++)
- {
- prims.Add(delink.ObjectData[i].ObjectLocalID);
- }
- handlerDelinkObjects = OnDelinkObjects;
- if (handlerDelinkObjects != null)
- {
- handlerDelinkObjects(prims);
- }
-
- break;
-
- case PacketType.ObjectAdd:
- if (OnAddPrim != null)
- {
- ObjectAddPacket addPacket = (ObjectAddPacket)Pack;
+ if (handlerUpdateVector != null)
+ {
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (addPacket.AgentData.SessionID != SessionId ||
- addPacket.AgentData.AgentID != AgentId)
+ handlerUpdateVector(localId, pos2, this);
+ }
break;
- }
- #endregion
+ case 10:
+ Quaternion rot3 = new Quaternion(block.Data, 0, true);
- PrimitiveBaseShape shape = GetShapeFromAddPacket(addPacket);
- // m_log.Info("[REZData]: " + addPacket.ToString());
- //BypassRaycast: 1
- //RayStart: <69.79469, 158.2652, 98.40343>
- //RayEnd: <61.97724, 141.995, 92.58341>
- //RayTargetID: 00000000-0000-0000-0000-000000000000
+ UpdatePrimRotation handlerUpdatePrimRotation = OnUpdatePrimGroupRotation;
+ if (handlerUpdatePrimRotation != null)
+ {
+ // Console.WriteLine("new rotation is " + rot3.X + " , " + rot3.Y + " , " + rot3.Z + " , " + rot3.W);
+ handlerUpdatePrimRotation(localId, rot3, this);
+ }
+ break;
+ case 11:
+ Vector3 pos3 = new Vector3(block.Data, 0);
+ Quaternion rot4 = new Quaternion(block.Data, 12, true);
- //Check to see if adding the prim is allowed; useful for any module wanting to restrict the
- //object from rezing initially
+ handlerUpdatePrimGroupRotation = OnUpdatePrimGroupMouseRotation;
+ if (handlerUpdatePrimGroupRotation != null)
+ {
+ // m_log.Debug("new rotation position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
+ // m_log.Debug("new group mouse rotation is " + rot4.X + " , " + rot4.Y + " , " + rot4.Z + " , " + rot4.W);
+ handlerUpdatePrimGroupRotation(localId, pos3, rot4, this);
+ }
+ break;
+ case 12:
+ case 28:
+ Vector3 scale7 = new Vector3(block.Data, 0);
- handlerAddPrim = OnAddPrim;
- if (handlerAddPrim != null)
- handlerAddPrim(AgentId, ActiveGroupId, addPacket.ObjectData.RayEnd, addPacket.ObjectData.Rotation, shape, addPacket.ObjectData.BypassRaycast, addPacket.ObjectData.RayStart, addPacket.ObjectData.RayTargetID, addPacket.ObjectData.RayEndIsIntersection);
- }
- break;
-
- case PacketType.ObjectShape:
- ObjectShapePacket shapePacket = (ObjectShapePacket)Pack;
+ UpdateVector handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
+ if (handlerUpdatePrimGroupScale != null)
+ {
+// m_log.Debug("new scale is " + scale7.X + " , " + scale7.Y + " , " + scale7.Z);
+ handlerUpdatePrimGroupScale(localId, scale7, this);
+ }
+ break;
+ case 13:
+ Vector3 scale2 = new Vector3(block.Data, 12);
+ Vector3 pos4 = new Vector3(block.Data, 0);
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (shapePacket.AgentData.SessionID != SessionId ||
- shapePacket.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+ //m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimScale(localId, scale2, this);
- handlerUpdatePrimShape = null;
- for (int i = 0; i < shapePacket.ObjectData.Length; i++)
- {
- handlerUpdatePrimShape = OnUpdatePrimShape;
- if (handlerUpdatePrimShape != null)
- {
- UpdateShapeArgs shapeData = new UpdateShapeArgs();
- shapeData.ObjectLocalID = shapePacket.ObjectData[i].ObjectLocalID;
- shapeData.PathBegin = shapePacket.ObjectData[i].PathBegin;
- shapeData.PathCurve = shapePacket.ObjectData[i].PathCurve;
- shapeData.PathEnd = shapePacket.ObjectData[i].PathEnd;
- shapeData.PathRadiusOffset = shapePacket.ObjectData[i].PathRadiusOffset;
- shapeData.PathRevolutions = shapePacket.ObjectData[i].PathRevolutions;
- shapeData.PathScaleX = shapePacket.ObjectData[i].PathScaleX;
- shapeData.PathScaleY = shapePacket.ObjectData[i].PathScaleY;
- shapeData.PathShearX = shapePacket.ObjectData[i].PathShearX;
- shapeData.PathShearY = shapePacket.ObjectData[i].PathShearY;
- shapeData.PathSkew = shapePacket.ObjectData[i].PathSkew;
- shapeData.PathTaperX = shapePacket.ObjectData[i].PathTaperX;
- shapeData.PathTaperY = shapePacket.ObjectData[i].PathTaperY;
- shapeData.PathTwist = shapePacket.ObjectData[i].PathTwist;
- shapeData.PathTwistBegin = shapePacket.ObjectData[i].PathTwistBegin;
- shapeData.ProfileBegin = shapePacket.ObjectData[i].ProfileBegin;
- shapeData.ProfileCurve = shapePacket.ObjectData[i].ProfileCurve;
- shapeData.ProfileEnd = shapePacket.ObjectData[i].ProfileEnd;
- shapeData.ProfileHollow = shapePacket.ObjectData[i].ProfileHollow;
+ // Change the position based on scale (for bug number 246)
+ handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ // m_log.Debug("new movement position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ handlerUpdatePrimSinglePosition(localId, pos4, this);
+ }
+ }
+ break;
+ case 29:
+ Vector3 scale5 = new Vector3(block.Data, 12);
+ Vector3 pos5 = new Vector3(block.Data, 0);
- handlerUpdatePrimShape(m_agentId, shapePacket.ObjectData[i].ObjectLocalID,
- shapeData);
- }
- }
- break;
-
- case PacketType.ObjectExtraParams:
- ObjectExtraParamsPacket extraPar = (ObjectExtraParamsPacket)Pack;
+ handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
+ if (handlerUpdatePrimGroupScale != null)
+ {
+ // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimGroupScale(localId, scale5, this);
+ handlerUpdateVector = OnUpdatePrimGroupPosition;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (extraPar.AgentData.SessionID != SessionId ||
- extraPar.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ if (handlerUpdateVector != null)
+ {
+ handlerUpdateVector(localId, pos5, this);
+ }
+ }
+ break;
+ case 21:
+ Vector3 scale6 = new Vector3(block.Data, 12);
+ Vector3 pos6 = new Vector3(block.Data, 0);
- handlerUpdateExtraParams = OnUpdateExtraParams;
- if (handlerUpdateExtraParams != null)
- {
- for (int i = 0 ; i < extraPar.ObjectData.Length ; i++)
- {
- handlerUpdateExtraParams(m_agentId, extraPar.ObjectData[i].ObjectLocalID,
- extraPar.ObjectData[i].ParamType,
- extraPar.ObjectData[i].ParamInUse, extraPar.ObjectData[i].ParamData);
+ handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+ // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimScale(localId, scale6, this);
+ handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ handlerUpdatePrimSinglePosition(localId, pos6, this);
+ }
+ }
+ break;
+ default:
+ m_log.Debug("[CLIENT] MultipleObjUpdate recieved an unknown packet type: " + (block.Type));
+ break;
}
}
- break;
- case PacketType.ObjectDuplicate:
- ObjectDuplicatePacket dupe = (ObjectDuplicatePacket)Pack;
+ }
+ }
+ return true;
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (dupe.AgentData.SessionID != SessionId ||
- dupe.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ public void RequestMapLayer()
+ {
+ //should be getting the map layer from the grid server
+ //send a layer covering the 800,800 - 1200,1200 area (should be covering the requested area)
+ MapLayerReplyPacket mapReply = (MapLayerReplyPacket)PacketPool.Instance.GetPacket(PacketType.MapLayerReply);
+ // TODO: don't create new blocks if recycling an old packet
+ mapReply.AgentData.AgentID = AgentId;
+ mapReply.AgentData.Flags = 0;
+ mapReply.LayerData = new MapLayerReplyPacket.LayerDataBlock[1];
+ mapReply.LayerData[0] = new MapLayerReplyPacket.LayerDataBlock();
+ mapReply.LayerData[0].Bottom = 0;
+ mapReply.LayerData[0].Left = 0;
+ mapReply.LayerData[0].Top = 30000;
+ mapReply.LayerData[0].Right = 30000;
+ mapReply.LayerData[0].ImageID = new UUID("00000000-0000-1111-9999-000000000006");
+ mapReply.Header.Zerocoded = true;
+ OutPacket(mapReply, ThrottleOutPacketType.Land);
+ }
- ObjectDuplicatePacket.AgentDataBlock AgentandGroupData = dupe.AgentData;
+ public void RequestMapBlocksX(int minX, int minY, int maxX, int maxY)
+ {
+ /*
+ IList simMapProfiles = m_gridServer.RequestMapBlocks(minX, minY, maxX, maxY);
+ MapBlockReplyPacket mbReply = new MapBlockReplyPacket();
+ mbReply.AgentData.AgentId = AgentId;
+ int len;
+ if (simMapProfiles == null)
+ len = 0;
+ else
+ len = simMapProfiles.Count;
- handlerObjectDuplicate = null;
+ mbReply.Data = new MapBlockReplyPacket.DataBlock[len];
+ int iii;
+ for (iii = 0; iii < len; iii++)
+ {
+ Hashtable mp = (Hashtable)simMapProfiles[iii];
+ mbReply.Data[iii] = new MapBlockReplyPacket.DataBlock();
+ mbReply.Data[iii].Name = Util.UTF8.GetBytes((string)mp["name"]);
+ mbReply.Data[iii].Access = System.Convert.ToByte(mp["access"]);
+ mbReply.Data[iii].Agents = System.Convert.ToByte(mp["agents"]);
+ mbReply.Data[iii].MapImageID = new UUID((string)mp["map-image-id"]);
+ mbReply.Data[iii].RegionFlags = System.Convert.ToUInt32(mp["region-flags"]);
+ mbReply.Data[iii].WaterHeight = System.Convert.ToByte(mp["water-height"]);
+ mbReply.Data[iii].X = System.Convert.ToUInt16(mp["x"]);
+ mbReply.Data[iii].Y = System.Convert.ToUInt16(mp["y"]);
+ }
+ this.OutPacket(mbReply, ThrottleOutPacketType.Land);
+ */
+ }
- for (int i = 0; i < dupe.ObjectData.Length; i++)
- {
- handlerObjectDuplicate = OnObjectDuplicate;
- if (handlerObjectDuplicate != null)
- {
- handlerObjectDuplicate(dupe.ObjectData[i].ObjectLocalID, dupe.SharedData.Offset,
- dupe.SharedData.DuplicateFlags, AgentandGroupData.AgentID,
- AgentandGroupData.GroupID);
- }
- }
+ ///
+ /// Sets the throttles from values supplied by the client
+ ///
+ ///
+ public void SetChildAgentThrottle(byte[] throttles)
+ {
+ m_udpClient.SetThrottles(throttles);
+ }
- break;
+ public byte[] GetThrottlesPacked(float multiplier)
+ {
+ return m_udpClient.GetThrottlesPacked();
+ }
- case PacketType.RequestMultipleObjects:
- RequestMultipleObjectsPacket incomingRequest = (RequestMultipleObjectsPacket)Pack;
+ public bool IsThrottleEmpty(ThrottleOutPacketType category)
+ {
+ return m_udpClient.IsThrottleEmpty(category);
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (incomingRequest.AgentData.SessionID != SessionId ||
- incomingRequest.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ ///
+ /// Unused
+ ///
+ public virtual void InPacket(object NewPack)
+ {
+ throw new NotImplementedException();
+ }
- handlerObjectRequest = null;
+ ///
+ /// This is the starting point for sending a simulator packet out to the client
+ ///
+ /// Packet to send
+ /// Throttling category for the packet
+ private void OutPacket(Packet packet, ThrottleOutPacketType throttlePacketType)
+ {
+ m_udpServer.SendPacket(m_udpClient, packet, throttlePacketType, true);
+ }
- for (int i = 0; i < incomingRequest.ObjectData.Length; i++)
- {
- handlerObjectRequest = OnObjectRequest;
- if (handlerObjectRequest != null)
- {
- handlerObjectRequest(incomingRequest.ObjectData[i].ID, this);
- }
- }
- break;
- case PacketType.ObjectSelect:
- ObjectSelectPacket incomingselect = (ObjectSelectPacket)Pack;
+ public bool AddMoney(int debit)
+ {
+ if (m_moneyBalance + debit >= 0)
+ {
+ m_moneyBalance += debit;
+ SendMoneyBalance(UUID.Zero, true, Utils.StringToBytes("Poof Poof!"), m_moneyBalance);
+ return true;
+ }
+ return false;
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
+ ///
+ /// Breaks down the genericMessagePacket into specific events
+ ///
+ ///
+ ///
+ ///
+ public void DecipherGenericMessage(string gmMethod, UUID gmInvoice, GenericMessagePacket.ParamListBlock[] gmParams)
+ {
+ switch (gmMethod)
+ {
+ case "autopilot":
+ float locx;
+ float locy;
+ float locz;
+
+ try
{
- if (incomingselect.AgentData.SessionID != SessionId ||
- incomingselect.AgentData.AgentID != AgentId)
- break;
+ uint regionX;
+ uint regionY;
+ Utils.LongToUInts(Scene.RegionInfo.RegionHandle, out regionX, out regionY);
+ locx = Convert.ToSingle(Utils.BytesToString(gmParams[0].Parameter)) - regionX;
+ locy = Convert.ToSingle(Utils.BytesToString(gmParams[1].Parameter)) - regionY;
+ locz = Convert.ToSingle(Utils.BytesToString(gmParams[2].Parameter));
}
- #endregion
-
- handlerObjectSelect = null;
-
- for (int i = 0; i < incomingselect.ObjectData.Length; i++)
+ catch (InvalidCastException)
{
- handlerObjectSelect = OnObjectSelect;
- if (handlerObjectSelect != null)
- {
- handlerObjectSelect(incomingselect.ObjectData[i].ObjectLocalID, this);
- }
+ m_log.Error("[CLIENT]: Invalid autopilot request");
+ return;
}
- break;
- case PacketType.ObjectDeselect:
- ObjectDeselectPacket incomingdeselect = (ObjectDeselectPacket)Pack;
- #region Packet Session and User Check
- if (m_checkPackets)
+ UpdateVector handlerAutoPilotGo = OnAutoPilotGo;
+ if (handlerAutoPilotGo != null)
{
- if (incomingdeselect.AgentData.SessionID != SessionId ||
- incomingdeselect.AgentData.AgentID != AgentId)
- break;
+ handlerAutoPilotGo(0, new Vector3(locx, locy, locz), this);
}
- #endregion
+ m_log.InfoFormat("[CLIENT]: Client Requests autopilot to position <{0},{1},{2}>", locx, locy, locz);
- handlerObjectDeselect = null;
- for (int i = 0; i < incomingdeselect.ObjectData.Length; i++)
- {
- handlerObjectDeselect = OnObjectDeselect;
- if (handlerObjectDeselect != null)
- {
- OnObjectDeselect(incomingdeselect.ObjectData[i].ObjectLocalID, this);
- }
- }
break;
- case PacketType.ObjectPosition:
- // DEPRECATED: but till libsecondlife removes it, people will use it
- ObjectPositionPacket position = (ObjectPositionPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
+ default:
+ m_log.Debug("[CLIENT]: Unknown Generic Message, Method: " + gmMethod + ". Invoice: " + gmInvoice + ". Dumping Params:");
+ for (int hi = 0; hi < gmParams.Length; hi++)
{
- if (position.AgentData.SessionID != SessionId ||
- position.AgentData.AgentID != AgentId)
- break;
+ Console.WriteLine(gmParams[hi].ToString());
}
- #endregion
+ //gmpack.MethodData.
+ break;
+ }
+ }
- for (int i = 0; i < position.ObjectData.Length; i++)
- {
- handlerUpdateVector = OnUpdatePrimGroupPosition;
- if (handlerUpdateVector != null)
- handlerUpdateVector(position.ObjectData[i].ObjectLocalID, position.ObjectData[i].Position, this);
- }
+ ///
+ /// Entryway from the client to the simulator. All UDP packets from the client will end up here
+ ///
+ /// OpenMetaverse.packet
+ public void ProcessInPacket(Packet Pack)
+ {
- break;
- case PacketType.ObjectScale:
- // DEPRECATED: but till libsecondlife removes it, people will use it
- ObjectScalePacket scale = (ObjectScalePacket)Pack;
+ if (ProcessPacketMethod(Pack))
+ {
+ return;
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (scale.AgentData.SessionID != SessionId ||
- scale.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ const bool m_checkPackets = true;
- for (int i = 0; i < scale.ObjectData.Length; i++)
- {
- handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
- if (handlerUpdatePrimGroupScale != null)
- handlerUpdatePrimGroupScale(scale.ObjectData[i].ObjectLocalID, scale.ObjectData[i].Scale, this);
- }
+ // Main packet processing conditional
+ switch (Pack.Type)
+ {
+ #region Scene/Avatar
- break;
- case PacketType.ObjectRotation:
- // DEPRECATED: but till libsecondlife removes it, people will use it
- ObjectRotationPacket rotation = (ObjectRotationPacket)Pack;
+ case PacketType.AvatarPropertiesRequest:
+ AvatarPropertiesRequestPacket avatarProperties = (AvatarPropertiesRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (rotation.AgentData.SessionID != SessionId ||
- rotation.AgentData.AgentID != AgentId)
+ if (avatarProperties.AgentData.SessionID != SessionId ||
+ avatarProperties.AgentData.AgentID != AgentId)
break;
}
#endregion
- for (int i = 0; i < rotation.ObjectData.Length; i++)
+ RequestAvatarProperties handlerRequestAvatarProperties = OnRequestAvatarProperties;
+ if (handlerRequestAvatarProperties != null)
{
- handlerUpdatePrimRotation = OnUpdatePrimGroupRotation;
- if (handlerUpdatePrimRotation != null)
- handlerUpdatePrimRotation(rotation.ObjectData[i].ObjectLocalID, rotation.ObjectData[i].Rotation, this);
+ handlerRequestAvatarProperties(this, avatarProperties.AgentData.AvatarID);
}
break;
- case PacketType.ObjectFlagUpdate:
- ObjectFlagUpdatePacket flags = (ObjectFlagUpdatePacket)Pack;
+
+ case PacketType.ChatFromViewer:
+ ChatFromViewerPacket inchatpack = (ChatFromViewerPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (flags.AgentData.SessionID != SessionId ||
- flags.AgentData.AgentID != AgentId)
+ if (inchatpack.AgentData.SessionID != SessionId ||
+ inchatpack.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerUpdatePrimFlags = OnUpdatePrimFlags;
-
- if (handlerUpdatePrimFlags != null)
- {
- byte[] data = Pack.ToBytes();
- // 46,47,48 are special positions within the packet
- // This may change so perhaps we need a better way
- // of storing this (OMV.FlagUpdatePacket.UsePhysics,etc?)
- bool UsePhysics = (data[46] != 0) ? true : false;
- bool IsTemporary = (data[47] != 0) ? true : false;
- bool IsPhantom = (data[48] != 0) ? true : false;
- handlerUpdatePrimFlags(flags.AgentData.ObjectLocalID, UsePhysics, IsTemporary, IsPhantom, this);
- }
- break;
- case PacketType.ObjectImage:
- ObjectImagePacket imagePack = (ObjectImagePacket)Pack;
+ string fromName = String.Empty; //ClientAvatar.firstname + " " + ClientAvatar.lastname;
+ byte[] message = inchatpack.ChatData.Message;
+ byte type = inchatpack.ChatData.Type;
+ Vector3 fromPos = new Vector3(); // ClientAvatar.Pos;
+ // UUID fromAgentID = AgentId;
- handlerUpdatePrimTexture = null;
- for (int i = 0; i < imagePack.ObjectData.Length; i++)
- {
- handlerUpdatePrimTexture = OnUpdatePrimTexture;
- if (handlerUpdatePrimTexture != null)
- {
- handlerUpdatePrimTexture(imagePack.ObjectData[i].ObjectLocalID,
- imagePack.ObjectData[i].TextureEntry, this);
- }
- }
- break;
- case PacketType.ObjectGrab:
- ObjectGrabPacket grab = (ObjectGrabPacket)Pack;
+ int channel = inchatpack.ChatData.Channel;
- #region Packet Session and User Check
- if (m_checkPackets)
+ if (OnChatFromClient != null)
{
- if (grab.AgentData.SessionID != SessionId ||
- grab.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
-
- handlerGrabObject = OnGrabObject;
+ OSChatMessage args = new OSChatMessage();
+ args.Channel = channel;
+ args.From = fromName;
+ args.Message = Utils.BytesToString(message);
+ args.Type = (ChatTypeEnum)type;
+ args.Position = fromPos;
- if (handlerGrabObject != null)
- {
- List touchArgs = new List();
- if ((grab.SurfaceInfo != null) && (grab.SurfaceInfo.Length > 0))
- {
- foreach (ObjectGrabPacket.SurfaceInfoBlock surfaceInfo in grab.SurfaceInfo)
- {
- SurfaceTouchEventArgs arg = new SurfaceTouchEventArgs();
- arg.Binormal = surfaceInfo.Binormal;
- arg.FaceIndex = surfaceInfo.FaceIndex;
- arg.Normal = surfaceInfo.Normal;
- arg.Position = surfaceInfo.Position;
- arg.STCoord = surfaceInfo.STCoord;
- arg.UVCoord = surfaceInfo.UVCoord;
- touchArgs.Add(arg);
- }
- }
- handlerGrabObject(grab.ObjectData.LocalID, grab.ObjectData.GrabOffset, this, touchArgs);
+ args.Scene = Scene;
+ args.Sender = this;
+ args.SenderUUID = this.AgentId;
+
+ ChatMessage handlerChatFromClient = OnChatFromClient;
+ if (handlerChatFromClient != null)
+ handlerChatFromClient(this, args);
}
break;
- case PacketType.ObjectGrabUpdate:
- ObjectGrabUpdatePacket grabUpdate = (ObjectGrabUpdatePacket)Pack;
+
+ case PacketType.AvatarPropertiesUpdate:
+ AvatarPropertiesUpdatePacket avatarProps = (AvatarPropertiesUpdatePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (grabUpdate.AgentData.SessionID != SessionId ||
- grabUpdate.AgentData.AgentID != AgentId)
+ if (avatarProps.AgentData.SessionID != SessionId ||
+ avatarProps.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerGrabUpdate = OnGrabUpdate;
-
- if (handlerGrabUpdate != null)
+ UpdateAvatarProperties handlerUpdateAvatarProperties = OnUpdateAvatarProperties;
+ if (handlerUpdateAvatarProperties != null)
{
- List touchArgs = new List();
- if ((grabUpdate.SurfaceInfo != null) && (grabUpdate.SurfaceInfo.Length > 0))
- {
- foreach (ObjectGrabUpdatePacket.SurfaceInfoBlock surfaceInfo in grabUpdate.SurfaceInfo)
- {
- SurfaceTouchEventArgs arg = new SurfaceTouchEventArgs();
- arg.Binormal = surfaceInfo.Binormal;
- arg.FaceIndex = surfaceInfo.FaceIndex;
- arg.Normal = surfaceInfo.Normal;
- arg.Position = surfaceInfo.Position;
- arg.STCoord = surfaceInfo.STCoord;
- arg.UVCoord = surfaceInfo.UVCoord;
- touchArgs.Add(arg);
- }
- }
- handlerGrabUpdate(grabUpdate.ObjectData.ObjectID, grabUpdate.ObjectData.GrabOffsetInitial,
- grabUpdate.ObjectData.GrabPosition, this, touchArgs);
+ AvatarPropertiesUpdatePacket.PropertiesDataBlock Properties = avatarProps.PropertiesData;
+ UserProfileData UserProfile = new UserProfileData();
+ UserProfile.ID = AgentId;
+ UserProfile.AboutText = Utils.BytesToString(Properties.AboutText);
+ UserProfile.FirstLifeAboutText = Utils.BytesToString(Properties.FLAboutText);
+ UserProfile.FirstLifeImage = Properties.FLImageID;
+ UserProfile.Image = Properties.ImageID;
+ UserProfile.ProfileUrl = Utils.BytesToString(Properties.ProfileURL);
+
+ handlerUpdateAvatarProperties(this, UserProfile);
}
break;
- case PacketType.ObjectDeGrab:
- ObjectDeGrabPacket deGrab = (ObjectDeGrabPacket)Pack;
+
+ case PacketType.ScriptDialogReply:
+ ScriptDialogReplyPacket rdialog = (ScriptDialogReplyPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (deGrab.AgentData.SessionID != SessionId ||
- deGrab.AgentData.AgentID != AgentId)
+ if (rdialog.AgentData.SessionID != SessionId ||
+ rdialog.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerDeGrabObject = OnDeGrabObject;
- if (handlerDeGrabObject != null)
+ int ch = rdialog.Data.ChatChannel;
+ byte[] msg = rdialog.Data.ButtonLabel;
+ if (OnChatFromClient != null)
{
- List touchArgs = new List();
- if ((deGrab.SurfaceInfo != null) && (deGrab.SurfaceInfo.Length > 0))
- {
- foreach (ObjectDeGrabPacket.SurfaceInfoBlock surfaceInfo in deGrab.SurfaceInfo)
- {
- SurfaceTouchEventArgs arg = new SurfaceTouchEventArgs();
- arg.Binormal = surfaceInfo.Binormal;
- arg.FaceIndex = surfaceInfo.FaceIndex;
- arg.Normal = surfaceInfo.Normal;
- arg.Position = surfaceInfo.Position;
- arg.STCoord = surfaceInfo.STCoord;
- arg.UVCoord = surfaceInfo.UVCoord;
- touchArgs.Add(arg);
- }
- }
- handlerDeGrabObject(deGrab.ObjectData.LocalID, this, touchArgs);
+ OSChatMessage args = new OSChatMessage();
+ args.Channel = ch;
+ args.From = String.Empty;
+ args.Message = Utils.BytesToString(msg);
+ args.Type = ChatTypeEnum.Shout;
+ args.Position = new Vector3();
+ args.Scene = Scene;
+ args.Sender = this;
+ ChatMessage handlerChatFromClient2 = OnChatFromClient;
+ if (handlerChatFromClient2 != null)
+ handlerChatFromClient2(this, args);
}
+
break;
- case PacketType.ObjectSpinStart:
- //m_log.Warn("[CLIENT]: unhandled ObjectSpinStart packet");
- ObjectSpinStartPacket spinStart = (ObjectSpinStartPacket)Pack;
+
+ case PacketType.ImprovedInstantMessage:
+ ImprovedInstantMessagePacket msgpack = (ImprovedInstantMessagePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (spinStart.AgentData.SessionID != SessionId ||
- spinStart.AgentData.AgentID != AgentId)
+ if (msgpack.AgentData.SessionID != SessionId ||
+ msgpack.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerSpinStart = OnSpinStart;
- if (handlerSpinStart != null)
+ string IMfromName = Util.FieldToString(msgpack.MessageBlock.FromAgentName);
+ string IMmessage = Utils.BytesToString(msgpack.MessageBlock.Message);
+ ImprovedInstantMessage handlerInstantMessage = OnInstantMessage;
+
+ if (handlerInstantMessage != null)
{
- handlerSpinStart(spinStart.ObjectData.ObjectID, this);
+ GridInstantMessage im = new GridInstantMessage(Scene,
+ msgpack.AgentData.AgentID,
+ IMfromName,
+ msgpack.MessageBlock.ToAgentID,
+ msgpack.MessageBlock.Dialog,
+ msgpack.MessageBlock.FromGroup,
+ IMmessage,
+ msgpack.MessageBlock.ID,
+ msgpack.MessageBlock.Offline != 0 ? true : false,
+ msgpack.MessageBlock.Position,
+ msgpack.MessageBlock.BinaryBucket);
+
+ handlerInstantMessage(this, im);
}
break;
- case PacketType.ObjectSpinUpdate:
- //m_log.Warn("[CLIENT]: unhandled ObjectSpinUpdate packet");
- ObjectSpinUpdatePacket spinUpdate = (ObjectSpinUpdatePacket)Pack;
+
+ case PacketType.AcceptFriendship:
+ AcceptFriendshipPacket afriendpack = (AcceptFriendshipPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (spinUpdate.AgentData.SessionID != SessionId ||
- spinUpdate.AgentData.AgentID != AgentId)
+ if (afriendpack.AgentData.SessionID != SessionId ||
+ afriendpack.AgentData.AgentID != AgentId)
break;
}
#endregion
- Vector3 axis;
- float angle;
- spinUpdate.ObjectData.Rotation.GetAxisAngle(out axis, out angle);
- //m_log.Warn("[CLIENT]: ObjectSpinUpdate packet rot axis:" + axis + " angle:" + angle);
+ // My guess is this is the folder to stick the calling card into
+ List callingCardFolders = new List();
- handlerSpinUpdate = OnSpinUpdate;
- if (handlerSpinUpdate != null)
+ UUID agentID = afriendpack.AgentData.AgentID;
+ UUID transactionID = afriendpack.TransactionBlock.TransactionID;
+
+ for (int fi = 0; fi < afriendpack.FolderData.Length; fi++)
{
- handlerSpinUpdate(spinUpdate.ObjectData.ObjectID, spinUpdate.ObjectData.Rotation, this);
+ callingCardFolders.Add(afriendpack.FolderData[fi].FolderID);
+ }
+
+ FriendActionDelegate handlerApproveFriendRequest = OnApproveFriendRequest;
+ if (handlerApproveFriendRequest != null)
+ {
+ handlerApproveFriendRequest(this, agentID, transactionID, callingCardFolders);
}
break;
- case PacketType.ObjectSpinStop:
- //m_log.Warn("[CLIENT]: unhandled ObjectSpinStop packet");
- ObjectSpinStopPacket spinStop = (ObjectSpinStopPacket)Pack;
+
+ case PacketType.DeclineFriendship:
+ DeclineFriendshipPacket dfriendpack = (DeclineFriendshipPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (spinStop.AgentData.SessionID != SessionId ||
- spinStop.AgentData.AgentID != AgentId)
+ if (dfriendpack.AgentData.SessionID != SessionId ||
+ dfriendpack.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerSpinStop = OnSpinStop;
- if (handlerSpinStop != null)
+ if (OnDenyFriendRequest != null)
{
- handlerSpinStop(spinStop.ObjectData.ObjectID, this);
+ OnDenyFriendRequest(this,
+ dfriendpack.AgentData.AgentID,
+ dfriendpack.TransactionBlock.TransactionID,
+ null);
}
break;
- case PacketType.ObjectDescription:
- ObjectDescriptionPacket objDes = (ObjectDescriptionPacket)Pack;
+ case PacketType.TerminateFriendship:
+ TerminateFriendshipPacket tfriendpack = (TerminateFriendshipPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (objDes.AgentData.SessionID != SessionId ||
- objDes.AgentData.AgentID != AgentId)
+ if (tfriendpack.AgentData.SessionID != SessionId ||
+ tfriendpack.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerObjectDescription = null;
+ UUID listOwnerAgentID = tfriendpack.AgentData.AgentID;
+ UUID exFriendID = tfriendpack.ExBlock.OtherID;
- for (int i = 0; i < objDes.ObjectData.Length; i++)
+ FriendshipTermination handlerTerminateFriendship = OnTerminateFriendship;
+ if (handlerTerminateFriendship != null)
{
- handlerObjectDescription = OnObjectDescription;
- if (handlerObjectDescription != null)
- {
- handlerObjectDescription(this, objDes.ObjectData[i].LocalID,
- Util.FieldToString(objDes.ObjectData[i].Description));
- }
+ handlerTerminateFriendship(this, listOwnerAgentID, exFriendID);
}
break;
- case PacketType.ObjectName:
- ObjectNamePacket objName = (ObjectNamePacket)Pack;
-
+
+ case PacketType.RezObject:
+ RezObjectPacket rezPacket = (RezObjectPacket)Pack;
+
#region Packet Session and User Check
if (m_checkPackets)
{
- if (objName.AgentData.SessionID != SessionId ||
- objName.AgentData.AgentID != AgentId)
+ if (rezPacket.AgentData.SessionID != SessionId ||
+ rezPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
-
- handlerObjectName = null;
- for (int i = 0; i < objName.ObjectData.Length; i++)
- {
- handlerObjectName = OnObjectName;
- if (handlerObjectName != null)
- {
- handlerObjectName(this, objName.ObjectData[i].LocalID,
- Util.FieldToString(objName.ObjectData[i].Name));
- }
- }
- break;
- case PacketType.ObjectPermissions:
- if (OnObjectPermissions != null)
- {
- ObjectPermissionsPacket newobjPerms = (ObjectPermissionsPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (newobjPerms.AgentData.SessionID != SessionId ||
- newobjPerms.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
-
- UUID AgentID = newobjPerms.AgentData.AgentID;
- UUID SessionID = newobjPerms.AgentData.SessionID;
-
- handlerObjectPermissions = null;
-
- for (int i = 0; i < newobjPerms.ObjectData.Length; i++)
- {
- ObjectPermissionsPacket.ObjectDataBlock permChanges = newobjPerms.ObjectData[i];
-
- byte field = permChanges.Field;
- uint localID = permChanges.ObjectLocalID;
- uint mask = permChanges.Mask;
- byte set = permChanges.Set;
- handlerObjectPermissions = OnObjectPermissions;
-
- if (handlerObjectPermissions != null)
- handlerObjectPermissions(this, AgentID, SessionID, field, localID, mask, set);
- }
+ RezObject handlerRezObject = OnRezObject;
+ if (handlerRezObject != null)
+ {
+ handlerRezObject(this, rezPacket.InventoryData.ItemID, rezPacket.RezData.RayEnd,
+ rezPacket.RezData.RayStart, rezPacket.RezData.RayTargetID,
+ rezPacket.RezData.BypassRaycast, rezPacket.RezData.RayEndIsIntersection,
+ rezPacket.RezData.RezSelected, rezPacket.RezData.RemoveItem,
+ rezPacket.RezData.FromTaskID);
}
-
- // Here's our data,
- // PermField contains the field the info goes into
- // PermField determines which mask we're changing
- //
- // chmask is the mask of the change
- // setTF is whether we're adding it or taking it away
- //
- // objLocalID is the localID of the object.
-
- // Unfortunately, we have to pass the event the packet because objData is an array
- // That means multiple object perms may be updated in a single packet.
-
break;
- case PacketType.Undo:
- UndoPacket undoitem = (UndoPacket)Pack;
+ case PacketType.DeRezObject:
+ DeRezObjectPacket DeRezPacket = (DeRezObjectPacket) Pack;
#region Packet Session and User Check
if (m_checkPackets)
- {
- if (undoitem.AgentData.SessionID != SessionId ||
- undoitem.AgentData.AgentID != AgentId)
+ {
+ if (DeRezPacket.AgentData.SessionID != SessionId ||
+ DeRezPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (undoitem.ObjectData.Length > 0)
+ DeRezObject handlerDeRezObject = OnDeRezObject;
+ if (handlerDeRezObject != null)
{
- for (int i = 0; i < undoitem.ObjectData.Length; i++)
- {
- UUID objiD = undoitem.ObjectData[i].ObjectID;
- handlerOnUndo = OnUndo;
- if (handlerOnUndo != null)
- {
- handlerOnUndo(this, objiD);
- }
+ List deRezIDs = new List();
+ foreach (DeRezObjectPacket.ObjectDataBlock data in
+ DeRezPacket.ObjectData)
+ {
+ deRezIDs.Add(data.ObjectLocalID);
}
+ // It just so happens that the values on the DeRezAction enumerator match the Destination
+ // values given by a Second Life client
+ handlerDeRezObject(this, deRezIDs,
+ DeRezPacket.AgentBlock.GroupID,
+ (DeRezAction)DeRezPacket.AgentBlock.Destination,
+ DeRezPacket.AgentBlock.DestinationID);
+
}
break;
- case PacketType.ObjectDuplicateOnRay:
- ObjectDuplicateOnRayPacket dupeOnRay = (ObjectDuplicateOnRayPacket)Pack;
+
+ case PacketType.ModifyLand:
+ ModifyLandPacket modify = (ModifyLandPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (dupeOnRay.AgentData.SessionID != SessionId ||
- dupeOnRay.AgentData.AgentID != AgentId)
+ if (modify.AgentData.SessionID != SessionId ||
+ modify.AgentData.AgentID != AgentId)
break;
}
- #endregion
-
- handlerObjectDuplicateOnRay = null;
-
- for (int i = 0; i < dupeOnRay.ObjectData.Length; i++)
+ #endregion
+ //m_log.Info("[LAND]: LAND:" + modify.ToString());
+ if (modify.ParcelData.Length > 0)
{
- handlerObjectDuplicateOnRay = OnObjectDuplicateOnRay;
- if (handlerObjectDuplicateOnRay != null)
+ if (OnModifyTerrain != null)
{
- handlerObjectDuplicateOnRay(dupeOnRay.ObjectData[i].ObjectLocalID, dupeOnRay.AgentData.DuplicateFlags,
- dupeOnRay.AgentData.AgentID, dupeOnRay.AgentData.GroupID, dupeOnRay.AgentData.RayTargetID, dupeOnRay.AgentData.RayEnd,
- dupeOnRay.AgentData.RayStart, dupeOnRay.AgentData.BypassRaycast, dupeOnRay.AgentData.RayEndIsIntersection,
- dupeOnRay.AgentData.CopyCenters, dupeOnRay.AgentData.CopyRotates);
+ for (int i = 0; i < modify.ParcelData.Length; i++)
+ {
+ ModifyTerrain handlerModifyTerrain = OnModifyTerrain;
+ if (handlerModifyTerrain != null)
+ {
+ handlerModifyTerrain(AgentId, modify.ModifyBlock.Height, modify.ModifyBlock.Seconds,
+ modify.ModifyBlock.BrushSize,
+ modify.ModifyBlock.Action, modify.ParcelData[i].North,
+ modify.ParcelData[i].West, modify.ParcelData[i].South,
+ modify.ParcelData[i].East, AgentId);
+ }
+ }
}
}
break;
- case PacketType.RequestObjectPropertiesFamily:
- //This powers the little tooltip that appears when you move your mouse over an object
- RequestObjectPropertiesFamilyPacket packToolTip = (RequestObjectPropertiesFamilyPacket)Pack;
- #region Packet Session and User Check
- if (m_checkPackets)
+ case PacketType.RegionHandshakeReply:
+
+ Action handlerRegionHandShakeReply = OnRegionHandShakeReply;
+ if (handlerRegionHandShakeReply != null)
{
- if (packToolTip.AgentData.SessionID != SessionId ||
- packToolTip.AgentData.AgentID != AgentId)
- break;
+ handlerRegionHandShakeReply(this);
}
- #endregion
- RequestObjectPropertiesFamilyPacket.ObjectDataBlock packObjBlock = packToolTip.ObjectData;
+ break;
- handlerRequestObjectPropertiesFamily = OnRequestObjectPropertiesFamily;
+ case PacketType.AgentWearablesRequest:
+ GenericCall2 handlerRequestWearables = OnRequestWearables;
- if (handlerRequestObjectPropertiesFamily != null)
+ if (handlerRequestWearables != null)
{
- handlerRequestObjectPropertiesFamily(this, m_agentId, packObjBlock.RequestFlags,
- packObjBlock.ObjectID);
+ handlerRequestWearables();
+ }
+
+ Action handlerRequestAvatarsData = OnRequestAvatarsData;
+
+ if (handlerRequestAvatarsData != null)
+ {
+ handlerRequestAvatarsData(this);
}
break;
- case PacketType.ObjectIncludeInSearch:
- //This lets us set objects to appear in search (stuff like DataSnapshot, etc)
- ObjectIncludeInSearchPacket packInSearch = (ObjectIncludeInSearchPacket)Pack;
- handlerObjectIncludeInSearch = null;
+
+ case PacketType.AgentSetAppearance:
+ AgentSetAppearancePacket appear = (AgentSetAppearancePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (packInSearch.AgentData.SessionID != SessionId ||
- packInSearch.AgentData.AgentID != AgentId)
+ if (appear.AgentData.SessionID != SessionId ||
+ appear.AgentData.AgentID != AgentId)
break;
}
#endregion
- foreach (ObjectIncludeInSearchPacket.ObjectDataBlock objData in packInSearch.ObjectData)
+ SetAppearance handlerSetAppearance = OnSetAppearance;
+ if (handlerSetAppearance != null)
{
- bool inSearch = objData.IncludeInSearch;
- uint localID = objData.ObjectLocalID;
+ // Temporarily protect ourselves from the mantis #951 failure.
+ // However, we could do this for several other handlers where a failure isn't terminal
+ // for the client session anyway, in order to protect ourselves against bad code in plugins
+ try
+ {
+ byte[] visualparams = new byte[appear.VisualParam.Length];
+ for (int i = 0; i < appear.VisualParam.Length; i++)
+ visualparams[i] = appear.VisualParam[i].ParamValue;
- handlerObjectIncludeInSearch = OnObjectIncludeInSearch;
+ Primitive.TextureEntry te = null;
+ if (appear.ObjectData.TextureEntry.Length > 1)
+ te = new Primitive.TextureEntry(appear.ObjectData.TextureEntry, 0, appear.ObjectData.TextureEntry.Length);
- if (handlerObjectIncludeInSearch != null)
+ handlerSetAppearance(te, visualparams);
+ }
+ catch (Exception e)
{
- handlerObjectIncludeInSearch(this, inSearch, localID);
+ m_log.ErrorFormat(
+ "[CLIENT VIEW]: AgentSetApperance packet handler threw an exception, {0}",
+ e);
}
}
+
break;
+
+ case PacketType.AgentIsNowWearing:
+ if (OnAvatarNowWearing != null)
+ {
+ AgentIsNowWearingPacket nowWearing = (AgentIsNowWearingPacket)Pack;
- case PacketType.ScriptAnswerYes:
- ScriptAnswerYesPacket scriptAnswer = (ScriptAnswerYesPacket)Pack;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (nowWearing.AgentData.SessionID != SessionId ||
+ nowWearing.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (scriptAnswer.AgentData.SessionID != SessionId ||
- scriptAnswer.AgentData.AgentID != AgentId)
- break;
+ AvatarWearingArgs wearingArgs = new AvatarWearingArgs();
+ for (int i = 0; i < nowWearing.WearableData.Length; i++)
+ {
+ AvatarWearingArgs.Wearable wearable =
+ new AvatarWearingArgs.Wearable(nowWearing.WearableData[i].ItemID,
+ nowWearing.WearableData[i].WearableType);
+ wearingArgs.NowWearing.Add(wearable);
+ }
+
+ AvatarNowWearing handlerAvatarNowWearing = OnAvatarNowWearing;
+ if (handlerAvatarNowWearing != null)
+ {
+ handlerAvatarNowWearing(this, wearingArgs);
+ }
}
- #endregion
+ break;
- handlerScriptAnswer = OnScriptAnswer;
- if (handlerScriptAnswer != null)
+ case PacketType.RezSingleAttachmentFromInv:
+ RezSingleAttachmentFromInv handlerRezSingleAttachment = OnRezSingleAttachmentFromInv;
+ if (handlerRezSingleAttachment != null)
{
- handlerScriptAnswer(this, scriptAnswer.Data.TaskID, scriptAnswer.Data.ItemID, scriptAnswer.Data.Questions);
+ RezSingleAttachmentFromInvPacket rez = (RezSingleAttachmentFromInvPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (rez.AgentData.SessionID != SessionId ||
+ rez.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ handlerRezSingleAttachment(this, rez.ObjectData.ItemID,
+ rez.ObjectData.AttachmentPt);
}
+
break;
- case PacketType.ObjectClickAction:
- ObjectClickActionPacket ocpacket = (ObjectClickActionPacket)Pack;
+ case PacketType.RezMultipleAttachmentsFromInv:
+ RezMultipleAttachmentsFromInv handlerRezMultipleAttachments = OnRezMultipleAttachmentsFromInv;
+ if (handlerRezMultipleAttachments != null)
+ {
+ RezMultipleAttachmentsFromInvPacket rez = (RezMultipleAttachmentsFromInvPacket)Pack;
+ handlerRezMultipleAttachments(this, rez.HeaderData,
+ rez.ObjectData);
+ }
- #region Packet Session and User Check
- if (m_checkPackets)
+ break;
+
+ case PacketType.DetachAttachmentIntoInv:
+ UUIDNameRequest handlerDetachAttachmentIntoInv = OnDetachAttachmentIntoInv;
+ if (handlerDetachAttachmentIntoInv != null)
{
- if (ocpacket.AgentData.SessionID != SessionId ||
- ocpacket.AgentData.AgentID != AgentId)
- break;
+ DetachAttachmentIntoInvPacket detachtoInv = (DetachAttachmentIntoInvPacket)Pack;
+
+ #region Packet Session and User Check
+ // UNSUPPORTED ON THIS PACKET
+ #endregion
+
+ UUID itemID = detachtoInv.ObjectData.ItemID;
+ // UUID ATTACH_agentID = detachtoInv.ObjectData.AgentID;
+
+ handlerDetachAttachmentIntoInv(itemID, this);
}
- #endregion
+ break;
- handlerObjectClickAction = OnObjectClickAction;
- if (handlerObjectClickAction != null)
+ case PacketType.ObjectAttach:
+ if (OnObjectAttach != null)
{
- foreach (ObjectClickActionPacket.ObjectDataBlock odata in ocpacket.ObjectData)
+ ObjectAttachPacket att = (ObjectAttachPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- byte action = odata.ClickAction;
- uint localID = odata.ObjectLocalID;
- handlerObjectClickAction(this, localID, action.ToString());
+ if (att.AgentData.SessionID != SessionId ||
+ att.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ ObjectAttach handlerObjectAttach = OnObjectAttach;
+
+ if (handlerObjectAttach != null)
+ {
+ if (att.ObjectData.Length > 0)
+ {
+ handlerObjectAttach(this, att.ObjectData[0].ObjectLocalID, att.AgentData.AttachmentPoint, att.ObjectData[0].Rotation, false);
+ }
}
}
break;
- case PacketType.ObjectMaterial:
- ObjectMaterialPacket ompacket = (ObjectMaterialPacket)Pack;
+ case PacketType.ObjectDetach:
+ ObjectDetachPacket dett = (ObjectDetachPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (ompacket.AgentData.SessionID != SessionId ||
- ompacket.AgentData.AgentID != AgentId)
+ if (dett.AgentData.SessionID != SessionId ||
+ dett.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerObjectMaterial = OnObjectMaterial;
- if (handlerObjectMaterial != null)
+ for (int j = 0; j < dett.ObjectData.Length; j++)
{
- foreach (ObjectMaterialPacket.ObjectDataBlock odata in ompacket.ObjectData)
+ uint obj = dett.ObjectData[j].ObjectLocalID;
+ ObjectDeselect handlerObjectDetach = OnObjectDetach;
+ if (handlerObjectDetach != null)
{
- byte material = odata.Material;
- uint localID = odata.ObjectLocalID;
- handlerObjectMaterial(this, localID, material.ToString());
+ handlerObjectDetach(obj, this);
}
+
}
break;
- #endregion
-
- #region Inventory/Asset/Other related packets
-
- case PacketType.RequestImage:
- RequestImagePacket imageRequest = (RequestImagePacket)Pack;
- //m_log.Debug("image request: " + Pack.ToString());
-
+ case PacketType.ObjectDrop:
+ ObjectDropPacket dropp = (ObjectDropPacket)Pack;
+
#region Packet Session and User Check
if (m_checkPackets)
{
- if (imageRequest.AgentData.SessionID != SessionId ||
- imageRequest.AgentData.AgentID != AgentId)
+ if (dropp.AgentData.SessionID != SessionId ||
+ dropp.AgentData.AgentID != AgentId)
break;
}
#endregion
- //handlerTextureRequest = null;
-
- for (int i = 0; i < imageRequest.RequestImage.Length; i++)
+ for (int j = 0; j < dropp.ObjectData.Length; j++)
{
- if (OnRequestTexture != null)
+ uint obj = dropp.ObjectData[j].ObjectLocalID;
+ ObjectDrop handlerObjectDrop = OnObjectDrop;
+ if (handlerObjectDrop != null)
{
- TextureRequestArgs args = new TextureRequestArgs();
- args.RequestedAssetID = imageRequest.RequestImage[i].Image;
- args.DiscardLevel = imageRequest.RequestImage[i].DiscardLevel;
- args.PacketNumber = imageRequest.RequestImage[i].Packet;
- args.Priority = imageRequest.RequestImage[i].DownloadPriority;
- args.requestSequence = imageRequest.Header.Sequence;
-
- //handlerTextureRequest = OnRequestTexture;
-
- //if (handlerTextureRequest != null)
- //OnRequestTexture(this, args);
-
- // in the end, we null this, so we have to check if it's null
- if (m_imageManager != null)
- {
- m_imageManager.EnqueueReq(args);
- }
+ handlerObjectDrop(obj, this);
}
}
break;
- case PacketType.TransferRequest:
- //m_log.Debug("ClientView.ProcessPackets.cs:ProcessInPacket() - Got transfer request");
+ case PacketType.SetAlwaysRun:
+ SetAlwaysRunPacket run = (SetAlwaysRunPacket)Pack;
- TransferRequestPacket transfer = (TransferRequestPacket)Pack;
- //m_log.Debug("Transfer Request: " + transfer.ToString());
- // Validate inventory transfers
- // Has to be done here, because AssetCache can't do it
- //
-
- if (transfer.TransferInfo.SourceType == 3)
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- UUID taskID = new UUID(transfer.TransferInfo.Params, 48);
- UUID itemID = new UUID(transfer.TransferInfo.Params, 64);
- UUID requestID = new UUID(transfer.TransferInfo.Params, 80);
- if (!(((Scene)m_scene).Permissions.BypassPermissions()))
- {
- if (taskID != UUID.Zero) // Prim
- {
- SceneObjectPart part = ((Scene)m_scene).GetSceneObjectPart(taskID);
- if (part == null)
- break;
-
- if (part.OwnerID != AgentId)
- break;
-
- if ((part.OwnerMask & (uint)PermissionMask.Modify) == 0)
- break;
+ if (run.AgentData.SessionID != SessionId ||
+ run.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- TaskInventoryItem ti = part.Inventory.GetInventoryItem(itemID);
- if (ti == null)
- break;
+ SetAlwaysRun handlerSetAlwaysRun = OnSetAlwaysRun;
+ if (handlerSetAlwaysRun != null)
+ handlerSetAlwaysRun(this, run.AgentData.AlwaysRun);
- if (ti.OwnerID != AgentId)
- break;
+ break;
- if ((ti.CurrentPermissions & ((uint)PermissionMask.Modify| (uint)PermissionMask.Copy | (uint)PermissionMask.Transfer)) != ((uint)PermissionMask.Modify| (uint)PermissionMask.Copy | (uint)PermissionMask.Transfer))
- break;
+ case PacketType.CompleteAgentMovement:
+ GenericCall2 handlerCompleteMovementToRegion = OnCompleteMovementToRegion;
+ if (handlerCompleteMovementToRegion != null)
+ {
+ handlerCompleteMovementToRegion();
+ }
+ handlerCompleteMovementToRegion = null;
- if (ti.AssetID != requestID)
- break;
- }
- else // Agent
- {
- IInventoryService invService = m_scene.RequestModuleInterface();
- InventoryItemBase assetRequestItem = new InventoryItemBase(itemID, AgentId);
- assetRequestItem = invService.GetItem(assetRequestItem);
- if (assetRequestItem == null)
- {
- assetRequestItem = ((Scene)m_scene).CommsManager.UserProfileCacheService.LibraryRoot.FindItem(itemID);
- if (assetRequestItem == null)
- return;
- }
+ break;
- // At this point, we need to apply perms
- // only to notecards and scripts. All
- // other asset types are always available
- //
- if (assetRequestItem.AssetType == 10)
- {
- if (!((Scene)m_scene).Permissions.CanViewScript(itemID, UUID.Zero, AgentId))
- {
- SendAgentAlertMessage("Insufficient permissions to view script", false);
- break;
- }
- }
- else if (assetRequestItem.AssetType == 7)
- {
- if (!((Scene)m_scene).Permissions.CanViewNotecard(itemID, UUID.Zero, AgentId))
- {
- SendAgentAlertMessage("Insufficient permissions to view notecard", false);
- break;
- }
- }
+ case PacketType.AgentUpdate:
+ if (OnAgentUpdate != null)
+ {
+ bool update = false;
+ AgentUpdatePacket agenUpdate = (AgentUpdatePacket)Pack;
- if (assetRequestItem.AssetID != requestID)
- break;
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (agenUpdate.AgentData.SessionID != SessionId ||
+ agenUpdate.AgentData.AgentID != AgentId)
+ break;
}
- }
-
- //m_assetCache.AddAssetRequest(this, transfer);
+ #endregion
- MakeAssetRequest(transfer);
+ AgentUpdatePacket.AgentDataBlock x = agenUpdate.AgentData;
- /* RequestAsset = OnRequestAsset;
- if (RequestAsset != null)
- {
- RequestAsset(this, transfer);
- }*/
- break;
- case PacketType.AssetUploadRequest:
- AssetUploadRequestPacket request = (AssetUploadRequestPacket)Pack;
+ // We can only check when we have something to check
+ // against.
-
- // m_log.Debug("upload request " + request.ToString());
- // m_log.Debug("upload request was for assetid: " + request.AssetBlock.TransactionID.Combine(this.SecureSessionId).ToString());
- UUID temp = UUID.Combine(request.AssetBlock.TransactionID, SecureSessionId);
+ if (lastarg != null)
+ {
+ update =
+ (
+ (x.BodyRotation != lastarg.BodyRotation) ||
+ (x.CameraAtAxis != lastarg.CameraAtAxis) ||
+ (x.CameraCenter != lastarg.CameraCenter) ||
+ (x.CameraLeftAxis != lastarg.CameraLeftAxis) ||
+ (x.CameraUpAxis != lastarg.CameraUpAxis) ||
+ (x.ControlFlags != lastarg.ControlFlags) ||
+ (x.Far != lastarg.Far) ||
+ (x.Flags != lastarg.Flags) ||
+ (x.State != lastarg.State) ||
+ (x.HeadRotation != lastarg.HeadRotation) ||
+ (x.SessionID != lastarg.SessionID) ||
+ (x.AgentID != lastarg.AgentID)
+ );
+ }
+ else
+ update = true;
- handlerAssetUploadRequest = OnAssetUploadRequest;
+ // These should be ordered from most-likely to
+ // least likely to change. I've made an initial
+ // guess at that.
- if (handlerAssetUploadRequest != null)
- {
- handlerAssetUploadRequest(this, temp,
- request.AssetBlock.TransactionID, request.AssetBlock.Type,
- request.AssetBlock.AssetData, request.AssetBlock.StoreLocal,
- request.AssetBlock.Tempfile);
- }
- break;
- case PacketType.RequestXfer:
- RequestXferPacket xferReq = (RequestXferPacket)Pack;
-
- handlerRequestXfer = OnRequestXfer;
+ if (update)
+ {
+ AgentUpdateArgs arg = new AgentUpdateArgs();
+ arg.AgentID = x.AgentID;
+ arg.BodyRotation = x.BodyRotation;
+ arg.CameraAtAxis = x.CameraAtAxis;
+ arg.CameraCenter = x.CameraCenter;
+ arg.CameraLeftAxis = x.CameraLeftAxis;
+ arg.CameraUpAxis = x.CameraUpAxis;
+ arg.ControlFlags = x.ControlFlags;
+ arg.Far = x.Far;
+ arg.Flags = x.Flags;
+ arg.HeadRotation = x.HeadRotation;
+ arg.SessionID = x.SessionID;
+ arg.State = x.State;
+ UpdateAgent handlerAgentUpdate = OnAgentUpdate;
+ lastarg = arg; // save this set of arguments for nexttime
+ if (handlerAgentUpdate != null)
+ OnAgentUpdate(this, arg);
- if (handlerRequestXfer != null)
- {
- handlerRequestXfer(this, xferReq.XferID.ID, Util.FieldToString(xferReq.XferID.Filename));
- }
- break;
- case PacketType.SendXferPacket:
- SendXferPacketPacket xferRec = (SendXferPacketPacket)Pack;
+ handlerAgentUpdate = null;
+ }
- handlerXferReceive = OnXferReceive;
- if (handlerXferReceive != null)
- {
- handlerXferReceive(this, xferRec.XferID.ID, xferRec.XferID.Packet, xferRec.DataPacket.Data);
- }
- break;
- case PacketType.ConfirmXferPacket:
- ConfirmXferPacketPacket confirmXfer = (ConfirmXferPacketPacket)Pack;
-
- handlerConfirmXfer = OnConfirmXfer;
- if (handlerConfirmXfer != null)
- {
- handlerConfirmXfer(this, confirmXfer.XferID.ID, confirmXfer.XferID.Packet);
}
break;
- case PacketType.AbortXfer:
- AbortXferPacket abortXfer = (AbortXferPacket)Pack;
- handlerAbortXfer = OnAbortXfer;
- if (handlerAbortXfer != null)
- {
- handlerAbortXfer(this, abortXfer.XferID.ID);
- }
- break;
- case PacketType.CreateInventoryFolder:
- CreateInventoryFolderPacket invFolder = (CreateInventoryFolderPacket)Pack;
+ case PacketType.AgentAnimation:
+ AgentAnimationPacket AgentAni = (AgentAnimationPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (invFolder.AgentData.SessionID != SessionId ||
- invFolder.AgentData.AgentID != AgentId)
+ if (AgentAni.AgentData.SessionID != SessionId ||
+ AgentAni.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerCreateInventoryFolder = OnCreateNewInventoryFolder;
- if (handlerCreateInventoryFolder != null)
+ StartAnim handlerStartAnim = null;
+ StopAnim handlerStopAnim = null;
+
+ for (int i = 0; i < AgentAni.AnimationList.Length; i++)
{
- handlerCreateInventoryFolder(this, invFolder.FolderData.FolderID,
- (ushort)invFolder.FolderData.Type,
- Util.FieldToString(invFolder.FolderData.Name),
- invFolder.FolderData.ParentID);
+ if (AgentAni.AnimationList[i].StartAnim)
+ {
+ handlerStartAnim = OnStartAnim;
+ if (handlerStartAnim != null)
+ {
+ handlerStartAnim(this, AgentAni.AnimationList[i].AnimID);
+ }
+ }
+ else
+ {
+ handlerStopAnim = OnStopAnim;
+ if (handlerStopAnim != null)
+ {
+ handlerStopAnim(this, AgentAni.AnimationList[i].AnimID);
+ }
+ }
}
break;
- case PacketType.UpdateInventoryFolder:
- if (OnUpdateInventoryFolder != null)
+
+ case PacketType.AgentRequestSit:
+ if (OnAgentRequestSit != null)
{
- UpdateInventoryFolderPacket invFolderx = (UpdateInventoryFolderPacket)Pack;
+ AgentRequestSitPacket agentRequestSit = (AgentRequestSitPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (invFolderx.AgentData.SessionID != SessionId ||
- invFolderx.AgentData.AgentID != AgentId)
+ if (agentRequestSit.AgentData.SessionID != SessionId ||
+ agentRequestSit.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerUpdateInventoryFolder = null;
-
- for (int i = 0; i < invFolderx.FolderData.Length; i++)
- {
- handlerUpdateInventoryFolder = OnUpdateInventoryFolder;
- if (handlerUpdateInventoryFolder != null)
- {
- OnUpdateInventoryFolder(this, invFolderx.FolderData[i].FolderID,
- (ushort)invFolderx.FolderData[i].Type,
- Util.FieldToString(invFolderx.FolderData[i].Name),
- invFolderx.FolderData[i].ParentID);
- }
- }
+ AgentRequestSit handlerAgentRequestSit = OnAgentRequestSit;
+ if (handlerAgentRequestSit != null)
+ handlerAgentRequestSit(this, agentRequestSit.AgentData.AgentID,
+ agentRequestSit.TargetObject.TargetID, agentRequestSit.TargetObject.Offset);
}
break;
- case PacketType.MoveInventoryFolder:
- if (OnMoveInventoryFolder != null)
+
+ case PacketType.AgentSit:
+ if (OnAgentSit != null)
{
- MoveInventoryFolderPacket invFoldery = (MoveInventoryFolderPacket)Pack;
+ AgentSitPacket agentSit = (AgentSitPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (invFoldery.AgentData.SessionID != SessionId ||
- invFoldery.AgentData.AgentID != AgentId)
+ if (agentSit.AgentData.SessionID != SessionId ||
+ agentSit.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerMoveInventoryFolder = null;
-
- for (int i = 0; i < invFoldery.InventoryData.Length; i++)
+ AgentSit handlerAgentSit = OnAgentSit;
+ if (handlerAgentSit != null)
{
- handlerMoveInventoryFolder = OnMoveInventoryFolder;
- if (handlerMoveInventoryFolder != null)
- {
- OnMoveInventoryFolder(this, invFoldery.InventoryData[i].FolderID,
- invFoldery.InventoryData[i].ParentID);
- }
+ OnAgentSit(this, agentSit.AgentData.AgentID);
}
}
break;
- case PacketType.CreateInventoryItem:
- CreateInventoryItemPacket createItem = (CreateInventoryItemPacket)Pack;
-
+
+ case PacketType.SoundTrigger:
+ SoundTriggerPacket soundTriggerPacket = (SoundTriggerPacket)Pack;
+
#region Packet Session and User Check
if (m_checkPackets)
{
- if (createItem.AgentData.SessionID != SessionId ||
- createItem.AgentData.AgentID != AgentId)
- break;
+ // UNSUPPORTED ON THIS PACKET
}
#endregion
- handlerCreateNewInventoryItem = OnCreateNewInventoryItem;
- if (handlerCreateNewInventoryItem != null)
+ SoundTrigger handlerSoundTrigger = OnSoundTrigger;
+ if (handlerSoundTrigger != null)
{
- handlerCreateNewInventoryItem(this, createItem.InventoryBlock.TransactionID,
- createItem.InventoryBlock.FolderID,
- createItem.InventoryBlock.CallbackID,
- Util.FieldToString(createItem.InventoryBlock.Description),
- Util.FieldToString(createItem.InventoryBlock.Name),
- createItem.InventoryBlock.InvType,
- createItem.InventoryBlock.Type,
- createItem.InventoryBlock.WearableType,
- createItem.InventoryBlock.NextOwnerMask,
- Util.UnixTimeSinceEpoch());
+ handlerSoundTrigger(soundTriggerPacket.SoundData.SoundID, soundTriggerPacket.SoundData.OwnerID,
+ soundTriggerPacket.SoundData.ObjectID, soundTriggerPacket.SoundData.ParentID,
+ soundTriggerPacket.SoundData.Gain, soundTriggerPacket.SoundData.Position,
+ soundTriggerPacket.SoundData.Handle);
+
}
break;
- case PacketType.FetchInventory:
- if (OnFetchInventory != null)
- {
- FetchInventoryPacket FetchInventoryx = (FetchInventoryPacket)Pack;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (FetchInventoryx.AgentData.SessionID != SessionId ||
- FetchInventoryx.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ case PacketType.AvatarPickerRequest:
+ AvatarPickerRequestPacket avRequestQuery = (AvatarPickerRequestPacket)Pack;
- handlerFetchInventory = null;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (avRequestQuery.AgentData.SessionID != SessionId ||
+ avRequestQuery.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- for (int i = 0; i < FetchInventoryx.InventoryData.Length; i++)
- {
- handlerFetchInventory = OnFetchInventory;
+ AvatarPickerRequestPacket.AgentDataBlock Requestdata = avRequestQuery.AgentData;
+ AvatarPickerRequestPacket.DataBlock querydata = avRequestQuery.Data;
+ //m_log.Debug("Agent Sends:" + Utils.BytesToString(querydata.Name));
- if (handlerFetchInventory != null)
- {
- OnFetchInventory(this, FetchInventoryx.InventoryData[i].ItemID,
- FetchInventoryx.InventoryData[i].OwnerID);
- }
- }
+ AvatarPickerRequest handlerAvatarPickerRequest = OnAvatarPickerRequest;
+ if (handlerAvatarPickerRequest != null)
+ {
+ handlerAvatarPickerRequest(this, Requestdata.AgentID, Requestdata.QueryID,
+ Utils.BytesToString(querydata.Name));
}
break;
- case PacketType.FetchInventoryDescendents:
- FetchInventoryDescendentsPacket Fetch = (FetchInventoryDescendentsPacket)Pack;
+
+ case PacketType.AgentDataUpdateRequest:
+ AgentDataUpdateRequestPacket avRequestDataUpdatePacket = (AgentDataUpdateRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (Fetch.AgentData.SessionID != SessionId ||
- Fetch.AgentData.AgentID != AgentId)
+ if (avRequestDataUpdatePacket.AgentData.SessionID != SessionId ||
+ avRequestDataUpdatePacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerFetchInventoryDescendents = OnFetchInventoryDescendents;
- if (handlerFetchInventoryDescendents != null)
+ FetchInventory handlerAgentDataUpdateRequest = OnAgentDataUpdateRequest;
+
+ if (handlerAgentDataUpdateRequest != null)
{
- handlerFetchInventoryDescendents(this, Fetch.InventoryData.FolderID, Fetch.InventoryData.OwnerID,
- Fetch.InventoryData.FetchFolders, Fetch.InventoryData.FetchItems,
- Fetch.InventoryData.SortOrder);
+ handlerAgentDataUpdateRequest(this, avRequestDataUpdatePacket.AgentData.AgentID, avRequestDataUpdatePacket.AgentData.SessionID);
}
+
break;
- case PacketType.PurgeInventoryDescendents:
- PurgeInventoryDescendentsPacket Purge = (PurgeInventoryDescendentsPacket)Pack;
+
+ case PacketType.UserInfoRequest:
+ UserInfoRequest handlerUserInfoRequest = OnUserInfoRequest;
+ if (handlerUserInfoRequest != null)
+ {
+ handlerUserInfoRequest(this);
+ }
+ else
+ {
+ SendUserInfoReply(false, true, "");
+ }
+ break;
+
+ case PacketType.UpdateUserInfo:
+ UpdateUserInfoPacket updateUserInfo = (UpdateUserInfoPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (Purge.AgentData.SessionID != SessionId ||
- Purge.AgentData.AgentID != AgentId)
+ if (updateUserInfo.AgentData.SessionID != SessionId ||
+ updateUserInfo.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerPurgeInventoryDescendents = OnPurgeInventoryDescendents;
- if (handlerPurgeInventoryDescendents != null)
+ UpdateUserInfo handlerUpdateUserInfo = OnUpdateUserInfo;
+ if (handlerUpdateUserInfo != null)
{
- handlerPurgeInventoryDescendents(this, Purge.InventoryData.FolderID);
+ bool visible = true;
+ string DirectoryVisibility =
+ Utils.BytesToString(updateUserInfo.UserData.DirectoryVisibility);
+ if (DirectoryVisibility == "hidden")
+ visible = false;
+
+ handlerUpdateUserInfo(
+ updateUserInfo.UserData.IMViaEMail,
+ visible, this);
}
break;
- case PacketType.UpdateInventoryItem:
- UpdateInventoryItemPacket inventoryItemUpdate = (UpdateInventoryItemPacket)Pack;
-
+
+ case PacketType.SetStartLocationRequest:
+ SetStartLocationRequestPacket avSetStartLocationRequestPacket = (SetStartLocationRequestPacket)Pack;
+
#region Packet Session and User Check
if (m_checkPackets)
{
- if (inventoryItemUpdate.AgentData.SessionID != SessionId ||
- inventoryItemUpdate.AgentData.AgentID != AgentId)
+ if (avSetStartLocationRequestPacket.AgentData.SessionID != SessionId ||
+ avSetStartLocationRequestPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (OnUpdateInventoryItem != null)
+ if (avSetStartLocationRequestPacket.AgentData.AgentID == AgentId && avSetStartLocationRequestPacket.AgentData.SessionID == SessionId)
{
- handlerUpdateInventoryItem = null;
- for (int i = 0; i < inventoryItemUpdate.InventoryData.Length; i++)
+ TeleportLocationRequest handlerSetStartLocationRequest = OnSetStartLocationRequest;
+ if (handlerSetStartLocationRequest != null)
{
- handlerUpdateInventoryItem = OnUpdateInventoryItem;
-
- if (handlerUpdateInventoryItem != null)
- {
- InventoryItemBase itemUpd = new InventoryItemBase();
- itemUpd.ID = inventoryItemUpdate.InventoryData[i].ItemID;
- itemUpd.Name = Util.FieldToString(inventoryItemUpdate.InventoryData[i].Name);
- itemUpd.Description = Util.FieldToString(inventoryItemUpdate.InventoryData[i].Description);
- itemUpd.GroupID = inventoryItemUpdate.InventoryData[i].GroupID;
- itemUpd.GroupOwned = inventoryItemUpdate.InventoryData[i].GroupOwned;
- itemUpd.GroupPermissions = inventoryItemUpdate.InventoryData[i].GroupMask;
- itemUpd.NextPermissions = inventoryItemUpdate.InventoryData[i].NextOwnerMask;
- itemUpd.EveryOnePermissions = inventoryItemUpdate.InventoryData[i].EveryoneMask;
- itemUpd.CreationDate = inventoryItemUpdate.InventoryData[i].CreationDate;
- itemUpd.Folder = inventoryItemUpdate.InventoryData[i].FolderID;
- itemUpd.InvType = inventoryItemUpdate.InventoryData[i].InvType;
- itemUpd.SalePrice = inventoryItemUpdate.InventoryData[i].SalePrice;
- itemUpd.SaleType = inventoryItemUpdate.InventoryData[i].SaleType;
- itemUpd.Flags = inventoryItemUpdate.InventoryData[i].Flags;
- /*
- OnUpdateInventoryItem(this, inventoryItemUpdate.InventoryData[i].TransactionID,
- inventoryItemUpdate.InventoryData[i].ItemID,
- Util.FieldToString(inventoryItemUpdate.InventoryData[i].Name),
- Util.FieldToString(inventoryItemUpdate.InventoryData[i].Description),
- inventoryItemUpdate.InventoryData[i].NextOwnerMask);
- */
- OnUpdateInventoryItem(this, inventoryItemUpdate.InventoryData[i].TransactionID,
- inventoryItemUpdate.InventoryData[i].ItemID,
- itemUpd);
- }
+ handlerSetStartLocationRequest(this, 0, avSetStartLocationRequestPacket.StartLocationData.LocationPos,
+ avSetStartLocationRequestPacket.StartLocationData.LocationLookAt,
+ avSetStartLocationRequestPacket.StartLocationData.LocationID);
}
}
- //m_log.Debug(Pack.ToString());
- /*for (int i = 0; i < inventoryItemUpdate.InventoryData.Length; i++)
- {
- if (inventoryItemUpdate.InventoryData[i].TransactionID != UUID.Zero)
- {
- AssetBase asset = m_assetCache.GetAsset(inventoryItemUpdate.InventoryData[i].TransactionID.Combine(this.SecureSessionId));
- if (asset != null)
- {
- // m_log.Debug("updating inventory item, found asset" + asset.FullID.ToString() + " already in cache");
- m_inventoryCache.UpdateInventoryItemAsset(this, inventoryItemUpdate.InventoryData[i].ItemID, asset);
- }
- else
- {
- asset = this.UploadAssets.AddUploadToAssetCache(inventoryItemUpdate.InventoryData[i].TransactionID);
- if (asset != null)
- {
- //m_log.Debug("updating inventory item, adding asset" + asset.FullID.ToString() + " to cache");
- m_inventoryCache.UpdateInventoryItemAsset(this, inventoryItemUpdate.InventoryData[i].ItemID, asset);
- }
- else
- {
- //m_log.Debug("trying to update inventory item, but asset is null");
- }
- }
- }
- else
- {
- m_inventoryCache.UpdateInventoryItemDetails(this, inventoryItemUpdate.InventoryData[i].ItemID, inventoryItemUpdate.InventoryData[i]); ;
- }
- }*/
break;
- case PacketType.CopyInventoryItem:
- CopyInventoryItemPacket copyitem = (CopyInventoryItemPacket)Pack;
+
+ case PacketType.AgentThrottle:
+ AgentThrottlePacket atpack = (AgentThrottlePacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (atpack.AgentData.SessionID != SessionId ||
+ atpack.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ m_udpClient.SetThrottles(atpack.Throttle.Throttles);
+ break;
+
+ case PacketType.AgentPause:
+ m_probesWithNoIngressPackets = 0;
+ m_clientBlocked = true;
+ break;
+
+ case PacketType.AgentResume:
+ m_probesWithNoIngressPackets = 0;
+ m_clientBlocked = false;
+ SendStartPingCheck(0);
+
+ break;
+
+ case PacketType.ForceScriptControlRelease:
+ ForceReleaseControls handlerForceReleaseControls = OnForceReleaseControls;
+ if (handlerForceReleaseControls != null)
+ {
+ handlerForceReleaseControls(this, AgentId);
+ }
+ break;
+
+ #endregion
+
+ #region Objects/m_sceneObjects
+
+ case PacketType.ObjectLink:
+ ObjectLinkPacket link = (ObjectLinkPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (copyitem.AgentData.SessionID != SessionId ||
- copyitem.AgentData.AgentID != AgentId)
+ if (link.AgentData.SessionID != SessionId ||
+ link.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerCopyInventoryItem = null;
- if (OnCopyInventoryItem != null)
+ uint parentprimid = 0;
+ List childrenprims = new List();
+ if (link.ObjectData.Length > 1)
{
- foreach (CopyInventoryItemPacket.InventoryDataBlock datablock in copyitem.InventoryData)
+ parentprimid = link.ObjectData[0].ObjectLocalID;
+
+ for (int i = 1; i < link.ObjectData.Length; i++)
{
- handlerCopyInventoryItem = OnCopyInventoryItem;
- if (handlerCopyInventoryItem != null)
- {
- handlerCopyInventoryItem(this, datablock.CallbackID, datablock.OldAgentID,
- datablock.OldItemID, datablock.NewFolderID,
- Util.FieldToString(datablock.NewName));
- }
+ childrenprims.Add(link.ObjectData[i].ObjectLocalID);
}
}
+ LinkObjects handlerLinkObjects = OnLinkObjects;
+ if (handlerLinkObjects != null)
+ {
+ handlerLinkObjects(this, parentprimid, childrenprims);
+ }
break;
- case PacketType.MoveInventoryItem:
- MoveInventoryItemPacket moveitem = (MoveInventoryItemPacket)Pack;
+
+ case PacketType.ObjectDelink:
+ ObjectDelinkPacket delink = (ObjectDelinkPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (moveitem.AgentData.SessionID != SessionId ||
- moveitem.AgentData.AgentID != AgentId)
+ if (delink.AgentData.SessionID != SessionId ||
+ delink.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (OnMoveInventoryItem != null)
+ // It appears the prim at index 0 is not always the root prim (for
+ // instance, when one prim of a link set has been edited independently
+ // of the others). Therefore, we'll pass all the ids onto the delink
+ // method for it to decide which is the root.
+ List prims = new List();
+ for (int i = 0; i < delink.ObjectData.Length; i++)
{
- handlerMoveInventoryItem = null;
- InventoryItemBase itm = null;
- List items = new List();
- foreach (MoveInventoryItemPacket.InventoryDataBlock datablock in moveitem.InventoryData)
- {
- itm = new InventoryItemBase(datablock.ItemID, AgentId);
- itm.Folder = datablock.FolderID;
- itm.Name = Util.FieldToString(datablock.NewName);
- // weird, comes out as empty string
- //m_log.DebugFormat("[XXX] new name: {0}", itm.Name);
- items.Add(itm);
- }
- handlerMoveInventoryItem = OnMoveInventoryItem;
- if (handlerMoveInventoryItem != null)
- {
- handlerMoveInventoryItem(this, items);
- }
+ prims.Add(delink.ObjectData[i].ObjectLocalID);
}
- break;
- case PacketType.RemoveInventoryItem:
- RemoveInventoryItemPacket removeItem = (RemoveInventoryItemPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
+ DelinkObjects handlerDelinkObjects = OnDelinkObjects;
+ if (handlerDelinkObjects != null)
{
- if (removeItem.AgentData.SessionID != SessionId ||
- removeItem.AgentData.AgentID != AgentId)
- break;
+ handlerDelinkObjects(prims);
}
- #endregion
- if (OnRemoveInventoryItem != null)
+ break;
+
+ case PacketType.ObjectAdd:
+ if (OnAddPrim != null)
{
- handlerRemoveInventoryItem = null;
- List uuids = new List();
- foreach (RemoveInventoryItemPacket.InventoryDataBlock datablock in removeItem.InventoryData)
- {
- uuids.Add(datablock.ItemID);
- }
- handlerRemoveInventoryItem = OnRemoveInventoryItem;
- if (handlerRemoveInventoryItem != null)
+ ObjectAddPacket addPacket = (ObjectAddPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- handlerRemoveInventoryItem(this, uuids);
+ if (addPacket.AgentData.SessionID != SessionId ||
+ addPacket.AgentData.AgentID != AgentId)
+ break;
}
+ #endregion
+
+ PrimitiveBaseShape shape = GetShapeFromAddPacket(addPacket);
+ // m_log.Info("[REZData]: " + addPacket.ToString());
+ //BypassRaycast: 1
+ //RayStart: <69.79469, 158.2652, 98.40343>
+ //RayEnd: <61.97724, 141.995, 92.58341>
+ //RayTargetID: 00000000-0000-0000-0000-000000000000
+
+ //Check to see if adding the prim is allowed; useful for any module wanting to restrict the
+ //object from rezing initially
+ AddNewPrim handlerAddPrim = OnAddPrim;
+ if (handlerAddPrim != null)
+ handlerAddPrim(AgentId, ActiveGroupId, addPacket.ObjectData.RayEnd, addPacket.ObjectData.Rotation, shape, addPacket.ObjectData.BypassRaycast, addPacket.ObjectData.RayStart, addPacket.ObjectData.RayTargetID, addPacket.ObjectData.RayEndIsIntersection);
}
break;
- case PacketType.RemoveInventoryFolder:
- RemoveInventoryFolderPacket removeFolder = (RemoveInventoryFolderPacket)Pack;
+
+ case PacketType.ObjectShape:
+ ObjectShapePacket shapePacket = (ObjectShapePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (removeFolder.AgentData.SessionID != SessionId ||
- removeFolder.AgentData.AgentID != AgentId)
+ if (shapePacket.AgentData.SessionID != SessionId ||
+ shapePacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (OnRemoveInventoryFolder != null)
+ UpdateShape handlerUpdatePrimShape = null;
+ for (int i = 0; i < shapePacket.ObjectData.Length; i++)
{
- handlerRemoveInventoryFolder = null;
- List uuids = new List();
- foreach (RemoveInventoryFolderPacket.FolderDataBlock datablock in removeFolder.FolderData)
- {
- uuids.Add(datablock.FolderID);
- }
- handlerRemoveInventoryFolder = OnRemoveInventoryFolder;
- if (handlerRemoveInventoryFolder != null)
+ handlerUpdatePrimShape = OnUpdatePrimShape;
+ if (handlerUpdatePrimShape != null)
{
- handlerRemoveInventoryFolder(this, uuids);
+ UpdateShapeArgs shapeData = new UpdateShapeArgs();
+ shapeData.ObjectLocalID = shapePacket.ObjectData[i].ObjectLocalID;
+ shapeData.PathBegin = shapePacket.ObjectData[i].PathBegin;
+ shapeData.PathCurve = shapePacket.ObjectData[i].PathCurve;
+ shapeData.PathEnd = shapePacket.ObjectData[i].PathEnd;
+ shapeData.PathRadiusOffset = shapePacket.ObjectData[i].PathRadiusOffset;
+ shapeData.PathRevolutions = shapePacket.ObjectData[i].PathRevolutions;
+ shapeData.PathScaleX = shapePacket.ObjectData[i].PathScaleX;
+ shapeData.PathScaleY = shapePacket.ObjectData[i].PathScaleY;
+ shapeData.PathShearX = shapePacket.ObjectData[i].PathShearX;
+ shapeData.PathShearY = shapePacket.ObjectData[i].PathShearY;
+ shapeData.PathSkew = shapePacket.ObjectData[i].PathSkew;
+ shapeData.PathTaperX = shapePacket.ObjectData[i].PathTaperX;
+ shapeData.PathTaperY = shapePacket.ObjectData[i].PathTaperY;
+ shapeData.PathTwist = shapePacket.ObjectData[i].PathTwist;
+ shapeData.PathTwistBegin = shapePacket.ObjectData[i].PathTwistBegin;
+ shapeData.ProfileBegin = shapePacket.ObjectData[i].ProfileBegin;
+ shapeData.ProfileCurve = shapePacket.ObjectData[i].ProfileCurve;
+ shapeData.ProfileEnd = shapePacket.ObjectData[i].ProfileEnd;
+ shapeData.ProfileHollow = shapePacket.ObjectData[i].ProfileHollow;
+
+ handlerUpdatePrimShape(m_agentId, shapePacket.ObjectData[i].ObjectLocalID,
+ shapeData);
}
}
break;
- case PacketType.RemoveInventoryObjects:
- RemoveInventoryObjectsPacket removeObject = (RemoveInventoryObjectsPacket)Pack;
+
+ case PacketType.ObjectExtraParams:
+ ObjectExtraParamsPacket extraPar = (ObjectExtraParamsPacket)Pack;
+
#region Packet Session and User Check
if (m_checkPackets)
{
- if (removeObject.AgentData.SessionID != SessionId ||
- removeObject.AgentData.AgentID != AgentId)
+ if (extraPar.AgentData.SessionID != SessionId ||
+ extraPar.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (OnRemoveInventoryFolder != null)
- {
- handlerRemoveInventoryFolder = null;
- List uuids = new List();
- foreach (RemoveInventoryObjectsPacket.FolderDataBlock datablock in removeObject.FolderData)
- {
- uuids.Add(datablock.FolderID);
- }
- handlerRemoveInventoryFolder = OnRemoveInventoryFolder;
- if (handlerRemoveInventoryFolder != null)
- {
- handlerRemoveInventoryFolder(this, uuids);
- }
- }
- if (OnRemoveInventoryItem != null)
+ ObjectExtraParams handlerUpdateExtraParams = OnUpdateExtraParams;
+ if (handlerUpdateExtraParams != null)
{
- handlerRemoveInventoryItem = null;
- List uuids = new List();
- foreach (RemoveInventoryObjectsPacket.ItemDataBlock datablock in removeObject.ItemData)
- {
- uuids.Add(datablock.ItemID);
- }
- handlerRemoveInventoryItem = OnRemoveInventoryItem;
- if (handlerRemoveInventoryItem != null)
+ for (int i = 0 ; i < extraPar.ObjectData.Length ; i++)
{
- handlerRemoveInventoryItem(this, uuids);
+ handlerUpdateExtraParams(m_agentId, extraPar.ObjectData[i].ObjectLocalID,
+ extraPar.ObjectData[i].ParamType,
+ extraPar.ObjectData[i].ParamInUse, extraPar.ObjectData[i].ParamData);
}
}
break;
- case PacketType.RequestTaskInventory:
- RequestTaskInventoryPacket requesttask = (RequestTaskInventoryPacket)Pack;
+ case PacketType.ObjectDuplicate:
+ ObjectDuplicatePacket dupe = (ObjectDuplicatePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (requesttask.AgentData.SessionID != SessionId ||
- requesttask.AgentData.AgentID != AgentId)
+ if (dupe.AgentData.SessionID != SessionId ||
+ dupe.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerRequestTaskInventory = OnRequestTaskInventory;
- if (handlerRequestTaskInventory != null)
+ ObjectDuplicatePacket.AgentDataBlock AgentandGroupData = dupe.AgentData;
+
+ ObjectDuplicate handlerObjectDuplicate = null;
+
+ for (int i = 0; i < dupe.ObjectData.Length; i++)
{
- handlerRequestTaskInventory(this, requesttask.InventoryData.LocalID);
+ handlerObjectDuplicate = OnObjectDuplicate;
+ if (handlerObjectDuplicate != null)
+ {
+ handlerObjectDuplicate(dupe.ObjectData[i].ObjectLocalID, dupe.SharedData.Offset,
+ dupe.SharedData.DuplicateFlags, AgentandGroupData.AgentID,
+ AgentandGroupData.GroupID);
+ }
}
+
break;
- case PacketType.UpdateTaskInventory:
- UpdateTaskInventoryPacket updatetask = (UpdateTaskInventoryPacket)Pack;
+
+ case PacketType.RequestMultipleObjects:
+ RequestMultipleObjectsPacket incomingRequest = (RequestMultipleObjectsPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (updatetask.AgentData.SessionID != SessionId ||
- updatetask.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
-
- if (OnUpdateTaskInventory != null)
- {
- if (updatetask.UpdateData.Key == 0)
- {
- handlerUpdateTaskInventory = OnUpdateTaskInventory;
- if (handlerUpdateTaskInventory != null)
- {
- TaskInventoryItem newTaskItem = new TaskInventoryItem();
- newTaskItem.ItemID = updatetask.InventoryData.ItemID;
- newTaskItem.ParentID = updatetask.InventoryData.FolderID;
- newTaskItem.CreatorID = updatetask.InventoryData.CreatorID;
- newTaskItem.OwnerID = updatetask.InventoryData.OwnerID;
- newTaskItem.GroupID = updatetask.InventoryData.GroupID;
- newTaskItem.BasePermissions = updatetask.InventoryData.BaseMask;
- newTaskItem.CurrentPermissions = updatetask.InventoryData.OwnerMask;
- newTaskItem.GroupPermissions = updatetask.InventoryData.GroupMask;
- newTaskItem.EveryonePermissions = updatetask.InventoryData.EveryoneMask;
- newTaskItem.NextPermissions = updatetask.InventoryData.NextOwnerMask;
- //newTaskItem.GroupOwned=updatetask.InventoryData.GroupOwned;
- newTaskItem.Type = updatetask.InventoryData.Type;
- newTaskItem.InvType = updatetask.InventoryData.InvType;
- newTaskItem.Flags = updatetask.InventoryData.Flags;
- //newTaskItem.SaleType=updatetask.InventoryData.SaleType;
- //newTaskItem.SalePrice=updatetask.InventoryData.SalePrice;;
- newTaskItem.Name = Util.FieldToString(updatetask.InventoryData.Name);
- newTaskItem.Description = Util.FieldToString(updatetask.InventoryData.Description);
- newTaskItem.CreationDate = (uint)updatetask.InventoryData.CreationDate;
- handlerUpdateTaskInventory(this, updatetask.InventoryData.TransactionID,
- newTaskItem, updatetask.UpdateData.LocalID);
- }
- }
+ if (incomingRequest.AgentData.SessionID != SessionId ||
+ incomingRequest.AgentData.AgentID != AgentId)
+ break;
}
+ #endregion
- break;
-
- case PacketType.RemoveTaskInventory:
+ ObjectRequest handlerObjectRequest = null;
- RemoveTaskInventoryPacket removeTask = (RemoveTaskInventoryPacket)Pack;
+ for (int i = 0; i < incomingRequest.ObjectData.Length; i++)
+ {
+ handlerObjectRequest = OnObjectRequest;
+ if (handlerObjectRequest != null)
+ {
+ handlerObjectRequest(incomingRequest.ObjectData[i].ID, this);
+ }
+ }
+ break;
+ case PacketType.ObjectSelect:
+ ObjectSelectPacket incomingselect = (ObjectSelectPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (removeTask.AgentData.SessionID != SessionId ||
- removeTask.AgentData.AgentID != AgentId)
+ if (incomingselect.AgentData.SessionID != SessionId ||
+ incomingselect.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerRemoveTaskItem = OnRemoveTaskItem;
+ ObjectSelect handlerObjectSelect = null;
- if (handlerRemoveTaskItem != null)
+ for (int i = 0; i < incomingselect.ObjectData.Length; i++)
{
- handlerRemoveTaskItem(this, removeTask.InventoryData.ItemID, removeTask.InventoryData.LocalID);
+ handlerObjectSelect = OnObjectSelect;
+ if (handlerObjectSelect != null)
+ {
+ handlerObjectSelect(incomingselect.ObjectData[i].ObjectLocalID, this);
+ }
}
-
break;
-
- case PacketType.MoveTaskInventory:
-
- MoveTaskInventoryPacket moveTaskInventoryPacket = (MoveTaskInventoryPacket)Pack;
+ case PacketType.ObjectDeselect:
+ ObjectDeselectPacket incomingdeselect = (ObjectDeselectPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (moveTaskInventoryPacket.AgentData.SessionID != SessionId ||
- moveTaskInventoryPacket.AgentData.AgentID != AgentId)
+ if (incomingdeselect.AgentData.SessionID != SessionId ||
+ incomingdeselect.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerMoveTaskItem = OnMoveTaskItem;
+ ObjectDeselect handlerObjectDeselect = null;
- if (handlerMoveTaskItem != null)
+ for (int i = 0; i < incomingdeselect.ObjectData.Length; i++)
{
- handlerMoveTaskItem(
- this, moveTaskInventoryPacket.AgentData.FolderID,
- moveTaskInventoryPacket.InventoryData.LocalID,
- moveTaskInventoryPacket.InventoryData.ItemID);
+ handlerObjectDeselect = OnObjectDeselect;
+ if (handlerObjectDeselect != null)
+ {
+ OnObjectDeselect(incomingdeselect.ObjectData[i].ObjectLocalID, this);
+ }
}
-
break;
-
- case PacketType.RezScript:
- //m_log.Debug(Pack.ToString());
- RezScriptPacket rezScriptx = (RezScriptPacket)Pack;
+ case PacketType.ObjectPosition:
+ // DEPRECATED: but till libsecondlife removes it, people will use it
+ ObjectPositionPacket position = (ObjectPositionPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (rezScriptx.AgentData.SessionID != SessionId ||
- rezScriptx.AgentData.AgentID != AgentId)
+ if (position.AgentData.SessionID != SessionId ||
+ position.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerRezScript = OnRezScript;
- InventoryItemBase item = new InventoryItemBase();
- item.ID = rezScriptx.InventoryBlock.ItemID;
- item.Folder = rezScriptx.InventoryBlock.FolderID;
- item.CreatorId = rezScriptx.InventoryBlock.CreatorID.ToString();
- item.Owner = rezScriptx.InventoryBlock.OwnerID;
- item.BasePermissions = rezScriptx.InventoryBlock.BaseMask;
- item.CurrentPermissions = rezScriptx.InventoryBlock.OwnerMask;
- item.EveryOnePermissions = rezScriptx.InventoryBlock.EveryoneMask;
- item.NextPermissions = rezScriptx.InventoryBlock.NextOwnerMask;
- item.GroupPermissions = rezScriptx.InventoryBlock.GroupMask;
- item.GroupOwned = rezScriptx.InventoryBlock.GroupOwned;
- item.GroupID = rezScriptx.InventoryBlock.GroupID;
- item.AssetType = rezScriptx.InventoryBlock.Type;
- item.InvType = rezScriptx.InventoryBlock.InvType;
- item.Flags = rezScriptx.InventoryBlock.Flags;
- item.SaleType = rezScriptx.InventoryBlock.SaleType;
- item.SalePrice = rezScriptx.InventoryBlock.SalePrice;
- item.Name = Util.FieldToString(rezScriptx.InventoryBlock.Name);
- item.Description = Util.FieldToString(rezScriptx.InventoryBlock.Description);
- item.CreationDate = rezScriptx.InventoryBlock.CreationDate;
- if (handlerRezScript != null)
+ for (int i = 0; i < position.ObjectData.Length; i++)
{
- handlerRezScript(this, item, rezScriptx.InventoryBlock.TransactionID, rezScriptx.UpdateBlock.ObjectLocalID);
+ UpdateVector handlerUpdateVector = OnUpdatePrimGroupPosition;
+ if (handlerUpdateVector != null)
+ handlerUpdateVector(position.ObjectData[i].ObjectLocalID, position.ObjectData[i].Position, this);
}
- break;
- case PacketType.MapLayerRequest:
- RequestMapLayer();
break;
- case PacketType.MapBlockRequest:
- MapBlockRequestPacket MapRequest = (MapBlockRequestPacket)Pack;
+ case PacketType.ObjectScale:
+ // DEPRECATED: but till libsecondlife removes it, people will use it
+ ObjectScalePacket scale = (ObjectScalePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (MapRequest.AgentData.SessionID != SessionId ||
- MapRequest.AgentData.AgentID != AgentId)
+ if (scale.AgentData.SessionID != SessionId ||
+ scale.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerRequestMapBlocks = OnRequestMapBlocks;
- if (handlerRequestMapBlocks != null)
+ for (int i = 0; i < scale.ObjectData.Length; i++)
{
- handlerRequestMapBlocks(this, MapRequest.PositionData.MinX, MapRequest.PositionData.MinY,
- MapRequest.PositionData.MaxX, MapRequest.PositionData.MaxY, MapRequest.AgentData.Flags);
+ UpdateVector handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
+ if (handlerUpdatePrimGroupScale != null)
+ handlerUpdatePrimGroupScale(scale.ObjectData[i].ObjectLocalID, scale.ObjectData[i].Scale, this);
}
+
break;
- case PacketType.MapNameRequest:
- MapNameRequestPacket map = (MapNameRequestPacket)Pack;
+ case PacketType.ObjectRotation:
+ // DEPRECATED: but till libsecondlife removes it, people will use it
+ ObjectRotationPacket rotation = (ObjectRotationPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (map.AgentData.SessionID != SessionId ||
- map.AgentData.AgentID != AgentId)
+ if (rotation.AgentData.SessionID != SessionId ||
+ rotation.AgentData.AgentID != AgentId)
break;
}
#endregion
- string mapName = Util.UTF8.GetString(map.NameData.Name, 0,
- map.NameData.Name.Length - 1);
- handlerMapNameRequest = OnMapNameRequest;
- if (handlerMapNameRequest != null)
+ for (int i = 0; i < rotation.ObjectData.Length; i++)
{
- handlerMapNameRequest(this, mapName);
+ UpdatePrimRotation handlerUpdatePrimRotation = OnUpdatePrimGroupRotation;
+ if (handlerUpdatePrimRotation != null)
+ handlerUpdatePrimRotation(rotation.ObjectData[i].ObjectLocalID, rotation.ObjectData[i].Rotation, this);
}
+
break;
- case PacketType.TeleportLandmarkRequest:
- TeleportLandmarkRequestPacket tpReq = (TeleportLandmarkRequestPacket)Pack;
+ case PacketType.ObjectFlagUpdate:
+ ObjectFlagUpdatePacket flags = (ObjectFlagUpdatePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (tpReq.Info.SessionID != SessionId ||
- tpReq.Info.AgentID != AgentId)
+ if (flags.AgentData.SessionID != SessionId ||
+ flags.AgentData.AgentID != AgentId)
break;
}
#endregion
- UUID lmid = tpReq.Info.LandmarkID;
- AssetLandmark lm;
- if (lmid != UUID.Zero)
- {
- //AssetBase lma = m_assetCache.GetAsset(lmid, false);
- AssetBase lma = m_assetService.Get(lmid.ToString());
-
- if (lma == null)
- {
- // Failed to find landmark
- TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
- tpCancel.Info.SessionID = tpReq.Info.SessionID;
- tpCancel.Info.AgentID = tpReq.Info.AgentID;
- OutPacket(tpCancel, ThrottleOutPacketType.Task);
- }
+ UpdatePrimFlags handlerUpdatePrimFlags = OnUpdatePrimFlags;
- try
- {
- lm = new AssetLandmark(lma);
- }
- catch (NullReferenceException)
- {
- // asset not found generates null ref inside the assetlandmark constructor.
- TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
- tpCancel.Info.SessionID = tpReq.Info.SessionID;
- tpCancel.Info.AgentID = tpReq.Info.AgentID;
- OutPacket(tpCancel, ThrottleOutPacketType.Task);
- break;
- }
+ if (handlerUpdatePrimFlags != null)
+ {
+ byte[] data = Pack.ToBytes();
+ // 46,47,48 are special positions within the packet
+ // This may change so perhaps we need a better way
+ // of storing this (OMV.FlagUpdatePacket.UsePhysics,etc?)
+ bool UsePhysics = (data[46] != 0) ? true : false;
+ bool IsTemporary = (data[47] != 0) ? true : false;
+ bool IsPhantom = (data[48] != 0) ? true : false;
+ handlerUpdatePrimFlags(flags.AgentData.ObjectLocalID, UsePhysics, IsTemporary, IsPhantom, this);
}
- else
+ break;
+ case PacketType.ObjectImage:
+ ObjectImagePacket imagePack = (ObjectImagePacket)Pack;
+
+ UpdatePrimTexture handlerUpdatePrimTexture = null;
+ for (int i = 0; i < imagePack.ObjectData.Length; i++)
{
- // Teleport home request
- handlerTeleportHomeRequest = OnTeleportHomeRequest;
- if (handlerTeleportHomeRequest != null)
+ handlerUpdatePrimTexture = OnUpdatePrimTexture;
+ if (handlerUpdatePrimTexture != null)
{
- handlerTeleportHomeRequest(AgentId, this);
+ handlerUpdatePrimTexture(imagePack.ObjectData[i].ObjectLocalID,
+ imagePack.ObjectData[i].TextureEntry, this);
}
- break;
}
+ break;
+ case PacketType.ObjectGrab:
+ ObjectGrabPacket grab = (ObjectGrabPacket)Pack;
- handlerTeleportLandmarkRequest = OnTeleportLandmarkRequest;
- if (handlerTeleportLandmarkRequest != null)
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- handlerTeleportLandmarkRequest(this, lm.RegionID, lm.Position);
+ if (grab.AgentData.SessionID != SessionId ||
+ grab.AgentData.AgentID != AgentId)
+ break;
}
- else
- {
- //no event handler so cancel request
-
+ #endregion
- TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
- tpCancel.Info.AgentID = tpReq.Info.AgentID;
- tpCancel.Info.SessionID = tpReq.Info.SessionID;
- OutPacket(tpCancel, ThrottleOutPacketType.Task);
+ GrabObject handlerGrabObject = OnGrabObject;
+ if (handlerGrabObject != null)
+ {
+ List touchArgs = new List();
+ if ((grab.SurfaceInfo != null) && (grab.SurfaceInfo.Length > 0))
+ {
+ foreach (ObjectGrabPacket.SurfaceInfoBlock surfaceInfo in grab.SurfaceInfo)
+ {
+ SurfaceTouchEventArgs arg = new SurfaceTouchEventArgs();
+ arg.Binormal = surfaceInfo.Binormal;
+ arg.FaceIndex = surfaceInfo.FaceIndex;
+ arg.Normal = surfaceInfo.Normal;
+ arg.Position = surfaceInfo.Position;
+ arg.STCoord = surfaceInfo.STCoord;
+ arg.UVCoord = surfaceInfo.UVCoord;
+ touchArgs.Add(arg);
+ }
+ }
+ handlerGrabObject(grab.ObjectData.LocalID, grab.ObjectData.GrabOffset, this, touchArgs);
}
break;
-
- case PacketType.TeleportLocationRequest:
- TeleportLocationRequestPacket tpLocReq = (TeleportLocationRequestPacket)Pack;
- // m_log.Debug(tpLocReq.ToString());
+ case PacketType.ObjectGrabUpdate:
+ ObjectGrabUpdatePacket grabUpdate = (ObjectGrabUpdatePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (tpLocReq.AgentData.SessionID != SessionId ||
- tpLocReq.AgentData.AgentID != AgentId)
+ if (grabUpdate.AgentData.SessionID != SessionId ||
+ grabUpdate.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerTeleportLocationRequest = OnTeleportLocationRequest;
- if (handlerTeleportLocationRequest != null)
- {
- handlerTeleportLocationRequest(this, tpLocReq.Info.RegionHandle, tpLocReq.Info.Position,
- tpLocReq.Info.LookAt, 16);
- }
- else
+ MoveObject handlerGrabUpdate = OnGrabUpdate;
+
+ if (handlerGrabUpdate != null)
{
- //no event handler so cancel request
- TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
- tpCancel.Info.SessionID = tpLocReq.AgentData.SessionID;
- tpCancel.Info.AgentID = tpLocReq.AgentData.AgentID;
- OutPacket(tpCancel, ThrottleOutPacketType.Task);
+ List touchArgs = new List();
+ if ((grabUpdate.SurfaceInfo != null) && (grabUpdate.SurfaceInfo.Length > 0))
+ {
+ foreach (ObjectGrabUpdatePacket.SurfaceInfoBlock surfaceInfo in grabUpdate.SurfaceInfo)
+ {
+ SurfaceTouchEventArgs arg = new SurfaceTouchEventArgs();
+ arg.Binormal = surfaceInfo.Binormal;
+ arg.FaceIndex = surfaceInfo.FaceIndex;
+ arg.Normal = surfaceInfo.Normal;
+ arg.Position = surfaceInfo.Position;
+ arg.STCoord = surfaceInfo.STCoord;
+ arg.UVCoord = surfaceInfo.UVCoord;
+ touchArgs.Add(arg);
+ }
+ }
+ handlerGrabUpdate(grabUpdate.ObjectData.ObjectID, grabUpdate.ObjectData.GrabOffsetInitial,
+ grabUpdate.ObjectData.GrabPosition, this, touchArgs);
}
break;
+ case PacketType.ObjectDeGrab:
+ ObjectDeGrabPacket deGrab = (ObjectDeGrabPacket)Pack;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (deGrab.AgentData.SessionID != SessionId ||
+ deGrab.AgentData.AgentID != AgentId)
+ break;
+ }
#endregion
- case PacketType.UUIDNameRequest:
- UUIDNameRequestPacket incoming = (UUIDNameRequestPacket)Pack;
-
- foreach (UUIDNameRequestPacket.UUIDNameBlockBlock UUIDBlock in incoming.UUIDNameBlock)
+ DeGrabObject handlerDeGrabObject = OnDeGrabObject;
+ if (handlerDeGrabObject != null)
{
- handlerNameRequest = OnNameFromUUIDRequest;
- if (handlerNameRequest != null)
+ List touchArgs = new List();
+ if ((deGrab.SurfaceInfo != null) && (deGrab.SurfaceInfo.Length > 0))
{
- handlerNameRequest(UUIDBlock.ID, this);
+ foreach (ObjectDeGrabPacket.SurfaceInfoBlock surfaceInfo in deGrab.SurfaceInfo)
+ {
+ SurfaceTouchEventArgs arg = new SurfaceTouchEventArgs();
+ arg.Binormal = surfaceInfo.Binormal;
+ arg.FaceIndex = surfaceInfo.FaceIndex;
+ arg.Normal = surfaceInfo.Normal;
+ arg.Position = surfaceInfo.Position;
+ arg.STCoord = surfaceInfo.STCoord;
+ arg.UVCoord = surfaceInfo.UVCoord;
+ touchArgs.Add(arg);
+ }
}
+ handlerDeGrabObject(deGrab.ObjectData.LocalID, this, touchArgs);
}
break;
-
- #region Parcel related packets
-
- case PacketType.RegionHandleRequest:
- RegionHandleRequestPacket rhrPack = (RegionHandleRequestPacket)Pack;
-
- handlerRegionHandleRequest = OnRegionHandleRequest;
- if (handlerRegionHandleRequest != null)
- {
- handlerRegionHandleRequest(this, rhrPack.RequestBlock.RegionID);
- }
- break;
-
- case PacketType.ParcelInfoRequest:
- ParcelInfoRequestPacket pirPack = (ParcelInfoRequestPacket)Pack;
+ case PacketType.ObjectSpinStart:
+ //m_log.Warn("[CLIENT]: unhandled ObjectSpinStart packet");
+ ObjectSpinStartPacket spinStart = (ObjectSpinStartPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (pirPack.AgentData.SessionID != SessionId ||
- pirPack.AgentData.AgentID != AgentId)
+ if (spinStart.AgentData.SessionID != SessionId ||
+ spinStart.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelInfoRequest = OnParcelInfoRequest;
- if (handlerParcelInfoRequest != null)
+ SpinStart handlerSpinStart = OnSpinStart;
+ if (handlerSpinStart != null)
{
- handlerParcelInfoRequest(this, pirPack.Data.ParcelID);
+ handlerSpinStart(spinStart.ObjectData.ObjectID, this);
}
break;
-
- case PacketType.ParcelAccessListRequest:
- ParcelAccessListRequestPacket requestPacket = (ParcelAccessListRequestPacket)Pack;
+ case PacketType.ObjectSpinUpdate:
+ //m_log.Warn("[CLIENT]: unhandled ObjectSpinUpdate packet");
+ ObjectSpinUpdatePacket spinUpdate = (ObjectSpinUpdatePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (requestPacket.AgentData.SessionID != SessionId ||
- requestPacket.AgentData.AgentID != AgentId)
+ if (spinUpdate.AgentData.SessionID != SessionId ||
+ spinUpdate.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelAccessListRequest = OnParcelAccessListRequest;
+ Vector3 axis;
+ float angle;
+ spinUpdate.ObjectData.Rotation.GetAxisAngle(out axis, out angle);
+ //m_log.Warn("[CLIENT]: ObjectSpinUpdate packet rot axis:" + axis + " angle:" + angle);
- if (handlerParcelAccessListRequest != null)
+ SpinObject handlerSpinUpdate = OnSpinUpdate;
+ if (handlerSpinUpdate != null)
{
- handlerParcelAccessListRequest(requestPacket.AgentData.AgentID, requestPacket.AgentData.SessionID,
- requestPacket.Data.Flags, requestPacket.Data.SequenceID,
- requestPacket.Data.LocalID, this);
+ handlerSpinUpdate(spinUpdate.ObjectData.ObjectID, spinUpdate.ObjectData.Rotation, this);
}
break;
-
- case PacketType.ParcelAccessListUpdate:
- ParcelAccessListUpdatePacket updatePacket = (ParcelAccessListUpdatePacket)Pack;
+ case PacketType.ObjectSpinStop:
+ //m_log.Warn("[CLIENT]: unhandled ObjectSpinStop packet");
+ ObjectSpinStopPacket spinStop = (ObjectSpinStopPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (updatePacket.AgentData.SessionID != SessionId ||
- updatePacket.AgentData.AgentID != AgentId)
+ if (spinStop.AgentData.SessionID != SessionId ||
+ spinStop.AgentData.AgentID != AgentId)
break;
}
#endregion
- List entries = new List();
- foreach (ParcelAccessListUpdatePacket.ListBlock block in updatePacket.List)
- {
- ParcelManager.ParcelAccessEntry entry = new ParcelManager.ParcelAccessEntry();
- entry.AgentID = block.ID;
- entry.Flags = (AccessList)block.Flags;
- entry.Time = new DateTime();
- entries.Add(entry);
- }
-
- handlerParcelAccessListUpdateRequest = OnParcelAccessListUpdateRequest;
- if (handlerParcelAccessListUpdateRequest != null)
+ SpinStop handlerSpinStop = OnSpinStop;
+ if (handlerSpinStop != null)
{
- handlerParcelAccessListUpdateRequest(updatePacket.AgentData.AgentID,
- updatePacket.AgentData.SessionID, updatePacket.Data.Flags,
- updatePacket.Data.LocalID, entries, this);
+ handlerSpinStop(spinStop.ObjectData.ObjectID, this);
}
break;
- case PacketType.ParcelPropertiesRequest:
- ParcelPropertiesRequestPacket propertiesRequest = (ParcelPropertiesRequestPacket)Pack;
+ case PacketType.ObjectDescription:
+ ObjectDescriptionPacket objDes = (ObjectDescriptionPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (propertiesRequest.AgentData.SessionID != SessionId ||
- propertiesRequest.AgentData.AgentID != AgentId)
+ if (objDes.AgentData.SessionID != SessionId ||
+ objDes.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelPropertiesRequest = OnParcelPropertiesRequest;
- if (handlerParcelPropertiesRequest != null)
+ GenericCall7 handlerObjectDescription = null;
+
+ for (int i = 0; i < objDes.ObjectData.Length; i++)
{
- handlerParcelPropertiesRequest((int)Math.Round(propertiesRequest.ParcelData.West),
- (int)Math.Round(propertiesRequest.ParcelData.South),
- (int)Math.Round(propertiesRequest.ParcelData.East),
- (int)Math.Round(propertiesRequest.ParcelData.North),
- propertiesRequest.ParcelData.SequenceID,
- propertiesRequest.ParcelData.SnapSelection, this);
+ handlerObjectDescription = OnObjectDescription;
+ if (handlerObjectDescription != null)
+ {
+ handlerObjectDescription(this, objDes.ObjectData[i].LocalID,
+ Util.FieldToString(objDes.ObjectData[i].Description));
+ }
}
break;
- case PacketType.ParcelDivide:
- ParcelDividePacket landDivide = (ParcelDividePacket)Pack;
-
+ case PacketType.ObjectName:
+ ObjectNamePacket objName = (ObjectNamePacket)Pack;
+
#region Packet Session and User Check
if (m_checkPackets)
{
- if (landDivide.AgentData.SessionID != SessionId ||
- landDivide.AgentData.AgentID != AgentId)
+ if (objName.AgentData.SessionID != SessionId ||
+ objName.AgentData.AgentID != AgentId)
break;
}
#endregion
-
- handlerParcelDivideRequest = OnParcelDivideRequest;
- if (handlerParcelDivideRequest != null)
+
+ GenericCall7 handlerObjectName = null;
+ for (int i = 0; i < objName.ObjectData.Length; i++)
{
- handlerParcelDivideRequest((int)Math.Round(landDivide.ParcelData.West),
- (int)Math.Round(landDivide.ParcelData.South),
- (int)Math.Round(landDivide.ParcelData.East),
- (int)Math.Round(landDivide.ParcelData.North), this);
+ handlerObjectName = OnObjectName;
+ if (handlerObjectName != null)
+ {
+ handlerObjectName(this, objName.ObjectData[i].LocalID,
+ Util.FieldToString(objName.ObjectData[i].Name));
+ }
}
break;
- case PacketType.ParcelJoin:
- ParcelJoinPacket landJoin = (ParcelJoinPacket)Pack;
+ case PacketType.ObjectPermissions:
+ if (OnObjectPermissions != null)
+ {
+ ObjectPermissionsPacket newobjPerms = (ObjectPermissionsPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (newobjPerms.AgentData.SessionID != SessionId ||
+ newobjPerms.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ UUID AgentID = newobjPerms.AgentData.AgentID;
+ UUID SessionID = newobjPerms.AgentData.SessionID;
+
+ ObjectPermissions handlerObjectPermissions = null;
+
+ for (int i = 0; i < newobjPerms.ObjectData.Length; i++)
+ {
+ ObjectPermissionsPacket.ObjectDataBlock permChanges = newobjPerms.ObjectData[i];
+
+ byte field = permChanges.Field;
+ uint localID = permChanges.ObjectLocalID;
+ uint mask = permChanges.Mask;
+ byte set = permChanges.Set;
+
+ handlerObjectPermissions = OnObjectPermissions;
+
+ if (handlerObjectPermissions != null)
+ handlerObjectPermissions(this, AgentID, SessionID, field, localID, mask, set);
+ }
+ }
+
+ // Here's our data,
+ // PermField contains the field the info goes into
+ // PermField determines which mask we're changing
+ //
+ // chmask is the mask of the change
+ // setTF is whether we're adding it or taking it away
+ //
+ // objLocalID is the localID of the object.
+
+ // Unfortunately, we have to pass the event the packet because objData is an array
+ // That means multiple object perms may be updated in a single packet.
+
+ break;
+
+ case PacketType.Undo:
+ UndoPacket undoitem = (UndoPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (landJoin.AgentData.SessionID != SessionId ||
- landJoin.AgentData.AgentID != AgentId)
+ if (undoitem.AgentData.SessionID != SessionId ||
+ undoitem.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelJoinRequest = OnParcelJoinRequest;
-
- if (handlerParcelJoinRequest != null)
+ if (undoitem.ObjectData.Length > 0)
{
- handlerParcelJoinRequest((int)Math.Round(landJoin.ParcelData.West),
- (int)Math.Round(landJoin.ParcelData.South),
- (int)Math.Round(landJoin.ParcelData.East),
- (int)Math.Round(landJoin.ParcelData.North), this);
+ for (int i = 0; i < undoitem.ObjectData.Length; i++)
+ {
+ UUID objiD = undoitem.ObjectData[i].ObjectID;
+ AgentSit handlerOnUndo = OnUndo;
+ if (handlerOnUndo != null)
+ {
+ handlerOnUndo(this, objiD);
+ }
+
+ }
}
break;
- case PacketType.ParcelPropertiesUpdate:
- ParcelPropertiesUpdatePacket parcelPropertiesPacket = (ParcelPropertiesUpdatePacket)Pack;
+ case PacketType.ObjectDuplicateOnRay:
+ ObjectDuplicateOnRayPacket dupeOnRay = (ObjectDuplicateOnRayPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (parcelPropertiesPacket.AgentData.SessionID != SessionId ||
- parcelPropertiesPacket.AgentData.AgentID != AgentId)
+ if (dupeOnRay.AgentData.SessionID != SessionId ||
+ dupeOnRay.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelPropertiesUpdateRequest = OnParcelPropertiesUpdateRequest;
+ ObjectDuplicateOnRay handlerObjectDuplicateOnRay = null;
- if (handlerParcelPropertiesUpdateRequest != null)
+ for (int i = 0; i < dupeOnRay.ObjectData.Length; i++)
{
- LandUpdateArgs args = new LandUpdateArgs();
-
- args.AuthBuyerID = parcelPropertiesPacket.ParcelData.AuthBuyerID;
- args.Category = (ParcelCategory)parcelPropertiesPacket.ParcelData.Category;
- args.Desc = Utils.BytesToString(parcelPropertiesPacket.ParcelData.Desc);
- args.GroupID = parcelPropertiesPacket.ParcelData.GroupID;
- args.LandingType = parcelPropertiesPacket.ParcelData.LandingType;
- args.MediaAutoScale = parcelPropertiesPacket.ParcelData.MediaAutoScale;
- args.MediaID = parcelPropertiesPacket.ParcelData.MediaID;
- args.MediaURL = Utils.BytesToString(parcelPropertiesPacket.ParcelData.MediaURL);
- args.MusicURL = Utils.BytesToString(parcelPropertiesPacket.ParcelData.MusicURL);
- args.Name = Utils.BytesToString(parcelPropertiesPacket.ParcelData.Name);
- args.ParcelFlags = parcelPropertiesPacket.ParcelData.ParcelFlags;
- args.PassHours = parcelPropertiesPacket.ParcelData.PassHours;
- args.PassPrice = parcelPropertiesPacket.ParcelData.PassPrice;
- args.SalePrice = parcelPropertiesPacket.ParcelData.SalePrice;
- args.SnapshotID = parcelPropertiesPacket.ParcelData.SnapshotID;
- args.UserLocation = parcelPropertiesPacket.ParcelData.UserLocation;
- args.UserLookAt = parcelPropertiesPacket.ParcelData.UserLookAt;
- handlerParcelPropertiesUpdateRequest(args, parcelPropertiesPacket.ParcelData.LocalID, this);
+ handlerObjectDuplicateOnRay = OnObjectDuplicateOnRay;
+ if (handlerObjectDuplicateOnRay != null)
+ {
+ handlerObjectDuplicateOnRay(dupeOnRay.ObjectData[i].ObjectLocalID, dupeOnRay.AgentData.DuplicateFlags,
+ dupeOnRay.AgentData.AgentID, dupeOnRay.AgentData.GroupID, dupeOnRay.AgentData.RayTargetID, dupeOnRay.AgentData.RayEnd,
+ dupeOnRay.AgentData.RayStart, dupeOnRay.AgentData.BypassRaycast, dupeOnRay.AgentData.RayEndIsIntersection,
+ dupeOnRay.AgentData.CopyCenters, dupeOnRay.AgentData.CopyRotates);
+ }
}
+
break;
- case PacketType.ParcelSelectObjects:
- ParcelSelectObjectsPacket selectPacket = (ParcelSelectObjectsPacket)Pack;
+ case PacketType.RequestObjectPropertiesFamily:
+ //This powers the little tooltip that appears when you move your mouse over an object
+ RequestObjectPropertiesFamilyPacket packToolTip = (RequestObjectPropertiesFamilyPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (selectPacket.AgentData.SessionID != SessionId ||
- selectPacket.AgentData.AgentID != AgentId)
+ if (packToolTip.AgentData.SessionID != SessionId ||
+ packToolTip.AgentData.AgentID != AgentId)
break;
}
#endregion
- List returnIDs = new List();
-
- foreach (ParcelSelectObjectsPacket.ReturnIDsBlock rb in
- selectPacket.ReturnIDs)
- {
- returnIDs.Add(rb.ReturnID);
- }
+ RequestObjectPropertiesFamilyPacket.ObjectDataBlock packObjBlock = packToolTip.ObjectData;
- handlerParcelSelectObjects = OnParcelSelectObjects;
+ RequestObjectPropertiesFamily handlerRequestObjectPropertiesFamily = OnRequestObjectPropertiesFamily;
- if (handlerParcelSelectObjects != null)
+ if (handlerRequestObjectPropertiesFamily != null)
{
- handlerParcelSelectObjects(selectPacket.ParcelData.LocalID,
- Convert.ToInt32(selectPacket.ParcelData.ReturnType), returnIDs, this);
+ handlerRequestObjectPropertiesFamily(this, m_agentId, packObjBlock.RequestFlags,
+ packObjBlock.ObjectID);
}
+
break;
- case PacketType.ParcelObjectOwnersRequest:
- //m_log.Debug(Pack.ToString());
- ParcelObjectOwnersRequestPacket reqPacket = (ParcelObjectOwnersRequestPacket)Pack;
+ case PacketType.ObjectIncludeInSearch:
+ //This lets us set objects to appear in search (stuff like DataSnapshot, etc)
+ ObjectIncludeInSearchPacket packInSearch = (ObjectIncludeInSearchPacket)Pack;
+ ObjectIncludeInSearch handlerObjectIncludeInSearch = null;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (reqPacket.AgentData.SessionID != SessionId ||
- reqPacket.AgentData.AgentID != AgentId)
+ if (packInSearch.AgentData.SessionID != SessionId ||
+ packInSearch.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelObjectOwnerRequest = OnParcelObjectOwnerRequest;
-
- if (handlerParcelObjectOwnerRequest != null)
+ foreach (ObjectIncludeInSearchPacket.ObjectDataBlock objData in packInSearch.ObjectData)
{
- handlerParcelObjectOwnerRequest(reqPacket.ParcelData.LocalID, this);
+ bool inSearch = objData.IncludeInSearch;
+ uint localID = objData.ObjectLocalID;
+
+ handlerObjectIncludeInSearch = OnObjectIncludeInSearch;
+
+ if (handlerObjectIncludeInSearch != null)
+ {
+ handlerObjectIncludeInSearch(this, inSearch, localID);
+ }
}
break;
- case PacketType.ParcelGodForceOwner:
- ParcelGodForceOwnerPacket godForceOwnerPacket = (ParcelGodForceOwnerPacket)Pack;
+
+ case PacketType.ScriptAnswerYes:
+ ScriptAnswerYesPacket scriptAnswer = (ScriptAnswerYesPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (godForceOwnerPacket.AgentData.SessionID != SessionId ||
- godForceOwnerPacket.AgentData.AgentID != AgentId)
+ if (scriptAnswer.AgentData.SessionID != SessionId ||
+ scriptAnswer.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelGodForceOwner = OnParcelGodForceOwner;
- if (handlerParcelGodForceOwner != null)
+ ScriptAnswer handlerScriptAnswer = OnScriptAnswer;
+ if (handlerScriptAnswer != null)
{
- handlerParcelGodForceOwner(godForceOwnerPacket.Data.LocalID, godForceOwnerPacket.Data.OwnerID, this);
+ handlerScriptAnswer(this, scriptAnswer.Data.TaskID, scriptAnswer.Data.ItemID, scriptAnswer.Data.Questions);
}
break;
- case PacketType.ParcelRelease:
- ParcelReleasePacket releasePacket = (ParcelReleasePacket)Pack;
+
+ case PacketType.ObjectClickAction:
+ ObjectClickActionPacket ocpacket = (ObjectClickActionPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (releasePacket.AgentData.SessionID != SessionId ||
- releasePacket.AgentData.AgentID != AgentId)
+ if (ocpacket.AgentData.SessionID != SessionId ||
+ ocpacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelAbandonRequest = OnParcelAbandonRequest;
- if (handlerParcelAbandonRequest != null)
+ GenericCall7 handlerObjectClickAction = OnObjectClickAction;
+ if (handlerObjectClickAction != null)
{
- handlerParcelAbandonRequest(releasePacket.Data.LocalID, this);
+ foreach (ObjectClickActionPacket.ObjectDataBlock odata in ocpacket.ObjectData)
+ {
+ byte action = odata.ClickAction;
+ uint localID = odata.ObjectLocalID;
+ handlerObjectClickAction(this, localID, action.ToString());
+ }
}
break;
- case PacketType.ParcelReclaim:
- ParcelReclaimPacket reclaimPacket = (ParcelReclaimPacket)Pack;
+
+ case PacketType.ObjectMaterial:
+ ObjectMaterialPacket ompacket = (ObjectMaterialPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (reclaimPacket.AgentData.SessionID != SessionId ||
- reclaimPacket.AgentData.AgentID != AgentId)
+ if (ompacket.AgentData.SessionID != SessionId ||
+ ompacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerParcelReclaim = OnParcelReclaim;
- if (handlerParcelReclaim != null)
+ GenericCall7 handlerObjectMaterial = OnObjectMaterial;
+ if (handlerObjectMaterial != null)
{
- handlerParcelReclaim(reclaimPacket.Data.LocalID, this);
+ foreach (ObjectMaterialPacket.ObjectDataBlock odata in ompacket.ObjectData)
+ {
+ byte material = odata.Material;
+ uint localID = odata.ObjectLocalID;
+ handlerObjectMaterial(this, localID, material.ToString());
+ }
}
break;
- case PacketType.ParcelReturnObjects:
+ #endregion
- ParcelReturnObjectsPacket parcelReturnObjects = (ParcelReturnObjectsPacket)Pack;
+ #region Inventory/Asset/Other related packets
+ case PacketType.RequestImage:
+ RequestImagePacket imageRequest = (RequestImagePacket)Pack;
+ //m_log.Debug("image request: " + Pack.ToString());
+
#region Packet Session and User Check
if (m_checkPackets)
{
- if (parcelReturnObjects.AgentData.SessionID != SessionId ||
- parcelReturnObjects.AgentData.AgentID != AgentId)
+ if (imageRequest.AgentData.SessionID != SessionId ||
+ imageRequest.AgentData.AgentID != AgentId)
break;
}
#endregion
- UUID[] puserselectedOwnerIDs = new UUID[parcelReturnObjects.OwnerIDs.Length];
- for (int parceliterator = 0; parceliterator < parcelReturnObjects.OwnerIDs.Length; parceliterator++)
- puserselectedOwnerIDs[parceliterator] = parcelReturnObjects.OwnerIDs[parceliterator].OwnerID;
+ //handlerTextureRequest = null;
- UUID[] puserselectedTaskIDs = new UUID[parcelReturnObjects.TaskIDs.Length];
+ for (int i = 0; i < imageRequest.RequestImage.Length; i++)
+ {
+ if (OnRequestTexture != null)
+ {
+ TextureRequestArgs args = new TextureRequestArgs();
+ args.RequestedAssetID = imageRequest.RequestImage[i].Image;
+ args.DiscardLevel = imageRequest.RequestImage[i].DiscardLevel;
+ args.PacketNumber = imageRequest.RequestImage[i].Packet;
+ args.Priority = imageRequest.RequestImage[i].DownloadPriority;
+ args.requestSequence = imageRequest.Header.Sequence;
- for (int parceliterator = 0; parceliterator < parcelReturnObjects.TaskIDs.Length; parceliterator++)
- puserselectedTaskIDs[parceliterator] = parcelReturnObjects.TaskIDs[parceliterator].TaskID;
+ //handlerTextureRequest = OnRequestTexture;
- handlerParcelReturnObjectsRequest = OnParcelReturnObjectsRequest;
- if (handlerParcelReturnObjectsRequest != null)
- {
- handlerParcelReturnObjectsRequest(parcelReturnObjects.ParcelData.LocalID, parcelReturnObjects.ParcelData.ReturnType, puserselectedOwnerIDs, puserselectedTaskIDs, this);
+ //if (handlerTextureRequest != null)
+ //OnRequestTexture(this, args);
+ // in the end, we null this, so we have to check if it's null
+ if (m_imageManager != null)
+ {
+ m_imageManager.EnqueueReq(args);
+ }
+ }
}
break;
- case PacketType.ParcelSetOtherCleanTime:
- ParcelSetOtherCleanTimePacket parcelSetOtherCleanTimePacket = (ParcelSetOtherCleanTimePacket)Pack;
+ case PacketType.TransferRequest:
+ //m_log.Debug("ClientView.ProcessPackets.cs:ProcessInPacket() - Got transfer request");
- #region Packet Session and User Check
- if (m_checkPackets)
+ TransferRequestPacket transfer = (TransferRequestPacket)Pack;
+ //m_log.Debug("Transfer Request: " + transfer.ToString());
+ // Validate inventory transfers
+ // Has to be done here, because AssetCache can't do it
+ //
+
+ if (transfer.TransferInfo.SourceType == 3)
{
- if (parcelSetOtherCleanTimePacket.AgentData.SessionID != SessionId ||
- parcelSetOtherCleanTimePacket.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ UUID taskID = new UUID(transfer.TransferInfo.Params, 48);
+ UUID itemID = new UUID(transfer.TransferInfo.Params, 64);
+ UUID requestID = new UUID(transfer.TransferInfo.Params, 80);
+ if (!(((Scene)m_scene).Permissions.BypassPermissions()))
+ {
+ if (taskID != UUID.Zero) // Prim
+ {
+ SceneObjectPart part = ((Scene)m_scene).GetSceneObjectPart(taskID);
+ if (part == null)
+ break;
- handlerParcelSetOtherCleanTime = OnParcelSetOtherCleanTime;
- if (handlerParcelSetOtherCleanTime != null)
- {
- handlerParcelSetOtherCleanTime(this,
- parcelSetOtherCleanTimePacket.ParcelData.LocalID,
- parcelSetOtherCleanTimePacket.ParcelData.OtherCleanTime);
+ if (part.OwnerID != AgentId)
+ break;
+
+ if ((part.OwnerMask & (uint)PermissionMask.Modify) == 0)
+ break;
+
+ TaskInventoryItem ti = part.Inventory.GetInventoryItem(itemID);
+ if (ti == null)
+ break;
+
+ if (ti.OwnerID != AgentId)
+ break;
+
+ if ((ti.CurrentPermissions & ((uint)PermissionMask.Modify| (uint)PermissionMask.Copy | (uint)PermissionMask.Transfer)) != ((uint)PermissionMask.Modify| (uint)PermissionMask.Copy | (uint)PermissionMask.Transfer))
+ break;
+
+ if (ti.AssetID != requestID)
+ break;
+ }
+ else // Agent
+ {
+ IInventoryService invService = m_scene.RequestModuleInterface();
+ InventoryItemBase assetRequestItem = new InventoryItemBase(itemID, AgentId);
+ assetRequestItem = invService.GetItem(assetRequestItem);
+ if (assetRequestItem == null)
+ {
+ assetRequestItem = ((Scene)m_scene).CommsManager.UserProfileCacheService.LibraryRoot.FindItem(itemID);
+ if (assetRequestItem == null)
+ return;
+ }
+
+ // At this point, we need to apply perms
+ // only to notecards and scripts. All
+ // other asset types are always available
+ //
+ if (assetRequestItem.AssetType == 10)
+ {
+ if (!((Scene)m_scene).Permissions.CanViewScript(itemID, UUID.Zero, AgentId))
+ {
+ SendAgentAlertMessage("Insufficient permissions to view script", false);
+ break;
+ }
+ }
+ else if (assetRequestItem.AssetType == 7)
+ {
+ if (!((Scene)m_scene).Permissions.CanViewNotecard(itemID, UUID.Zero, AgentId))
+ {
+ SendAgentAlertMessage("Insufficient permissions to view notecard", false);
+ break;
+ }
+ }
+
+ if (assetRequestItem.AssetID != requestID)
+ break;
+ }
+ }
}
+
+ //m_assetCache.AddAssetRequest(this, transfer);
+
+ MakeAssetRequest(transfer);
+
+ /* RequestAsset = OnRequestAsset;
+ if (RequestAsset != null)
+ {
+ RequestAsset(this, transfer);
+ }*/
break;
+ case PacketType.AssetUploadRequest:
+ AssetUploadRequestPacket request = (AssetUploadRequestPacket)Pack;
- case PacketType.LandStatRequest:
- LandStatRequestPacket lsrp = (LandStatRequestPacket)Pack;
+
+ // m_log.Debug("upload request " + request.ToString());
+ // m_log.Debug("upload request was for assetid: " + request.AssetBlock.TransactionID.Combine(this.SecureSessionId).ToString());
+ UUID temp = UUID.Combine(request.AssetBlock.TransactionID, SecureSessionId);
- #region Packet Session and User Check
- if (m_checkPackets)
+ UDPAssetUploadRequest handlerAssetUploadRequest = OnAssetUploadRequest;
+
+ if (handlerAssetUploadRequest != null)
{
- if (lsrp.AgentData.SessionID != SessionId ||
- lsrp.AgentData.AgentID != AgentId)
- break;
+ handlerAssetUploadRequest(this, temp,
+ request.AssetBlock.TransactionID, request.AssetBlock.Type,
+ request.AssetBlock.AssetData, request.AssetBlock.StoreLocal,
+ request.AssetBlock.Tempfile);
}
- #endregion
+ break;
+ case PacketType.RequestXfer:
+ RequestXferPacket xferReq = (RequestXferPacket)Pack;
+
+ RequestXfer handlerRequestXfer = OnRequestXfer;
- handlerLandStatRequest = OnLandStatRequest;
- if (handlerLandStatRequest != null)
+ if (handlerRequestXfer != null)
{
- handlerLandStatRequest(lsrp.RequestData.ParcelLocalID, lsrp.RequestData.ReportType, lsrp.RequestData.RequestFlags, Utils.BytesToString(lsrp.RequestData.Filter), this);
+ handlerRequestXfer(this, xferReq.XferID.ID, Util.FieldToString(xferReq.XferID.Filename));
}
break;
+ case PacketType.SendXferPacket:
+ SendXferPacketPacket xferRec = (SendXferPacketPacket)Pack;
- case PacketType.ParcelDwellRequest:
- ParcelDwellRequestPacket dwellrq =
- (ParcelDwellRequestPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
+ XferReceive handlerXferReceive = OnXferReceive;
+ if (handlerXferReceive != null)
{
- if (dwellrq.AgentData.SessionID != SessionId ||
- dwellrq.AgentData.AgentID != AgentId)
- break;
+ handlerXferReceive(this, xferRec.XferID.ID, xferRec.XferID.Packet, xferRec.DataPacket.Data);
}
- #endregion
-
- handlerParcelDwellRequest = OnParcelDwellRequest;
- if (handlerParcelDwellRequest != null)
+ break;
+ case PacketType.ConfirmXferPacket:
+ ConfirmXferPacketPacket confirmXfer = (ConfirmXferPacketPacket)Pack;
+
+ ConfirmXfer handlerConfirmXfer = OnConfirmXfer;
+ if (handlerConfirmXfer != null)
{
- handlerParcelDwellRequest(dwellrq.Data.LocalID, this);
+ handlerConfirmXfer(this, confirmXfer.XferID.ID, confirmXfer.XferID.Packet);
}
break;
+ case PacketType.AbortXfer:
+ AbortXferPacket abortXfer = (AbortXferPacket)Pack;
+ AbortXfer handlerAbortXfer = OnAbortXfer;
+ if (handlerAbortXfer != null)
+ {
+ handlerAbortXfer(this, abortXfer.XferID.ID);
+ }
- #endregion
-
- #region Estate Packets
-
- case PacketType.EstateOwnerMessage:
- EstateOwnerMessagePacket messagePacket = (EstateOwnerMessagePacket)Pack;
- //m_log.Debug(messagePacket.ToString());
+ break;
+ case PacketType.CreateInventoryFolder:
+ CreateInventoryFolderPacket invFolder = (CreateInventoryFolderPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (messagePacket.AgentData.SessionID != SessionId ||
- messagePacket.AgentData.AgentID != AgentId)
+ if (invFolder.AgentData.SessionID != SessionId ||
+ invFolder.AgentData.AgentID != AgentId)
break;
}
#endregion
- switch (Utils.BytesToString(messagePacket.MethodData.Method))
+ CreateInventoryFolder handlerCreateInventoryFolder = OnCreateNewInventoryFolder;
+ if (handlerCreateInventoryFolder != null)
{
- case "getinfo":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- OnDetailedEstateDataRequest(this, messagePacket.MethodData.Invoice);
- }
- break;
- case "setregioninfo":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- OnSetEstateFlagsRequest(convertParamStringToBool(messagePacket.ParamList[0].Parameter), convertParamStringToBool(messagePacket.ParamList[1].Parameter),
- convertParamStringToBool(messagePacket.ParamList[2].Parameter), !convertParamStringToBool(messagePacket.ParamList[3].Parameter),
- Convert.ToInt16(Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[4].Parameter))),
- (float)Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[5].Parameter)),
- Convert.ToInt16(Utils.BytesToString(messagePacket.ParamList[6].Parameter)),
- convertParamStringToBool(messagePacket.ParamList[7].Parameter), convertParamStringToBool(messagePacket.ParamList[8].Parameter));
- }
- break;
-// case "texturebase":
-// if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
-// {
-// foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
-// {
-// string s = Utils.BytesToString(block.Parameter);
-// string[] splitField = s.Split(' ');
-// if (splitField.Length == 2)
-// {
-// UUID tempUUID = new UUID(splitField[1]);
-// OnSetEstateTerrainBaseTexture(this, Convert.ToInt16(splitField[0]), tempUUID);
-// }
-// }
-// }
-// break;
- case "texturedetail":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
- {
- string s = Utils.BytesToString(block.Parameter);
- string[] splitField = s.Split(' ');
- if (splitField.Length == 2)
- {
- Int16 corner = Convert.ToInt16(splitField[0]);
- UUID textureUUID = new UUID(splitField[1]);
-
- OnSetEstateTerrainDetailTexture(this, corner, textureUUID);
- }
- }
- }
-
- break;
- case "textureheights":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
- {
- string s = Utils.BytesToString(block.Parameter);
- string[] splitField = s.Split(' ');
- if (splitField.Length == 3)
- {
- Int16 corner = Convert.ToInt16(splitField[0]);
- float lowValue = (float)Convert.ToDecimal(splitField[1]);
- float highValue = (float)Convert.ToDecimal(splitField[2]);
-
- OnSetEstateTerrainTextureHeights(this, corner, lowValue, highValue);
- }
- }
- }
- break;
- case "texturecommit":
- OnCommitEstateTerrainTextureRequest(this);
- break;
- case "setregionterrain":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- if (messagePacket.ParamList.Length != 9)
- {
- m_log.Error("EstateOwnerMessage: SetRegionTerrain method has a ParamList of invalid length");
- }
- else
- {
- try
- {
- string tmp = Utils.BytesToString(messagePacket.ParamList[0].Parameter);
- if (!tmp.Contains(".")) tmp += ".00";
- float WaterHeight = (float)Convert.ToDecimal(tmp);
- tmp = Utils.BytesToString(messagePacket.ParamList[1].Parameter);
- if (!tmp.Contains(".")) tmp += ".00";
- float TerrainRaiseLimit = (float)Convert.ToDecimal(tmp);
- tmp = Utils.BytesToString(messagePacket.ParamList[2].Parameter);
- if (!tmp.Contains(".")) tmp += ".00";
- float TerrainLowerLimit = (float)Convert.ToDecimal(tmp);
- bool UseEstateSun = convertParamStringToBool(messagePacket.ParamList[3].Parameter);
- bool UseFixedSun = convertParamStringToBool(messagePacket.ParamList[4].Parameter);
- float SunHour = (float)Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[5].Parameter));
- bool UseGlobal = convertParamStringToBool(messagePacket.ParamList[6].Parameter);
- bool EstateFixedSun = convertParamStringToBool(messagePacket.ParamList[7].Parameter);
- float EstateSunHour = (float)Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[8].Parameter));
-
- OnSetRegionTerrainSettings(WaterHeight, TerrainRaiseLimit, TerrainLowerLimit, UseEstateSun, UseFixedSun, SunHour, UseGlobal, EstateFixedSun, EstateSunHour);
-
- }
- catch (Exception ex)
- {
- m_log.Error("EstateOwnerMessage: Exception while setting terrain settings: \n" + messagePacket + "\n" + ex);
- }
- }
- }
-
- break;
- case "restart":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- // There's only 1 block in the estateResetSim.. and that's the number of seconds till restart.
- foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
- {
- float timeSeconds;
- Utils.TryParseSingle(Utils.BytesToString(block.Parameter), out timeSeconds);
- timeSeconds = (int)timeSeconds;
- OnEstateRestartSimRequest(this, (int)timeSeconds);
-
- }
- }
- break;
- case "estatechangecovenantid":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
- {
- UUID newCovenantID = new UUID(Utils.BytesToString(block.Parameter));
- OnEstateChangeCovenantRequest(this, newCovenantID);
- }
- }
- break;
- case "estateaccessdelta": // Estate access delta manages the banlist and allow list too.
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- int estateAccessType = Convert.ToInt16(Utils.BytesToString(messagePacket.ParamList[1].Parameter));
- OnUpdateEstateAccessDeltaRequest(this, messagePacket.MethodData.Invoice, estateAccessType, new UUID(Utils.BytesToString(messagePacket.ParamList[2].Parameter)));
-
- }
- break;
- case "simulatormessage":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- UUID invoice = messagePacket.MethodData.Invoice;
- UUID SenderID = new UUID(Utils.BytesToString(messagePacket.ParamList[2].Parameter));
- string SenderName = Utils.BytesToString(messagePacket.ParamList[3].Parameter);
- string Message = Utils.BytesToString(messagePacket.ParamList[4].Parameter);
- UUID sessionID = messagePacket.AgentData.SessionID;
- OnSimulatorBlueBoxMessageRequest(this, invoice, SenderID, sessionID, SenderName, Message);
- }
- break;
- case "instantmessage":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- if (messagePacket.ParamList.Length < 5)
- break;
- UUID invoice = messagePacket.MethodData.Invoice;
- UUID SenderID = new UUID(Utils.BytesToString(messagePacket.ParamList[2].Parameter));
- string SenderName = Utils.BytesToString(messagePacket.ParamList[3].Parameter);
- string Message = Utils.BytesToString(messagePacket.ParamList[4].Parameter);
- UUID sessionID = messagePacket.AgentData.SessionID;
- OnEstateBlueBoxMessageRequest(this, invoice, SenderID, sessionID, SenderName, Message);
- }
- break;
- case "setregiondebug":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- UUID invoice = messagePacket.MethodData.Invoice;
- UUID SenderID = messagePacket.AgentData.AgentID;
- bool scripted = convertParamStringToBool(messagePacket.ParamList[0].Parameter);
- bool collisionEvents = convertParamStringToBool(messagePacket.ParamList[1].Parameter);
- bool physics = convertParamStringToBool(messagePacket.ParamList[2].Parameter);
+ handlerCreateInventoryFolder(this, invFolder.FolderData.FolderID,
+ (ushort)invFolder.FolderData.Type,
+ Util.FieldToString(invFolder.FolderData.Name),
+ invFolder.FolderData.ParentID);
+ }
+ break;
+ case PacketType.UpdateInventoryFolder:
+ if (OnUpdateInventoryFolder != null)
+ {
+ UpdateInventoryFolderPacket invFolderx = (UpdateInventoryFolderPacket)Pack;
- OnEstateDebugRegionRequest(this, invoice, SenderID, scripted, collisionEvents, physics);
- }
- break;
- case "teleporthomeuser":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- UUID invoice = messagePacket.MethodData.Invoice;
- UUID SenderID = messagePacket.AgentData.AgentID;
- UUID Prey;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (invFolderx.AgentData.SessionID != SessionId ||
+ invFolderx.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- UUID.TryParse(Utils.BytesToString(messagePacket.ParamList[1].Parameter), out Prey);
+ UpdateInventoryFolder handlerUpdateInventoryFolder = null;
- OnEstateTeleportOneUserHomeRequest(this, invoice, SenderID, Prey);
- }
- break;
- case "teleporthomeallusers":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ for (int i = 0; i < invFolderx.FolderData.Length; i++)
+ {
+ handlerUpdateInventoryFolder = OnUpdateInventoryFolder;
+ if (handlerUpdateInventoryFolder != null)
{
- UUID invoice = messagePacket.MethodData.Invoice;
- UUID SenderID = messagePacket.AgentData.AgentID;
- OnEstateTeleportAllUsersHomeRequest(this, invoice, SenderID);
+ OnUpdateInventoryFolder(this, invFolderx.FolderData[i].FolderID,
+ (ushort)invFolderx.FolderData[i].Type,
+ Util.FieldToString(invFolderx.FolderData[i].Name),
+ invFolderx.FolderData[i].ParentID);
}
- break;
- case "colliders":
- handlerLandStatRequest = OnLandStatRequest;
- if (handlerLandStatRequest != null)
+ }
+ }
+ break;
+ case PacketType.MoveInventoryFolder:
+ if (OnMoveInventoryFolder != null)
+ {
+ MoveInventoryFolderPacket invFoldery = (MoveInventoryFolderPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (invFoldery.AgentData.SessionID != SessionId ||
+ invFoldery.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ MoveInventoryFolder handlerMoveInventoryFolder = null;
+
+ for (int i = 0; i < invFoldery.InventoryData.Length; i++)
+ {
+ handlerMoveInventoryFolder = OnMoveInventoryFolder;
+ if (handlerMoveInventoryFolder != null)
{
- handlerLandStatRequest(0, 1, 0, "", this);
+ OnMoveInventoryFolder(this, invFoldery.InventoryData[i].FolderID,
+ invFoldery.InventoryData[i].ParentID);
}
+ }
+ }
+ break;
+ case PacketType.CreateInventoryItem:
+ CreateInventoryItemPacket createItem = (CreateInventoryItemPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (createItem.AgentData.SessionID != SessionId ||
+ createItem.AgentData.AgentID != AgentId)
break;
- case "scripts":
- handlerLandStatRequest = OnLandStatRequest;
- if (handlerLandStatRequest != null)
+ }
+ #endregion
+
+ CreateNewInventoryItem handlerCreateNewInventoryItem = OnCreateNewInventoryItem;
+ if (handlerCreateNewInventoryItem != null)
+ {
+ handlerCreateNewInventoryItem(this, createItem.InventoryBlock.TransactionID,
+ createItem.InventoryBlock.FolderID,
+ createItem.InventoryBlock.CallbackID,
+ Util.FieldToString(createItem.InventoryBlock.Description),
+ Util.FieldToString(createItem.InventoryBlock.Name),
+ createItem.InventoryBlock.InvType,
+ createItem.InventoryBlock.Type,
+ createItem.InventoryBlock.WearableType,
+ createItem.InventoryBlock.NextOwnerMask,
+ Util.UnixTimeSinceEpoch());
+ }
+ break;
+ case PacketType.FetchInventory:
+ if (OnFetchInventory != null)
+ {
+ FetchInventoryPacket FetchInventoryx = (FetchInventoryPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (FetchInventoryx.AgentData.SessionID != SessionId ||
+ FetchInventoryx.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ FetchInventory handlerFetchInventory = null;
+
+ for (int i = 0; i < FetchInventoryx.InventoryData.Length; i++)
+ {
+ handlerFetchInventory = OnFetchInventory;
+
+ if (handlerFetchInventory != null)
{
- handlerLandStatRequest(0, 0, 0, "", this);
+ OnFetchInventory(this, FetchInventoryx.InventoryData[i].ItemID,
+ FetchInventoryx.InventoryData[i].OwnerID);
}
+ }
+ }
+ break;
+ case PacketType.FetchInventoryDescendents:
+ FetchInventoryDescendentsPacket Fetch = (FetchInventoryDescendentsPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (Fetch.AgentData.SessionID != SessionId ||
+ Fetch.AgentData.AgentID != AgentId)
break;
- case "terrain":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
- {
- if (messagePacket.ParamList.Length > 0)
- {
- if (Utils.BytesToString(messagePacket.ParamList[0].Parameter) == "bake")
- {
- handlerBakeTerrain = OnBakeTerrain;
- if (handlerBakeTerrain != null)
- {
- handlerBakeTerrain(this);
- }
- }
- if (Utils.BytesToString(messagePacket.ParamList[0].Parameter) == "download filename")
- {
- if (messagePacket.ParamList.Length > 1)
- {
- handlerRequestTerrain = OnRequestTerrain;
- if (handlerRequestTerrain != null)
- {
- handlerRequestTerrain(this, Utils.BytesToString(messagePacket.ParamList[1].Parameter));
- }
- }
- }
- if (Utils.BytesToString(messagePacket.ParamList[0].Parameter) == "upload filename")
- {
- if (messagePacket.ParamList.Length > 1)
- {
- handlerUploadTerrain = OnUploadTerrain;
- if (handlerUploadTerrain != null)
- {
- handlerUploadTerrain(this, Utils.BytesToString(messagePacket.ParamList[1].Parameter));
- }
- }
- }
+ }
+ #endregion
- }
+ FetchInventoryDescendents handlerFetchInventoryDescendents = OnFetchInventoryDescendents;
+ if (handlerFetchInventoryDescendents != null)
+ {
+ handlerFetchInventoryDescendents(this, Fetch.InventoryData.FolderID, Fetch.InventoryData.OwnerID,
+ Fetch.InventoryData.FetchFolders, Fetch.InventoryData.FetchItems,
+ Fetch.InventoryData.SortOrder);
+ }
+ break;
+ case PacketType.PurgeInventoryDescendents:
+ PurgeInventoryDescendentsPacket Purge = (PurgeInventoryDescendentsPacket)Pack;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (Purge.AgentData.SessionID != SessionId ||
+ Purge.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- }
+ PurgeInventoryDescendents handlerPurgeInventoryDescendents = OnPurgeInventoryDescendents;
+ if (handlerPurgeInventoryDescendents != null)
+ {
+ handlerPurgeInventoryDescendents(this, Purge.InventoryData.FolderID);
+ }
+ break;
+ case PacketType.UpdateInventoryItem:
+ UpdateInventoryItemPacket inventoryItemUpdate = (UpdateInventoryItemPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (inventoryItemUpdate.AgentData.SessionID != SessionId ||
+ inventoryItemUpdate.AgentData.AgentID != AgentId)
break;
+ }
+ #endregion
- case "estatechangeinfo":
- if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ if (OnUpdateInventoryItem != null)
+ {
+ UpdateInventoryItem handlerUpdateInventoryItem = null;
+ for (int i = 0; i < inventoryItemUpdate.InventoryData.Length; i++)
+ {
+ handlerUpdateInventoryItem = OnUpdateInventoryItem;
+
+ if (handlerUpdateInventoryItem != null)
{
- UUID invoice = messagePacket.MethodData.Invoice;
- UUID SenderID = messagePacket.AgentData.AgentID;
- UInt32 param1 = Convert.ToUInt32(Utils.BytesToString(messagePacket.ParamList[1].Parameter));
- UInt32 param2 = Convert.ToUInt32(Utils.BytesToString(messagePacket.ParamList[2].Parameter));
+ InventoryItemBase itemUpd = new InventoryItemBase();
+ itemUpd.ID = inventoryItemUpdate.InventoryData[i].ItemID;
+ itemUpd.Name = Util.FieldToString(inventoryItemUpdate.InventoryData[i].Name);
+ itemUpd.Description = Util.FieldToString(inventoryItemUpdate.InventoryData[i].Description);
+ itemUpd.GroupID = inventoryItemUpdate.InventoryData[i].GroupID;
+ itemUpd.GroupOwned = inventoryItemUpdate.InventoryData[i].GroupOwned;
+ itemUpd.GroupPermissions = inventoryItemUpdate.InventoryData[i].GroupMask;
+ itemUpd.NextPermissions = inventoryItemUpdate.InventoryData[i].NextOwnerMask;
+ itemUpd.EveryOnePermissions = inventoryItemUpdate.InventoryData[i].EveryoneMask;
+ itemUpd.CreationDate = inventoryItemUpdate.InventoryData[i].CreationDate;
+ itemUpd.Folder = inventoryItemUpdate.InventoryData[i].FolderID;
+ itemUpd.InvType = inventoryItemUpdate.InventoryData[i].InvType;
+ itemUpd.SalePrice = inventoryItemUpdate.InventoryData[i].SalePrice;
+ itemUpd.SaleType = inventoryItemUpdate.InventoryData[i].SaleType;
+ itemUpd.Flags = inventoryItemUpdate.InventoryData[i].Flags;
- handlerEstateChangeInfo = OnEstateChangeInfo;
- if (handlerEstateChangeInfo != null)
- {
- handlerEstateChangeInfo(this, invoice, SenderID, param1, param2);
- }
+ OnUpdateInventoryItem(this, inventoryItemUpdate.InventoryData[i].TransactionID,
+ inventoryItemUpdate.InventoryData[i].ItemID,
+ itemUpd);
}
- break;
+ }
+ }
+ break;
+ case PacketType.CopyInventoryItem:
+ CopyInventoryItemPacket copyitem = (CopyInventoryItemPacket)Pack;
- default:
- m_log.Error("EstateOwnerMessage: Unknown method requested\n" + messagePacket);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (copyitem.AgentData.SessionID != SessionId ||
+ copyitem.AgentData.AgentID != AgentId)
break;
}
-
- //int parcelID, uint reportType, uint requestflags, string filter
-
- //lsrp.RequestData.ParcelLocalID;
- //lsrp.RequestData.ReportType; // 1 = colliders, 0 = scripts
- //lsrp.RequestData.RequestFlags;
- //lsrp.RequestData.Filter;
+ #endregion
+ CopyInventoryItem handlerCopyInventoryItem = null;
+ if (OnCopyInventoryItem != null)
+ {
+ foreach (CopyInventoryItemPacket.InventoryDataBlock datablock in copyitem.InventoryData)
+ {
+ handlerCopyInventoryItem = OnCopyInventoryItem;
+ if (handlerCopyInventoryItem != null)
+ {
+ handlerCopyInventoryItem(this, datablock.CallbackID, datablock.OldAgentID,
+ datablock.OldItemID, datablock.NewFolderID,
+ Util.FieldToString(datablock.NewName));
+ }
+ }
+ }
break;
-
- case PacketType.RequestRegionInfo:
- RequestRegionInfoPacket.AgentDataBlock mPacket = ((RequestRegionInfoPacket)Pack).AgentData;
+ case PacketType.MoveInventoryItem:
+ MoveInventoryItemPacket moveitem = (MoveInventoryItemPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (mPacket.SessionID != SessionId ||
- mPacket.AgentID != AgentId)
+ if (moveitem.AgentData.SessionID != SessionId ||
+ moveitem.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerRegionInfoRequest = OnRegionInfoRequest;
- if (handlerRegionInfoRequest != null)
+ if (OnMoveInventoryItem != null)
{
- handlerRegionInfoRequest(this);
+ MoveInventoryItem handlerMoveInventoryItem = null;
+ InventoryItemBase itm = null;
+ List items = new List();
+ foreach (MoveInventoryItemPacket.InventoryDataBlock datablock in moveitem.InventoryData)
+ {
+ itm = new InventoryItemBase(datablock.ItemID, AgentId);
+ itm.Folder = datablock.FolderID;
+ itm.Name = Util.FieldToString(datablock.NewName);
+ // weird, comes out as empty string
+ //m_log.DebugFormat("[XXX] new name: {0}", itm.Name);
+ items.Add(itm);
+ }
+ handlerMoveInventoryItem = OnMoveInventoryItem;
+ if (handlerMoveInventoryItem != null)
+ {
+ handlerMoveInventoryItem(this, items);
+ }
}
break;
- case PacketType.EstateCovenantRequest:
-
- //EstateCovenantRequestPacket.AgentDataBlock epack =
- // ((EstateCovenantRequestPacket)Pack).AgentData;
+ case PacketType.RemoveInventoryItem:
+ RemoveInventoryItemPacket removeItem = (RemoveInventoryItemPacket)Pack;
- handlerEstateCovenantRequest = OnEstateCovenantRequest;
- if (handlerEstateCovenantRequest != null)
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- handlerEstateCovenantRequest(this);
+ if (removeItem.AgentData.SessionID != SessionId ||
+ removeItem.AgentData.AgentID != AgentId)
+ break;
}
- break;
-
#endregion
- #region GodPackets
-
- case PacketType.RequestGodlikePowers:
- RequestGodlikePowersPacket rglpPack = (RequestGodlikePowersPacket)Pack;
- RequestGodlikePowersPacket.RequestBlockBlock rblock = rglpPack.RequestBlock;
- UUID token = rblock.Token;
-
- RequestGodlikePowersPacket.AgentDataBlock ablock = rglpPack.AgentData;
+ if (OnRemoveInventoryItem != null)
+ {
+ RemoveInventoryItem handlerRemoveInventoryItem = null;
+ List uuids = new List();
+ foreach (RemoveInventoryItemPacket.InventoryDataBlock datablock in removeItem.InventoryData)
+ {
+ uuids.Add(datablock.ItemID);
+ }
+ handlerRemoveInventoryItem = OnRemoveInventoryItem;
+ if (handlerRemoveInventoryItem != null)
+ {
+ handlerRemoveInventoryItem(this, uuids);
+ }
- handlerReqGodlikePowers = OnRequestGodlikePowers;
+ }
+ break;
+ case PacketType.RemoveInventoryFolder:
+ RemoveInventoryFolderPacket removeFolder = (RemoveInventoryFolderPacket)Pack;
- if (handlerReqGodlikePowers != null)
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- handlerReqGodlikePowers(ablock.AgentID, ablock.SessionID, token, rblock.Godlike, this);
+ if (removeFolder.AgentData.SessionID != SessionId ||
+ removeFolder.AgentData.AgentID != AgentId)
+ break;
}
+ #endregion
- break;
- case PacketType.GodKickUser:
- GodKickUserPacket gkupack = (GodKickUserPacket)Pack;
-
- if (gkupack.UserInfo.GodSessionID == SessionId && AgentId == gkupack.UserInfo.GodID)
+ if (OnRemoveInventoryFolder != null)
{
- handlerGodKickUser = OnGodKickUser;
- if (handlerGodKickUser != null)
+ RemoveInventoryFolder handlerRemoveInventoryFolder = null;
+ List uuids = new List();
+ foreach (RemoveInventoryFolderPacket.FolderDataBlock datablock in removeFolder.FolderData)
{
- handlerGodKickUser(gkupack.UserInfo.GodID, gkupack.UserInfo.GodSessionID,
- gkupack.UserInfo.AgentID, (uint)0, gkupack.UserInfo.Reason);
+ uuids.Add(datablock.FolderID);
+ }
+ handlerRemoveInventoryFolder = OnRemoveInventoryFolder;
+ if (handlerRemoveInventoryFolder != null)
+ {
+ handlerRemoveInventoryFolder(this, uuids);
}
}
- else
- {
- SendAgentAlertMessage("Kick request denied", false);
- }
- //KickUserPacket kupack = new KickUserPacket();
- //KickUserPacket.UserInfoBlock kupackib = kupack.UserInfo;
-
- //kupack.UserInfo.AgentID = gkupack.UserInfo.AgentID;
- //kupack.UserInfo.SessionID = gkupack.UserInfo.GodSessionID;
-
- //kupack.TargetBlock.TargetIP = (uint)0;
- //kupack.TargetBlock.TargetPort = (ushort)0;
- //kupack.UserInfo.Reason = gkupack.UserInfo.Reason;
-
- //OutPacket(kupack, ThrottleOutPacketType.Task);
break;
-
- #endregion
-
- #region Economy/Transaction Packets
-
- case PacketType.MoneyBalanceRequest:
- MoneyBalanceRequestPacket moneybalancerequestpacket = (MoneyBalanceRequestPacket)Pack;
-
+ case PacketType.RemoveInventoryObjects:
+ RemoveInventoryObjectsPacket removeObject = (RemoveInventoryObjectsPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (moneybalancerequestpacket.AgentData.SessionID != SessionId ||
- moneybalancerequestpacket.AgentData.AgentID != AgentId)
+ if (removeObject.AgentData.SessionID != SessionId ||
+ removeObject.AgentData.AgentID != AgentId)
break;
}
#endregion
-
- handlerMoneyBalanceRequest = OnMoneyBalanceRequest;
-
- if (handlerMoneyBalanceRequest != null)
+ if (OnRemoveInventoryFolder != null)
{
- handlerMoneyBalanceRequest(this, moneybalancerequestpacket.AgentData.AgentID, moneybalancerequestpacket.AgentData.SessionID, moneybalancerequestpacket.MoneyData.TransactionID);
+ RemoveInventoryFolder handlerRemoveInventoryFolder = null;
+ List uuids = new List();
+ foreach (RemoveInventoryObjectsPacket.FolderDataBlock datablock in removeObject.FolderData)
+ {
+ uuids.Add(datablock.FolderID);
+ }
+ handlerRemoveInventoryFolder = OnRemoveInventoryFolder;
+ if (handlerRemoveInventoryFolder != null)
+ {
+ handlerRemoveInventoryFolder(this, uuids);
+ }
}
+ if (OnRemoveInventoryItem != null)
+ {
+ RemoveInventoryItem handlerRemoveInventoryItem = null;
+ List uuids = new List();
+ foreach (RemoveInventoryObjectsPacket.ItemDataBlock datablock in removeObject.ItemData)
+ {
+ uuids.Add(datablock.ItemID);
+ }
+ handlerRemoveInventoryItem = OnRemoveInventoryItem;
+ if (handlerRemoveInventoryItem != null)
+ {
+ handlerRemoveInventoryItem(this, uuids);
+ }
+ }
break;
- case PacketType.EconomyDataRequest:
+ case PacketType.RequestTaskInventory:
+ RequestTaskInventoryPacket requesttask = (RequestTaskInventoryPacket)Pack;
-
- handlerEconomoyDataRequest = OnEconomyDataRequest;
- if (handlerEconomoyDataRequest != null)
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- handlerEconomoyDataRequest(AgentId);
+ if (requesttask.AgentData.SessionID != SessionId ||
+ requesttask.AgentData.AgentID != AgentId)
+ break;
}
- break;
- case PacketType.RequestPayPrice:
- RequestPayPricePacket requestPayPricePacket = (RequestPayPricePacket)Pack;
+ #endregion
- handlerRequestPayPrice = OnRequestPayPrice;
- if (handlerRequestPayPrice != null)
+ RequestTaskInventory handlerRequestTaskInventory = OnRequestTaskInventory;
+ if (handlerRequestTaskInventory != null)
{
- handlerRequestPayPrice(this, requestPayPricePacket.ObjectData.ObjectID);
+ handlerRequestTaskInventory(this, requesttask.InventoryData.LocalID);
}
break;
-
- case PacketType.ObjectSaleInfo:
- ObjectSaleInfoPacket objectSaleInfoPacket = (ObjectSaleInfoPacket)Pack;
+ case PacketType.UpdateTaskInventory:
+ UpdateTaskInventoryPacket updatetask = (UpdateTaskInventoryPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (objectSaleInfoPacket.AgentData.SessionID != SessionId ||
- objectSaleInfoPacket.AgentData.AgentID != AgentId)
+ if (updatetask.AgentData.SessionID != SessionId ||
+ updatetask.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerObjectSaleInfo = OnObjectSaleInfo;
- if (handlerObjectSaleInfo != null)
+ if (OnUpdateTaskInventory != null)
{
- foreach (ObjectSaleInfoPacket.ObjectDataBlock d
- in objectSaleInfoPacket.ObjectData)
+ if (updatetask.UpdateData.Key == 0)
{
- handlerObjectSaleInfo(this,
- objectSaleInfoPacket.AgentData.AgentID,
- objectSaleInfoPacket.AgentData.SessionID,
- d.LocalID,
- d.SaleType,
- d.SalePrice);
+ UpdateTaskInventory handlerUpdateTaskInventory = OnUpdateTaskInventory;
+ if (handlerUpdateTaskInventory != null)
+ {
+ TaskInventoryItem newTaskItem = new TaskInventoryItem();
+ newTaskItem.ItemID = updatetask.InventoryData.ItemID;
+ newTaskItem.ParentID = updatetask.InventoryData.FolderID;
+ newTaskItem.CreatorID = updatetask.InventoryData.CreatorID;
+ newTaskItem.OwnerID = updatetask.InventoryData.OwnerID;
+ newTaskItem.GroupID = updatetask.InventoryData.GroupID;
+ newTaskItem.BasePermissions = updatetask.InventoryData.BaseMask;
+ newTaskItem.CurrentPermissions = updatetask.InventoryData.OwnerMask;
+ newTaskItem.GroupPermissions = updatetask.InventoryData.GroupMask;
+ newTaskItem.EveryonePermissions = updatetask.InventoryData.EveryoneMask;
+ newTaskItem.NextPermissions = updatetask.InventoryData.NextOwnerMask;
+ //newTaskItem.GroupOwned=updatetask.InventoryData.GroupOwned;
+ newTaskItem.Type = updatetask.InventoryData.Type;
+ newTaskItem.InvType = updatetask.InventoryData.InvType;
+ newTaskItem.Flags = updatetask.InventoryData.Flags;
+ //newTaskItem.SaleType=updatetask.InventoryData.SaleType;
+ //newTaskItem.SalePrice=updatetask.InventoryData.SalePrice;;
+ newTaskItem.Name = Util.FieldToString(updatetask.InventoryData.Name);
+ newTaskItem.Description = Util.FieldToString(updatetask.InventoryData.Description);
+ newTaskItem.CreationDate = (uint)updatetask.InventoryData.CreationDate;
+ handlerUpdateTaskInventory(this, updatetask.InventoryData.TransactionID,
+ newTaskItem, updatetask.UpdateData.LocalID);
+ }
}
}
+
break;
- case PacketType.ObjectBuy:
- ObjectBuyPacket objectBuyPacket = (ObjectBuyPacket)Pack;
+ case PacketType.RemoveTaskInventory:
+
+ RemoveTaskInventoryPacket removeTask = (RemoveTaskInventoryPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (objectBuyPacket.AgentData.SessionID != SessionId ||
- objectBuyPacket.AgentData.AgentID != AgentId)
+ if (removeTask.AgentData.SessionID != SessionId ||
+ removeTask.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerObjectBuy = OnObjectBuy;
+ RemoveTaskInventory handlerRemoveTaskItem = OnRemoveTaskItem;
- if (handlerObjectBuy != null)
+ if (handlerRemoveTaskItem != null)
{
- foreach (ObjectBuyPacket.ObjectDataBlock d
- in objectBuyPacket.ObjectData)
- {
- handlerObjectBuy(this,
- objectBuyPacket.AgentData.AgentID,
- objectBuyPacket.AgentData.SessionID,
- objectBuyPacket.AgentData.GroupID,
- objectBuyPacket.AgentData.CategoryID,
- d.ObjectLocalID,
- d.SaleType,
- d.SalePrice);
- }
+ handlerRemoveTaskItem(this, removeTask.InventoryData.ItemID, removeTask.InventoryData.LocalID);
}
- break;
-
- #endregion
-
- #region Script Packets
- case PacketType.GetScriptRunning:
- GetScriptRunningPacket scriptRunning = (GetScriptRunningPacket)Pack;
-
- handlerGetScriptRunning = OnGetScriptRunning;
- if (handlerGetScriptRunning != null)
- {
- handlerGetScriptRunning(this, scriptRunning.Script.ObjectID, scriptRunning.Script.ItemID);
- }
break;
- case PacketType.SetScriptRunning:
- SetScriptRunningPacket setScriptRunning = (SetScriptRunningPacket)Pack;
+ case PacketType.MoveTaskInventory:
+
+ MoveTaskInventoryPacket moveTaskInventoryPacket = (MoveTaskInventoryPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (setScriptRunning.AgentData.SessionID != SessionId ||
- setScriptRunning.AgentData.AgentID != AgentId)
+ if (moveTaskInventoryPacket.AgentData.SessionID != SessionId ||
+ moveTaskInventoryPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerSetScriptRunning = OnSetScriptRunning;
- if (handlerSetScriptRunning != null)
+ MoveTaskInventory handlerMoveTaskItem = OnMoveTaskItem;
+
+ if (handlerMoveTaskItem != null)
{
- handlerSetScriptRunning(this, setScriptRunning.Script.ObjectID, setScriptRunning.Script.ItemID, setScriptRunning.Script.Running);
+ handlerMoveTaskItem(
+ this, moveTaskInventoryPacket.AgentData.FolderID,
+ moveTaskInventoryPacket.InventoryData.LocalID,
+ moveTaskInventoryPacket.InventoryData.ItemID);
}
+
break;
- case PacketType.ScriptReset:
- ScriptResetPacket scriptResetPacket = (ScriptResetPacket)Pack;
+ case PacketType.RezScript:
+ //m_log.Debug(Pack.ToString());
+ RezScriptPacket rezScriptx = (RezScriptPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (scriptResetPacket.AgentData.SessionID != SessionId ||
- scriptResetPacket.AgentData.AgentID != AgentId)
+ if (rezScriptx.AgentData.SessionID != SessionId ||
+ rezScriptx.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerScriptReset = OnScriptReset;
- if (handlerScriptReset != null)
+ RezScript handlerRezScript = OnRezScript;
+ InventoryItemBase item = new InventoryItemBase();
+ item.ID = rezScriptx.InventoryBlock.ItemID;
+ item.Folder = rezScriptx.InventoryBlock.FolderID;
+ item.CreatorId = rezScriptx.InventoryBlock.CreatorID.ToString();
+ item.Owner = rezScriptx.InventoryBlock.OwnerID;
+ item.BasePermissions = rezScriptx.InventoryBlock.BaseMask;
+ item.CurrentPermissions = rezScriptx.InventoryBlock.OwnerMask;
+ item.EveryOnePermissions = rezScriptx.InventoryBlock.EveryoneMask;
+ item.NextPermissions = rezScriptx.InventoryBlock.NextOwnerMask;
+ item.GroupPermissions = rezScriptx.InventoryBlock.GroupMask;
+ item.GroupOwned = rezScriptx.InventoryBlock.GroupOwned;
+ item.GroupID = rezScriptx.InventoryBlock.GroupID;
+ item.AssetType = rezScriptx.InventoryBlock.Type;
+ item.InvType = rezScriptx.InventoryBlock.InvType;
+ item.Flags = rezScriptx.InventoryBlock.Flags;
+ item.SaleType = rezScriptx.InventoryBlock.SaleType;
+ item.SalePrice = rezScriptx.InventoryBlock.SalePrice;
+ item.Name = Util.FieldToString(rezScriptx.InventoryBlock.Name);
+ item.Description = Util.FieldToString(rezScriptx.InventoryBlock.Description);
+ item.CreationDate = rezScriptx.InventoryBlock.CreationDate;
+
+ if (handlerRezScript != null)
{
- handlerScriptReset(this, scriptResetPacket.Script.ObjectID, scriptResetPacket.Script.ItemID);
+ handlerRezScript(this, item, rezScriptx.InventoryBlock.TransactionID, rezScriptx.UpdateBlock.ObjectLocalID);
}
break;
- #endregion
-
- #region Gesture Managment
-
- case PacketType.ActivateGestures:
- ActivateGesturesPacket activateGesturePacket = (ActivateGesturesPacket)Pack;
+ case PacketType.MapLayerRequest:
+ RequestMapLayer();
+ break;
+ case PacketType.MapBlockRequest:
+ MapBlockRequestPacket MapRequest = (MapBlockRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (activateGesturePacket.AgentData.SessionID != SessionId ||
- activateGesturePacket.AgentData.AgentID != AgentId)
+ if (MapRequest.AgentData.SessionID != SessionId ||
+ MapRequest.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerActivateGesture = OnActivateGesture;
- if (handlerActivateGesture != null)
+ RequestMapBlocks handlerRequestMapBlocks = OnRequestMapBlocks;
+ if (handlerRequestMapBlocks != null)
{
- handlerActivateGesture(this,
- activateGesturePacket.Data[0].AssetID,
- activateGesturePacket.Data[0].ItemID);
+ handlerRequestMapBlocks(this, MapRequest.PositionData.MinX, MapRequest.PositionData.MinY,
+ MapRequest.PositionData.MaxX, MapRequest.PositionData.MaxY, MapRequest.AgentData.Flags);
}
- else m_log.Error("Null pointer for activateGesture");
-
break;
-
- case PacketType.DeactivateGestures:
- DeactivateGesturesPacket deactivateGesturePacket = (DeactivateGesturesPacket)Pack;
+ case PacketType.MapNameRequest:
+ MapNameRequestPacket map = (MapNameRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (deactivateGesturePacket.AgentData.SessionID != SessionId ||
- deactivateGesturePacket.AgentData.AgentID != AgentId)
+ if (map.AgentData.SessionID != SessionId ||
+ map.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerDeactivateGesture = OnDeactivateGesture;
- if (handlerDeactivateGesture != null)
+ string mapName = Util.UTF8.GetString(map.NameData.Name, 0,
+ map.NameData.Name.Length - 1);
+ RequestMapName handlerMapNameRequest = OnMapNameRequest;
+ if (handlerMapNameRequest != null)
{
- handlerDeactivateGesture(this, deactivateGesturePacket.Data[0].ItemID);
+ handlerMapNameRequest(this, mapName);
}
break;
- case PacketType.ObjectOwner:
- ObjectOwnerPacket objectOwnerPacket = (ObjectOwnerPacket)Pack;
+ case PacketType.TeleportLandmarkRequest:
+ TeleportLandmarkRequestPacket tpReq = (TeleportLandmarkRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (objectOwnerPacket.AgentData.SessionID != SessionId ||
- objectOwnerPacket.AgentData.AgentID != AgentId)
+ if (tpReq.Info.SessionID != SessionId ||
+ tpReq.Info.AgentID != AgentId)
break;
}
#endregion
- List localIDs = new List();
+ UUID lmid = tpReq.Info.LandmarkID;
+ AssetLandmark lm;
+ if (lmid != UUID.Zero)
+ {
+ //AssetBase lma = m_assetCache.GetAsset(lmid, false);
+ AssetBase lma = m_assetService.Get(lmid.ToString());
- foreach (ObjectOwnerPacket.ObjectDataBlock d in objectOwnerPacket.ObjectData)
- localIDs.Add(d.ObjectLocalID);
+ if (lma == null)
+ {
+ // Failed to find landmark
+ TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
+ tpCancel.Info.SessionID = tpReq.Info.SessionID;
+ tpCancel.Info.AgentID = tpReq.Info.AgentID;
+ OutPacket(tpCancel, ThrottleOutPacketType.Task);
+ }
- handlerObjectOwner = OnObjectOwner;
- if (handlerObjectOwner != null)
+ try
+ {
+ lm = new AssetLandmark(lma);
+ }
+ catch (NullReferenceException)
+ {
+ // asset not found generates null ref inside the assetlandmark constructor.
+ TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
+ tpCancel.Info.SessionID = tpReq.Info.SessionID;
+ tpCancel.Info.AgentID = tpReq.Info.AgentID;
+ OutPacket(tpCancel, ThrottleOutPacketType.Task);
+ break;
+ }
+ }
+ else
{
- handlerObjectOwner(this, objectOwnerPacket.HeaderData.OwnerID, objectOwnerPacket.HeaderData.GroupID, localIDs);
+ // Teleport home request
+ UUIDNameRequest handlerTeleportHomeRequest = OnTeleportHomeRequest;
+ if (handlerTeleportHomeRequest != null)
+ {
+ handlerTeleportHomeRequest(AgentId, this);
+ }
+ break;
}
- break;
-
- #endregion
-
-
- #region unimplemented handlers
-
- case PacketType.StartPingCheck:
- // Send the client the ping response back
- // Pass the same PingID in the matching packet
- // Handled In the packet processing
- //m_log.Debug("[CLIENT]: possibly unhandled StartPingCheck packet");
- break;
- case PacketType.CompletePingCheck:
- // TODO: Perhaps this should be processed on the Sim to determine whether or not to drop a dead client
- //m_log.Warn("[CLIENT]: unhandled CompletePingCheck packet");
- break;
-
- case PacketType.ViewerStats:
- // TODO: handle this packet
- //m_log.Warn("[CLIENT]: unhandled ViewerStats packet");
- break;
- case PacketType.MapItemRequest:
- MapItemRequestPacket mirpk = (MapItemRequestPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
+ TeleportLandmarkRequest handlerTeleportLandmarkRequest = OnTeleportLandmarkRequest;
+ if (handlerTeleportLandmarkRequest != null)
{
- if (mirpk.AgentData.SessionID != SessionId ||
- mirpk.AgentData.AgentID != AgentId)
- break;
+ handlerTeleportLandmarkRequest(this, lm.RegionID, lm.Position);
}
- #endregion
-
- //m_log.Debug(mirpk.ToString());
- handlerMapItemRequest = OnMapItemRequest;
- if (handlerMapItemRequest != null)
+ else
{
- handlerMapItemRequest(this,mirpk.AgentData.Flags, mirpk.AgentData.EstateID,
- mirpk.AgentData.Godlike,mirpk.RequestData.ItemType,
- mirpk.RequestData.RegionHandle);
+ //no event handler so cancel request
+
+
+ TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
+ tpCancel.Info.AgentID = tpReq.Info.AgentID;
+ tpCancel.Info.SessionID = tpReq.Info.SessionID;
+ OutPacket(tpCancel, ThrottleOutPacketType.Task);
}
break;
- case PacketType.TransferAbort:
- // TODO: handle this packet
- //m_log.Warn("[CLIENT]: unhandled TransferAbort packet");
- break;
- case PacketType.MuteListRequest:
- MuteListRequestPacket muteListRequest =
- (MuteListRequestPacket)Pack;
+ case PacketType.TeleportLocationRequest:
+ TeleportLocationRequestPacket tpLocReq = (TeleportLocationRequestPacket)Pack;
+ // m_log.Debug(tpLocReq.ToString());
#region Packet Session and User Check
if (m_checkPackets)
{
- if (muteListRequest.AgentData.SessionID != SessionId ||
- muteListRequest.AgentData.AgentID != AgentId)
+ if (tpLocReq.AgentData.SessionID != SessionId ||
+ tpLocReq.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerMuteListRequest = OnMuteListRequest;
- if (handlerMuteListRequest != null)
+ TeleportLocationRequest handlerTeleportLocationRequest = OnTeleportLocationRequest;
+ if (handlerTeleportLocationRequest != null)
{
- handlerMuteListRequest(this, muteListRequest.MuteData.MuteCRC);
+ handlerTeleportLocationRequest(this, tpLocReq.Info.RegionHandle, tpLocReq.Info.Position,
+ tpLocReq.Info.LookAt, 16);
}
else
{
- SendUseCachedMuteList();
+ //no event handler so cancel request
+ TeleportCancelPacket tpCancel = (TeleportCancelPacket)PacketPool.Instance.GetPacket(PacketType.TeleportCancel);
+ tpCancel.Info.SessionID = tpLocReq.AgentData.SessionID;
+ tpCancel.Info.AgentID = tpLocReq.AgentData.AgentID;
+ OutPacket(tpCancel, ThrottleOutPacketType.Task);
}
break;
- case PacketType.UseCircuitCode:
- // Don't display this one, we handle it at a lower level
- break;
- case PacketType.AgentHeightWidth:
- // TODO: handle this packet
- //m_log.Warn("[CLIENT]: unhandled AgentHeightWidth packet");
+ #endregion
+
+ case PacketType.UUIDNameRequest:
+ UUIDNameRequestPacket incoming = (UUIDNameRequestPacket)Pack;
+
+ foreach (UUIDNameRequestPacket.UUIDNameBlockBlock UUIDBlock in incoming.UUIDNameBlock)
+ {
+ UUIDNameRequest handlerNameRequest = OnNameFromUUIDRequest;
+ if (handlerNameRequest != null)
+ {
+ handlerNameRequest(UUIDBlock.ID, this);
+ }
+ }
break;
- case PacketType.InventoryDescendents:
- // TODO: handle this packet
- //m_log.Warn("[CLIENT]: unhandled InventoryDescent packet");
+ #region Parcel related packets
+ case PacketType.RegionHandleRequest:
+ RegionHandleRequestPacket rhrPack = (RegionHandleRequestPacket)Pack;
+
+ RegionHandleRequest handlerRegionHandleRequest = OnRegionHandleRequest;
+ if (handlerRegionHandleRequest != null)
+ {
+ handlerRegionHandleRequest(this, rhrPack.RequestBlock.RegionID);
+ }
break;
- case PacketType.DirPlacesQuery:
- DirPlacesQueryPacket dirPlacesQueryPacket = (DirPlacesQueryPacket)Pack;
- //m_log.Debug(dirPlacesQueryPacket.ToString());
+
+ case PacketType.ParcelInfoRequest:
+ ParcelInfoRequestPacket pirPack = (ParcelInfoRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (dirPlacesQueryPacket.AgentData.SessionID != SessionId ||
- dirPlacesQueryPacket.AgentData.AgentID != AgentId)
+ if (pirPack.AgentData.SessionID != SessionId ||
+ pirPack.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerDirPlacesQuery = OnDirPlacesQuery;
- if (handlerDirPlacesQuery != null)
+ ParcelInfoRequest handlerParcelInfoRequest = OnParcelInfoRequest;
+ if (handlerParcelInfoRequest != null)
{
- handlerDirPlacesQuery(this,
- dirPlacesQueryPacket.QueryData.QueryID,
- Utils.BytesToString(
- dirPlacesQueryPacket.QueryData.QueryText),
- (int)dirPlacesQueryPacket.QueryData.QueryFlags,
- (int)dirPlacesQueryPacket.QueryData.Category,
- Utils.BytesToString(
- dirPlacesQueryPacket.QueryData.SimName),
- dirPlacesQueryPacket.QueryData.QueryStart);
+ handlerParcelInfoRequest(this, pirPack.Data.ParcelID);
}
break;
- case PacketType.DirFindQuery:
- DirFindQueryPacket dirFindQueryPacket = (DirFindQueryPacket)Pack;
+
+ case PacketType.ParcelAccessListRequest:
+ ParcelAccessListRequestPacket requestPacket = (ParcelAccessListRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (dirFindQueryPacket.AgentData.SessionID != SessionId ||
- dirFindQueryPacket.AgentData.AgentID != AgentId)
+ if (requestPacket.AgentData.SessionID != SessionId ||
+ requestPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerDirFindQuery = OnDirFindQuery;
- if (handlerDirFindQuery != null)
+ ParcelAccessListRequest handlerParcelAccessListRequest = OnParcelAccessListRequest;
+
+ if (handlerParcelAccessListRequest != null)
{
- handlerDirFindQuery(this,
- dirFindQueryPacket.QueryData.QueryID,
- Utils.BytesToString(
- dirFindQueryPacket.QueryData.QueryText),
- dirFindQueryPacket.QueryData.QueryFlags,
- dirFindQueryPacket.QueryData.QueryStart);
+ handlerParcelAccessListRequest(requestPacket.AgentData.AgentID, requestPacket.AgentData.SessionID,
+ requestPacket.Data.Flags, requestPacket.Data.SequenceID,
+ requestPacket.Data.LocalID, this);
}
break;
- case PacketType.DirLandQuery:
- DirLandQueryPacket dirLandQueryPacket = (DirLandQueryPacket)Pack;
+
+ case PacketType.ParcelAccessListUpdate:
+ ParcelAccessListUpdatePacket updatePacket = (ParcelAccessListUpdatePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (dirLandQueryPacket.AgentData.SessionID != SessionId ||
- dirLandQueryPacket.AgentData.AgentID != AgentId)
+ if (updatePacket.AgentData.SessionID != SessionId ||
+ updatePacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerDirLandQuery = OnDirLandQuery;
- if (handlerDirLandQuery != null)
+ List entries = new List();
+ foreach (ParcelAccessListUpdatePacket.ListBlock block in updatePacket.List)
{
- handlerDirLandQuery(this,
- dirLandQueryPacket.QueryData.QueryID,
- dirLandQueryPacket.QueryData.QueryFlags,
- dirLandQueryPacket.QueryData.SearchType,
- dirLandQueryPacket.QueryData.Price,
- dirLandQueryPacket.QueryData.Area,
- dirLandQueryPacket.QueryData.QueryStart);
+ ParcelManager.ParcelAccessEntry entry = new ParcelManager.ParcelAccessEntry();
+ entry.AgentID = block.ID;
+ entry.Flags = (AccessList)block.Flags;
+ entry.Time = new DateTime();
+ entries.Add(entry);
+ }
+
+ ParcelAccessListUpdateRequest handlerParcelAccessListUpdateRequest = OnParcelAccessListUpdateRequest;
+ if (handlerParcelAccessListUpdateRequest != null)
+ {
+ handlerParcelAccessListUpdateRequest(updatePacket.AgentData.AgentID,
+ updatePacket.AgentData.SessionID, updatePacket.Data.Flags,
+ updatePacket.Data.LocalID, entries, this);
}
break;
- case PacketType.DirPopularQuery:
- DirPopularQueryPacket dirPopularQueryPacket = (DirPopularQueryPacket)Pack;
+ case PacketType.ParcelPropertiesRequest:
+
+ ParcelPropertiesRequestPacket propertiesRequest = (ParcelPropertiesRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (dirPopularQueryPacket.AgentData.SessionID != SessionId ||
- dirPopularQueryPacket.AgentData.AgentID != AgentId)
+ if (propertiesRequest.AgentData.SessionID != SessionId ||
+ propertiesRequest.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerDirPopularQuery = OnDirPopularQuery;
- if (handlerDirPopularQuery != null)
+ ParcelPropertiesRequest handlerParcelPropertiesRequest = OnParcelPropertiesRequest;
+ if (handlerParcelPropertiesRequest != null)
{
- handlerDirPopularQuery(this,
- dirPopularQueryPacket.QueryData.QueryID,
- dirPopularQueryPacket.QueryData.QueryFlags);
+ handlerParcelPropertiesRequest((int)Math.Round(propertiesRequest.ParcelData.West),
+ (int)Math.Round(propertiesRequest.ParcelData.South),
+ (int)Math.Round(propertiesRequest.ParcelData.East),
+ (int)Math.Round(propertiesRequest.ParcelData.North),
+ propertiesRequest.ParcelData.SequenceID,
+ propertiesRequest.ParcelData.SnapSelection, this);
}
break;
- case PacketType.DirClassifiedQuery:
- DirClassifiedQueryPacket dirClassifiedQueryPacket = (DirClassifiedQueryPacket)Pack;
+ case PacketType.ParcelDivide:
+ ParcelDividePacket landDivide = (ParcelDividePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (dirClassifiedQueryPacket.AgentData.SessionID != SessionId ||
- dirClassifiedQueryPacket.AgentData.AgentID != AgentId)
+ if (landDivide.AgentData.SessionID != SessionId ||
+ landDivide.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerDirClassifiedQuery = OnDirClassifiedQuery;
- if (handlerDirClassifiedQuery != null)
+ ParcelDivideRequest handlerParcelDivideRequest = OnParcelDivideRequest;
+ if (handlerParcelDivideRequest != null)
{
- handlerDirClassifiedQuery(this,
- dirClassifiedQueryPacket.QueryData.QueryID,
- Utils.BytesToString(
- dirClassifiedQueryPacket.QueryData.QueryText),
- dirClassifiedQueryPacket.QueryData.QueryFlags,
- dirClassifiedQueryPacket.QueryData.Category,
- dirClassifiedQueryPacket.QueryData.QueryStart);
+ handlerParcelDivideRequest((int)Math.Round(landDivide.ParcelData.West),
+ (int)Math.Round(landDivide.ParcelData.South),
+ (int)Math.Round(landDivide.ParcelData.East),
+ (int)Math.Round(landDivide.ParcelData.North), this);
}
break;
- case PacketType.EventInfoRequest:
- EventInfoRequestPacket eventInfoRequestPacket = (EventInfoRequestPacket)Pack;
+ case PacketType.ParcelJoin:
+ ParcelJoinPacket landJoin = (ParcelJoinPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (eventInfoRequestPacket.AgentData.SessionID != SessionId ||
- eventInfoRequestPacket.AgentData.AgentID != AgentId)
+ if (landJoin.AgentData.SessionID != SessionId ||
+ landJoin.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (OnEventInfoRequest != null)
+ ParcelJoinRequest handlerParcelJoinRequest = OnParcelJoinRequest;
+
+ if (handlerParcelJoinRequest != null)
{
- OnEventInfoRequest(this, eventInfoRequestPacket.EventData.EventID);
+ handlerParcelJoinRequest((int)Math.Round(landJoin.ParcelData.West),
+ (int)Math.Round(landJoin.ParcelData.South),
+ (int)Math.Round(landJoin.ParcelData.East),
+ (int)Math.Round(landJoin.ParcelData.North), this);
}
break;
-
- #region Calling Card
-
- case PacketType.OfferCallingCard:
- OfferCallingCardPacket offerCallingCardPacket = (OfferCallingCardPacket)Pack;
+ case PacketType.ParcelPropertiesUpdate:
+ ParcelPropertiesUpdatePacket parcelPropertiesPacket = (ParcelPropertiesUpdatePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (offerCallingCardPacket.AgentData.SessionID != SessionId ||
- offerCallingCardPacket.AgentData.AgentID != AgentId)
+ if (parcelPropertiesPacket.AgentData.SessionID != SessionId ||
+ parcelPropertiesPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (OnOfferCallingCard != null)
+ ParcelPropertiesUpdateRequest handlerParcelPropertiesUpdateRequest = OnParcelPropertiesUpdateRequest;
+
+ if (handlerParcelPropertiesUpdateRequest != null)
{
- OnOfferCallingCard(this,
- offerCallingCardPacket.AgentBlock.DestID,
- offerCallingCardPacket.AgentBlock.TransactionID);
+ LandUpdateArgs args = new LandUpdateArgs();
+
+ args.AuthBuyerID = parcelPropertiesPacket.ParcelData.AuthBuyerID;
+ args.Category = (ParcelCategory)parcelPropertiesPacket.ParcelData.Category;
+ args.Desc = Utils.BytesToString(parcelPropertiesPacket.ParcelData.Desc);
+ args.GroupID = parcelPropertiesPacket.ParcelData.GroupID;
+ args.LandingType = parcelPropertiesPacket.ParcelData.LandingType;
+ args.MediaAutoScale = parcelPropertiesPacket.ParcelData.MediaAutoScale;
+ args.MediaID = parcelPropertiesPacket.ParcelData.MediaID;
+ args.MediaURL = Utils.BytesToString(parcelPropertiesPacket.ParcelData.MediaURL);
+ args.MusicURL = Utils.BytesToString(parcelPropertiesPacket.ParcelData.MusicURL);
+ args.Name = Utils.BytesToString(parcelPropertiesPacket.ParcelData.Name);
+ args.ParcelFlags = parcelPropertiesPacket.ParcelData.ParcelFlags;
+ args.PassHours = parcelPropertiesPacket.ParcelData.PassHours;
+ args.PassPrice = parcelPropertiesPacket.ParcelData.PassPrice;
+ args.SalePrice = parcelPropertiesPacket.ParcelData.SalePrice;
+ args.SnapshotID = parcelPropertiesPacket.ParcelData.SnapshotID;
+ args.UserLocation = parcelPropertiesPacket.ParcelData.UserLocation;
+ args.UserLookAt = parcelPropertiesPacket.ParcelData.UserLookAt;
+ handlerParcelPropertiesUpdateRequest(args, parcelPropertiesPacket.ParcelData.LocalID, this);
}
break;
-
- case PacketType.AcceptCallingCard:
- AcceptCallingCardPacket acceptCallingCardPacket = (AcceptCallingCardPacket)Pack;
+ case PacketType.ParcelSelectObjects:
+ ParcelSelectObjectsPacket selectPacket = (ParcelSelectObjectsPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (acceptCallingCardPacket.AgentData.SessionID != SessionId ||
- acceptCallingCardPacket.AgentData.AgentID != AgentId)
+ if (selectPacket.AgentData.SessionID != SessionId ||
+ selectPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- // according to http://wiki.secondlife.com/wiki/AcceptCallingCard FolderData should
- // contain exactly one entry
- if (OnAcceptCallingCard != null && acceptCallingCardPacket.FolderData.Length > 0)
+ List returnIDs = new List();
+
+ foreach (ParcelSelectObjectsPacket.ReturnIDsBlock rb in
+ selectPacket.ReturnIDs)
{
- OnAcceptCallingCard(this,
- acceptCallingCardPacket.TransactionBlock.TransactionID,
- acceptCallingCardPacket.FolderData[0].FolderID);
+ returnIDs.Add(rb.ReturnID);
}
- break;
- case PacketType.DeclineCallingCard:
- DeclineCallingCardPacket declineCallingCardPacket = (DeclineCallingCardPacket)Pack;
+ ParcelSelectObjects handlerParcelSelectObjects = OnParcelSelectObjects;
+
+ if (handlerParcelSelectObjects != null)
+ {
+ handlerParcelSelectObjects(selectPacket.ParcelData.LocalID,
+ Convert.ToInt32(selectPacket.ParcelData.ReturnType), returnIDs, this);
+ }
+ break;
+ case PacketType.ParcelObjectOwnersRequest:
+ //m_log.Debug(Pack.ToString());
+ ParcelObjectOwnersRequestPacket reqPacket = (ParcelObjectOwnersRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (declineCallingCardPacket.AgentData.SessionID != SessionId ||
- declineCallingCardPacket.AgentData.AgentID != AgentId)
+ if (reqPacket.AgentData.SessionID != SessionId ||
+ reqPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (OnDeclineCallingCard != null)
+ ParcelObjectOwnerRequest handlerParcelObjectOwnerRequest = OnParcelObjectOwnerRequest;
+
+ if (handlerParcelObjectOwnerRequest != null)
{
- OnDeclineCallingCard(this,
- declineCallingCardPacket.TransactionBlock.TransactionID);
+ handlerParcelObjectOwnerRequest(reqPacket.ParcelData.LocalID, this);
}
break;
- #endregion
-
- #region Groups
- case PacketType.ActivateGroup:
- ActivateGroupPacket activateGroupPacket = (ActivateGroupPacket)Pack;
+ case PacketType.ParcelGodForceOwner:
+ ParcelGodForceOwnerPacket godForceOwnerPacket = (ParcelGodForceOwnerPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (activateGroupPacket.AgentData.SessionID != SessionId ||
- activateGroupPacket.AgentData.AgentID != AgentId)
+ if (godForceOwnerPacket.AgentData.SessionID != SessionId ||
+ godForceOwnerPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ ParcelGodForceOwner handlerParcelGodForceOwner = OnParcelGodForceOwner;
+ if (handlerParcelGodForceOwner != null)
{
- m_GroupsModule.ActivateGroup(this, activateGroupPacket.AgentData.GroupID);
- m_GroupsModule.SendAgentGroupDataUpdate(this);
+ handlerParcelGodForceOwner(godForceOwnerPacket.Data.LocalID, godForceOwnerPacket.Data.OwnerID, this);
}
break;
-
- case PacketType.GroupTitlesRequest:
- GroupTitlesRequestPacket groupTitlesRequest =
- (GroupTitlesRequestPacket)Pack;
+ case PacketType.ParcelRelease:
+ ParcelReleasePacket releasePacket = (ParcelReleasePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupTitlesRequest.AgentData.SessionID != SessionId ||
- groupTitlesRequest.AgentData.AgentID != AgentId)
+ if (releasePacket.AgentData.SessionID != SessionId ||
+ releasePacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ ParcelAbandonRequest handlerParcelAbandonRequest = OnParcelAbandonRequest;
+ if (handlerParcelAbandonRequest != null)
{
- GroupTitlesReplyPacket groupTitlesReply = (GroupTitlesReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupTitlesReply);
-
- groupTitlesReply.AgentData =
- new GroupTitlesReplyPacket.AgentDataBlock();
-
- groupTitlesReply.AgentData.AgentID = AgentId;
- groupTitlesReply.AgentData.GroupID =
- groupTitlesRequest.AgentData.GroupID;
-
- groupTitlesReply.AgentData.RequestID =
- groupTitlesRequest.AgentData.RequestID;
-
- List titles =
- m_GroupsModule.GroupTitlesRequest(this,
- groupTitlesRequest.AgentData.GroupID);
-
- groupTitlesReply.GroupData =
- new GroupTitlesReplyPacket.GroupDataBlock[titles.Count];
-
- int i = 0;
- foreach (GroupTitlesData d in titles)
- {
- groupTitlesReply.GroupData[i] =
- new GroupTitlesReplyPacket.GroupDataBlock();
+ handlerParcelAbandonRequest(releasePacket.Data.LocalID, this);
+ }
+ break;
+ case PacketType.ParcelReclaim:
+ ParcelReclaimPacket reclaimPacket = (ParcelReclaimPacket)Pack;
- groupTitlesReply.GroupData[i].Title =
- Utils.StringToBytes(d.Name);
- groupTitlesReply.GroupData[i].RoleID =
- d.UUID;
- groupTitlesReply.GroupData[i].Selected =
- d.Selected;
- i++;
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (reclaimPacket.AgentData.SessionID != SessionId ||
+ reclaimPacket.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- OutPacket(groupTitlesReply, ThrottleOutPacketType.Task);
+ ParcelReclaim handlerParcelReclaim = OnParcelReclaim;
+ if (handlerParcelReclaim != null)
+ {
+ handlerParcelReclaim(reclaimPacket.Data.LocalID, this);
}
break;
+ case PacketType.ParcelReturnObjects:
- case PacketType.GroupProfileRequest:
- GroupProfileRequestPacket groupProfileRequest =
- (GroupProfileRequestPacket)Pack;
+
+ ParcelReturnObjectsPacket parcelReturnObjects = (ParcelReturnObjectsPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupProfileRequest.AgentData.SessionID != SessionId ||
- groupProfileRequest.AgentData.AgentID != AgentId)
+ if (parcelReturnObjects.AgentData.SessionID != SessionId ||
+ parcelReturnObjects.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
- {
- GroupProfileReplyPacket groupProfileReply = (GroupProfileReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupProfileReply);
+ UUID[] puserselectedOwnerIDs = new UUID[parcelReturnObjects.OwnerIDs.Length];
+ for (int parceliterator = 0; parceliterator < parcelReturnObjects.OwnerIDs.Length; parceliterator++)
+ puserselectedOwnerIDs[parceliterator] = parcelReturnObjects.OwnerIDs[parceliterator].OwnerID;
- groupProfileReply.AgentData = new GroupProfileReplyPacket.AgentDataBlock();
- groupProfileReply.GroupData = new GroupProfileReplyPacket.GroupDataBlock();
- groupProfileReply.AgentData.AgentID = AgentId;
+ UUID[] puserselectedTaskIDs = new UUID[parcelReturnObjects.TaskIDs.Length];
- GroupProfileData d = m_GroupsModule.GroupProfileRequest(this,
- groupProfileRequest.GroupData.GroupID);
+ for (int parceliterator = 0; parceliterator < parcelReturnObjects.TaskIDs.Length; parceliterator++)
+ puserselectedTaskIDs[parceliterator] = parcelReturnObjects.TaskIDs[parceliterator].TaskID;
- groupProfileReply.GroupData.GroupID = d.GroupID;
- groupProfileReply.GroupData.Name = Utils.StringToBytes(d.Name);
- groupProfileReply.GroupData.Charter = Utils.StringToBytes(d.Charter);
- groupProfileReply.GroupData.ShowInList = d.ShowInList;
- groupProfileReply.GroupData.MemberTitle = Utils.StringToBytes(d.MemberTitle);
- groupProfileReply.GroupData.PowersMask = d.PowersMask;
- groupProfileReply.GroupData.InsigniaID = d.InsigniaID;
- groupProfileReply.GroupData.FounderID = d.FounderID;
- groupProfileReply.GroupData.MembershipFee = d.MembershipFee;
- groupProfileReply.GroupData.OpenEnrollment = d.OpenEnrollment;
- groupProfileReply.GroupData.Money = d.Money;
- groupProfileReply.GroupData.GroupMembershipCount = d.GroupMembershipCount;
- groupProfileReply.GroupData.GroupRolesCount = d.GroupRolesCount;
- groupProfileReply.GroupData.AllowPublish = d.AllowPublish;
- groupProfileReply.GroupData.MaturePublish = d.MaturePublish;
- groupProfileReply.GroupData.OwnerRole = d.OwnerRole;
+ ParcelReturnObjectsRequest handlerParcelReturnObjectsRequest = OnParcelReturnObjectsRequest;
+ if (handlerParcelReturnObjectsRequest != null)
+ {
+ handlerParcelReturnObjectsRequest(parcelReturnObjects.ParcelData.LocalID, parcelReturnObjects.ParcelData.ReturnType, puserselectedOwnerIDs, puserselectedTaskIDs, this);
- OutPacket(groupProfileReply, ThrottleOutPacketType.Task);
}
break;
- case PacketType.GroupMembersRequest:
- GroupMembersRequestPacket groupMembersRequestPacket =
- (GroupMembersRequestPacket)Pack;
+ case PacketType.ParcelSetOtherCleanTime:
+ ParcelSetOtherCleanTimePacket parcelSetOtherCleanTimePacket = (ParcelSetOtherCleanTimePacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupMembersRequestPacket.AgentData.SessionID != SessionId ||
- groupMembersRequestPacket.AgentData.AgentID != AgentId)
+ if (parcelSetOtherCleanTimePacket.AgentData.SessionID != SessionId ||
+ parcelSetOtherCleanTimePacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ ParcelSetOtherCleanTime handlerParcelSetOtherCleanTime = OnParcelSetOtherCleanTime;
+ if (handlerParcelSetOtherCleanTime != null)
{
- List members =
- m_GroupsModule.GroupMembersRequest(this, groupMembersRequestPacket.GroupData.GroupID);
-
- int memberCount = members.Count;
-
- while (true)
- {
- int blockCount = members.Count;
- if (blockCount > 40)
- blockCount = 40;
-
- GroupMembersReplyPacket groupMembersReply = (GroupMembersReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupMembersReply);
-
- groupMembersReply.AgentData =
- new GroupMembersReplyPacket.AgentDataBlock();
- groupMembersReply.GroupData =
- new GroupMembersReplyPacket.GroupDataBlock();
- groupMembersReply.MemberData =
- new GroupMembersReplyPacket.MemberDataBlock[
- blockCount];
-
- groupMembersReply.AgentData.AgentID = AgentId;
- groupMembersReply.GroupData.GroupID =
- groupMembersRequestPacket.GroupData.GroupID;
- groupMembersReply.GroupData.RequestID =
- groupMembersRequestPacket.GroupData.RequestID;
- groupMembersReply.GroupData.MemberCount = memberCount;
-
- for (int i = 0 ; i < blockCount ; i++)
- {
- GroupMembersData m = members[0];
- members.RemoveAt(0);
-
- groupMembersReply.MemberData[i] =
- new GroupMembersReplyPacket.MemberDataBlock();
- groupMembersReply.MemberData[i].AgentID =
- m.AgentID;
- groupMembersReply.MemberData[i].Contribution =
- m.Contribution;
- groupMembersReply.MemberData[i].OnlineStatus =
- Utils.StringToBytes(m.OnlineStatus);
- groupMembersReply.MemberData[i].AgentPowers =
- m.AgentPowers;
- groupMembersReply.MemberData[i].Title =
- Utils.StringToBytes(m.Title);
- groupMembersReply.MemberData[i].IsOwner =
- m.IsOwner;
- }
- OutPacket(groupMembersReply, ThrottleOutPacketType.Task);
- if (members.Count == 0)
- break;
- }
+ handlerParcelSetOtherCleanTime(this,
+ parcelSetOtherCleanTimePacket.ParcelData.LocalID,
+ parcelSetOtherCleanTimePacket.ParcelData.OtherCleanTime);
}
break;
- case PacketType.GroupRoleDataRequest:
- GroupRoleDataRequestPacket groupRolesRequest =
- (GroupRoleDataRequestPacket)Pack;
+ case PacketType.LandStatRequest:
+ LandStatRequestPacket lsrp = (LandStatRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupRolesRequest.AgentData.SessionID != SessionId ||
- groupRolesRequest.AgentData.AgentID != AgentId)
+ if (lsrp.AgentData.SessionID != SessionId ||
+ lsrp.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ GodLandStatRequest handlerLandStatRequest = OnLandStatRequest;
+ if (handlerLandStatRequest != null)
{
- GroupRoleDataReplyPacket groupRolesReply = (GroupRoleDataReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupRoleDataReply);
-
- groupRolesReply.AgentData =
- new GroupRoleDataReplyPacket.AgentDataBlock();
-
- groupRolesReply.AgentData.AgentID = AgentId;
-
- groupRolesReply.GroupData =
- new GroupRoleDataReplyPacket.GroupDataBlock();
-
- groupRolesReply.GroupData.GroupID =
- groupRolesRequest.GroupData.GroupID;
-
- groupRolesReply.GroupData.RequestID =
- groupRolesRequest.GroupData.RequestID;
-
- List titles =
- m_GroupsModule.GroupRoleDataRequest(this,
- groupRolesRequest.GroupData.GroupID);
-
- groupRolesReply.GroupData.RoleCount =
- titles.Count;
-
- groupRolesReply.RoleData =
- new GroupRoleDataReplyPacket.RoleDataBlock[titles.Count];
-
- int i = 0;
- foreach (GroupRolesData d in titles)
- {
- groupRolesReply.RoleData[i] =
- new GroupRoleDataReplyPacket.RoleDataBlock();
+ handlerLandStatRequest(lsrp.RequestData.ParcelLocalID, lsrp.RequestData.ReportType, lsrp.RequestData.RequestFlags, Utils.BytesToString(lsrp.RequestData.Filter), this);
+ }
+ break;
- groupRolesReply.RoleData[i].RoleID =
- d.RoleID;
- groupRolesReply.RoleData[i].Name =
- Utils.StringToBytes(d.Name);
- groupRolesReply.RoleData[i].Title =
- Utils.StringToBytes(d.Title);
- groupRolesReply.RoleData[i].Description =
- Utils.StringToBytes(d.Description);
- groupRolesReply.RoleData[i].Powers =
- d.Powers;
- groupRolesReply.RoleData[i].Members =
- (uint)d.Members;
+ case PacketType.ParcelDwellRequest:
+ ParcelDwellRequestPacket dwellrq =
+ (ParcelDwellRequestPacket)Pack;
- i++;
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (dwellrq.AgentData.SessionID != SessionId ||
+ dwellrq.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- OutPacket(groupRolesReply, ThrottleOutPacketType.Task);
+ ParcelDwellRequest handlerParcelDwellRequest = OnParcelDwellRequest;
+ if (handlerParcelDwellRequest != null)
+ {
+ handlerParcelDwellRequest(dwellrq.Data.LocalID, this);
}
break;
- case PacketType.GroupRoleMembersRequest:
- GroupRoleMembersRequestPacket groupRoleMembersRequest =
- (GroupRoleMembersRequestPacket)Pack;
+ #endregion
+
+ #region Estate Packets
+
+ case PacketType.EstateOwnerMessage:
+ EstateOwnerMessagePacket messagePacket = (EstateOwnerMessagePacket)Pack;
+ //m_log.Debug(messagePacket.ToString());
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupRoleMembersRequest.AgentData.SessionID != SessionId ||
- groupRoleMembersRequest.AgentData.AgentID != AgentId)
+ if (messagePacket.AgentData.SessionID != SessionId ||
+ messagePacket.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ switch (Utils.BytesToString(messagePacket.MethodData.Method))
+ {
+ case "getinfo":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ OnDetailedEstateDataRequest(this, messagePacket.MethodData.Invoice);
+ }
+ break;
+ case "setregioninfo":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ OnSetEstateFlagsRequest(convertParamStringToBool(messagePacket.ParamList[0].Parameter), convertParamStringToBool(messagePacket.ParamList[1].Parameter),
+ convertParamStringToBool(messagePacket.ParamList[2].Parameter), !convertParamStringToBool(messagePacket.ParamList[3].Parameter),
+ Convert.ToInt16(Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[4].Parameter))),
+ (float)Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[5].Parameter)),
+ Convert.ToInt16(Utils.BytesToString(messagePacket.ParamList[6].Parameter)),
+ convertParamStringToBool(messagePacket.ParamList[7].Parameter), convertParamStringToBool(messagePacket.ParamList[8].Parameter));
+ }
+ break;
+// case "texturebase":
+// if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+// {
+// foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
+// {
+// string s = Utils.BytesToString(block.Parameter);
+// string[] splitField = s.Split(' ');
+// if (splitField.Length == 2)
+// {
+// UUID tempUUID = new UUID(splitField[1]);
+// OnSetEstateTerrainBaseTexture(this, Convert.ToInt16(splitField[0]), tempUUID);
+// }
+// }
+// }
+// break;
+ case "texturedetail":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
+ {
+ string s = Utils.BytesToString(block.Parameter);
+ string[] splitField = s.Split(' ');
+ if (splitField.Length == 2)
+ {
+ Int16 corner = Convert.ToInt16(splitField[0]);
+ UUID textureUUID = new UUID(splitField[1]);
+
+ OnSetEstateTerrainDetailTexture(this, corner, textureUUID);
+ }
+ }
+ }
+
break;
- }
- #endregion
+ case "textureheights":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
+ {
+ string s = Utils.BytesToString(block.Parameter);
+ string[] splitField = s.Split(' ');
+ if (splitField.Length == 3)
+ {
+ Int16 corner = Convert.ToInt16(splitField[0]);
+ float lowValue = (float)Convert.ToDecimal(splitField[1]);
+ float highValue = (float)Convert.ToDecimal(splitField[2]);
- if (m_GroupsModule != null)
- {
- List mappings =
- m_GroupsModule.GroupRoleMembersRequest(this,
- groupRoleMembersRequest.GroupData.GroupID);
+ OnSetEstateTerrainTextureHeights(this, corner, lowValue, highValue);
+ }
+ }
+ }
+ break;
+ case "texturecommit":
+ OnCommitEstateTerrainTextureRequest(this);
+ break;
+ case "setregionterrain":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ if (messagePacket.ParamList.Length != 9)
+ {
+ m_log.Error("EstateOwnerMessage: SetRegionTerrain method has a ParamList of invalid length");
+ }
+ else
+ {
+ try
+ {
+ string tmp = Utils.BytesToString(messagePacket.ParamList[0].Parameter);
+ if (!tmp.Contains(".")) tmp += ".00";
+ float WaterHeight = (float)Convert.ToDecimal(tmp);
+ tmp = Utils.BytesToString(messagePacket.ParamList[1].Parameter);
+ if (!tmp.Contains(".")) tmp += ".00";
+ float TerrainRaiseLimit = (float)Convert.ToDecimal(tmp);
+ tmp = Utils.BytesToString(messagePacket.ParamList[2].Parameter);
+ if (!tmp.Contains(".")) tmp += ".00";
+ float TerrainLowerLimit = (float)Convert.ToDecimal(tmp);
+ bool UseEstateSun = convertParamStringToBool(messagePacket.ParamList[3].Parameter);
+ bool UseFixedSun = convertParamStringToBool(messagePacket.ParamList[4].Parameter);
+ float SunHour = (float)Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[5].Parameter));
+ bool UseGlobal = convertParamStringToBool(messagePacket.ParamList[6].Parameter);
+ bool EstateFixedSun = convertParamStringToBool(messagePacket.ParamList[7].Parameter);
+ float EstateSunHour = (float)Convert.ToDecimal(Utils.BytesToString(messagePacket.ParamList[8].Parameter));
- int mappingsCount = mappings.Count;
+ OnSetRegionTerrainSettings(WaterHeight, TerrainRaiseLimit, TerrainLowerLimit, UseEstateSun, UseFixedSun, SunHour, UseGlobal, EstateFixedSun, EstateSunHour);
- while (mappings.Count > 0)
- {
- int pairs = mappings.Count;
- if (pairs > 32)
- pairs = 32;
+ }
+ catch (Exception ex)
+ {
+ m_log.Error("EstateOwnerMessage: Exception while setting terrain settings: \n" + messagePacket + "\n" + ex);
+ }
+ }
+ }
- GroupRoleMembersReplyPacket groupRoleMembersReply = (GroupRoleMembersReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupRoleMembersReply);
- groupRoleMembersReply.AgentData =
- new GroupRoleMembersReplyPacket.AgentDataBlock();
- groupRoleMembersReply.AgentData.AgentID =
- AgentId;
- groupRoleMembersReply.AgentData.GroupID =
- groupRoleMembersRequest.GroupData.GroupID;
- groupRoleMembersReply.AgentData.RequestID =
- groupRoleMembersRequest.GroupData.RequestID;
+ break;
+ case "restart":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ // There's only 1 block in the estateResetSim.. and that's the number of seconds till restart.
+ foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
+ {
+ float timeSeconds;
+ Utils.TryParseSingle(Utils.BytesToString(block.Parameter), out timeSeconds);
+ timeSeconds = (int)timeSeconds;
+ OnEstateRestartSimRequest(this, (int)timeSeconds);
- groupRoleMembersReply.AgentData.TotalPairs =
- (uint)mappingsCount;
+ }
+ }
+ break;
+ case "estatechangecovenantid":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ foreach (EstateOwnerMessagePacket.ParamListBlock block in messagePacket.ParamList)
+ {
+ UUID newCovenantID = new UUID(Utils.BytesToString(block.Parameter));
+ OnEstateChangeCovenantRequest(this, newCovenantID);
+ }
+ }
+ break;
+ case "estateaccessdelta": // Estate access delta manages the banlist and allow list too.
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ int estateAccessType = Convert.ToInt16(Utils.BytesToString(messagePacket.ParamList[1].Parameter));
+ OnUpdateEstateAccessDeltaRequest(this, messagePacket.MethodData.Invoice, estateAccessType, new UUID(Utils.BytesToString(messagePacket.ParamList[2].Parameter)));
- groupRoleMembersReply.MemberData =
- new GroupRoleMembersReplyPacket.MemberDataBlock[pairs];
+ }
+ break;
+ case "simulatormessage":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ UUID invoice = messagePacket.MethodData.Invoice;
+ UUID SenderID = new UUID(Utils.BytesToString(messagePacket.ParamList[2].Parameter));
+ string SenderName = Utils.BytesToString(messagePacket.ParamList[3].Parameter);
+ string Message = Utils.BytesToString(messagePacket.ParamList[4].Parameter);
+ UUID sessionID = messagePacket.AgentData.SessionID;
+ OnSimulatorBlueBoxMessageRequest(this, invoice, SenderID, sessionID, SenderName, Message);
+ }
+ break;
+ case "instantmessage":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ if (messagePacket.ParamList.Length < 5)
+ break;
+ UUID invoice = messagePacket.MethodData.Invoice;
+ UUID SenderID = new UUID(Utils.BytesToString(messagePacket.ParamList[2].Parameter));
+ string SenderName = Utils.BytesToString(messagePacket.ParamList[3].Parameter);
+ string Message = Utils.BytesToString(messagePacket.ParamList[4].Parameter);
+ UUID sessionID = messagePacket.AgentData.SessionID;
+ OnEstateBlueBoxMessageRequest(this, invoice, SenderID, sessionID, SenderName, Message);
+ }
+ break;
+ case "setregiondebug":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ UUID invoice = messagePacket.MethodData.Invoice;
+ UUID SenderID = messagePacket.AgentData.AgentID;
+ bool scripted = convertParamStringToBool(messagePacket.ParamList[0].Parameter);
+ bool collisionEvents = convertParamStringToBool(messagePacket.ParamList[1].Parameter);
+ bool physics = convertParamStringToBool(messagePacket.ParamList[2].Parameter);
- for (int i = 0 ; i < pairs ; i++)
+ OnEstateDebugRegionRequest(this, invoice, SenderID, scripted, collisionEvents, physics);
+ }
+ break;
+ case "teleporthomeuser":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
{
- GroupRoleMembersData d = mappings[0];
- mappings.RemoveAt(0);
+ UUID invoice = messagePacket.MethodData.Invoice;
+ UUID SenderID = messagePacket.AgentData.AgentID;
+ UUID Prey;
- groupRoleMembersReply.MemberData[i] =
- new GroupRoleMembersReplyPacket.MemberDataBlock();
+ UUID.TryParse(Utils.BytesToString(messagePacket.ParamList[1].Parameter), out Prey);
- groupRoleMembersReply.MemberData[i].RoleID =
- d.RoleID;
- groupRoleMembersReply.MemberData[i].MemberID =
- d.MemberID;
+ OnEstateTeleportOneUserHomeRequest(this, invoice, SenderID, Prey);
+ }
+ break;
+ case "teleporthomeallusers":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ UUID invoice = messagePacket.MethodData.Invoice;
+ UUID SenderID = messagePacket.AgentData.AgentID;
+ OnEstateTeleportAllUsersHomeRequest(this, invoice, SenderID);
+ }
+ break;
+ case "colliders":
+ handlerLandStatRequest = OnLandStatRequest;
+ if (handlerLandStatRequest != null)
+ {
+ handlerLandStatRequest(0, 1, 0, "", this);
+ }
+ break;
+ case "scripts":
+ handlerLandStatRequest = OnLandStatRequest;
+ if (handlerLandStatRequest != null)
+ {
+ handlerLandStatRequest(0, 0, 0, "", this);
}
+ break;
+ case "terrain":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ if (messagePacket.ParamList.Length > 0)
+ {
+ if (Utils.BytesToString(messagePacket.ParamList[0].Parameter) == "bake")
+ {
+ BakeTerrain handlerBakeTerrain = OnBakeTerrain;
+ if (handlerBakeTerrain != null)
+ {
+ handlerBakeTerrain(this);
+ }
+ }
+ if (Utils.BytesToString(messagePacket.ParamList[0].Parameter) == "download filename")
+ {
+ if (messagePacket.ParamList.Length > 1)
+ {
+ RequestTerrain handlerRequestTerrain = OnRequestTerrain;
+ if (handlerRequestTerrain != null)
+ {
+ handlerRequestTerrain(this, Utils.BytesToString(messagePacket.ParamList[1].Parameter));
+ }
+ }
+ }
+ if (Utils.BytesToString(messagePacket.ParamList[0].Parameter) == "upload filename")
+ {
+ if (messagePacket.ParamList.Length > 1)
+ {
+ RequestTerrain handlerUploadTerrain = OnUploadTerrain;
+ if (handlerUploadTerrain != null)
+ {
+ handlerUploadTerrain(this, Utils.BytesToString(messagePacket.ParamList[1].Parameter));
+ }
+ }
+ }
- OutPacket(groupRoleMembersReply, ThrottleOutPacketType.Task);
- }
- }
- break;
+ }
- case PacketType.CreateGroupRequest:
- CreateGroupRequestPacket createGroupRequest =
- (CreateGroupRequestPacket)Pack;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (createGroupRequest.AgentData.SessionID != SessionId ||
- createGroupRequest.AgentData.AgentID != AgentId)
+ }
break;
- }
- #endregion
- if (m_GroupsModule != null)
- {
- m_GroupsModule.CreateGroup(this,
- Utils.BytesToString(createGroupRequest.GroupData.Name),
- Utils.BytesToString(createGroupRequest.GroupData.Charter),
- createGroupRequest.GroupData.ShowInList,
- createGroupRequest.GroupData.InsigniaID,
- createGroupRequest.GroupData.MembershipFee,
- createGroupRequest.GroupData.OpenEnrollment,
- createGroupRequest.GroupData.AllowPublish,
- createGroupRequest.GroupData.MaturePublish);
- }
- break;
+ case "estatechangeinfo":
+ if (((Scene)m_scene).Permissions.CanIssueEstateCommand(AgentId, false))
+ {
+ UUID invoice = messagePacket.MethodData.Invoice;
+ UUID SenderID = messagePacket.AgentData.AgentID;
+ UInt32 param1 = Convert.ToUInt32(Utils.BytesToString(messagePacket.ParamList[1].Parameter));
+ UInt32 param2 = Convert.ToUInt32(Utils.BytesToString(messagePacket.ParamList[2].Parameter));
- case PacketType.UpdateGroupInfo:
- UpdateGroupInfoPacket updateGroupInfo =
- (UpdateGroupInfoPacket)Pack;
+ EstateChangeInfo handlerEstateChangeInfo = OnEstateChangeInfo;
+ if (handlerEstateChangeInfo != null)
+ {
+ handlerEstateChangeInfo(this, invoice, SenderID, param1, param2);
+ }
+ }
+ break;
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (updateGroupInfo.AgentData.SessionID != SessionId ||
- updateGroupInfo.AgentData.AgentID != AgentId)
+ default:
+ m_log.Error("EstateOwnerMessage: Unknown method requested\n" + messagePacket);
break;
}
- #endregion
+
+ //int parcelID, uint reportType, uint requestflags, string filter
- if (m_GroupsModule != null)
- {
- m_GroupsModule.UpdateGroupInfo(this,
- updateGroupInfo.GroupData.GroupID,
- Utils.BytesToString(updateGroupInfo.GroupData.Charter),
- updateGroupInfo.GroupData.ShowInList,
- updateGroupInfo.GroupData.InsigniaID,
- updateGroupInfo.GroupData.MembershipFee,
- updateGroupInfo.GroupData.OpenEnrollment,
- updateGroupInfo.GroupData.AllowPublish,
- updateGroupInfo.GroupData.MaturePublish);
- }
+ //lsrp.RequestData.ParcelLocalID;
+ //lsrp.RequestData.ReportType; // 1 = colliders, 0 = scripts
+ //lsrp.RequestData.RequestFlags;
+ //lsrp.RequestData.Filter;
break;
- case PacketType.SetGroupAcceptNotices:
- SetGroupAcceptNoticesPacket setGroupAcceptNotices =
- (SetGroupAcceptNoticesPacket)Pack;
+ case PacketType.RequestRegionInfo:
+ RequestRegionInfoPacket.AgentDataBlock mPacket = ((RequestRegionInfoPacket)Pack).AgentData;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (setGroupAcceptNotices.AgentData.SessionID != SessionId ||
- setGroupAcceptNotices.AgentData.AgentID != AgentId)
+ if (mPacket.SessionID != SessionId ||
+ mPacket.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ RegionInfoRequest handlerRegionInfoRequest = OnRegionInfoRequest;
+ if (handlerRegionInfoRequest != null)
{
- m_GroupsModule.SetGroupAcceptNotices(this,
- setGroupAcceptNotices.Data.GroupID,
- setGroupAcceptNotices.Data.AcceptNotices,
- setGroupAcceptNotices.NewData.ListInProfile);
+ handlerRegionInfoRequest(this);
}
-
break;
+ case PacketType.EstateCovenantRequest:
- case PacketType.GroupTitleUpdate:
- GroupTitleUpdatePacket groupTitleUpdate =
- (GroupTitleUpdatePacket)Pack;
+ //EstateCovenantRequestPacket.AgentDataBlock epack =
+ // ((EstateCovenantRequestPacket)Pack).AgentData;
- #region Packet Session and User Check
- if (m_checkPackets)
+ EstateCovenantRequest handlerEstateCovenantRequest = OnEstateCovenantRequest;
+ if (handlerEstateCovenantRequest != null)
{
- if (groupTitleUpdate.AgentData.SessionID != SessionId ||
- groupTitleUpdate.AgentData.AgentID != AgentId)
- break;
+ handlerEstateCovenantRequest(this);
}
+ break;
+
#endregion
- if (m_GroupsModule != null)
+ #region GodPackets
+
+ case PacketType.RequestGodlikePowers:
+ RequestGodlikePowersPacket rglpPack = (RequestGodlikePowersPacket)Pack;
+ RequestGodlikePowersPacket.RequestBlockBlock rblock = rglpPack.RequestBlock;
+ UUID token = rblock.Token;
+
+ RequestGodlikePowersPacket.AgentDataBlock ablock = rglpPack.AgentData;
+
+ RequestGodlikePowers handlerReqGodlikePowers = OnRequestGodlikePowers;
+
+ if (handlerReqGodlikePowers != null)
{
- m_GroupsModule.GroupTitleUpdate(this,
- groupTitleUpdate.AgentData.GroupID,
- groupTitleUpdate.AgentData.TitleRoleID);
+ handlerReqGodlikePowers(ablock.AgentID, ablock.SessionID, token, rblock.Godlike, this);
}
break;
+ case PacketType.GodKickUser:
+ GodKickUserPacket gkupack = (GodKickUserPacket)Pack;
-
- case PacketType.ParcelDeedToGroup:
- ParcelDeedToGroupPacket parcelDeedToGroup = (ParcelDeedToGroupPacket)Pack;
- if (m_GroupsModule != null)
+ if (gkupack.UserInfo.GodSessionID == SessionId && AgentId == gkupack.UserInfo.GodID)
{
- handlerParcelDeedToGroup = OnParcelDeedToGroup;
- if (handlerParcelDeedToGroup != null)
+ GodKickUser handlerGodKickUser = OnGodKickUser;
+ if (handlerGodKickUser != null)
{
- handlerParcelDeedToGroup(parcelDeedToGroup.Data.LocalID, parcelDeedToGroup.Data.GroupID,this);
-
+ handlerGodKickUser(gkupack.UserInfo.GodID, gkupack.UserInfo.GodSessionID,
+ gkupack.UserInfo.AgentID, (uint)0, gkupack.UserInfo.Reason);
}
}
+ else
+ {
+ SendAgentAlertMessage("Kick request denied", false);
+ }
+ //KickUserPacket kupack = new KickUserPacket();
+ //KickUserPacket.UserInfoBlock kupackib = kupack.UserInfo;
+
+ //kupack.UserInfo.AgentID = gkupack.UserInfo.AgentID;
+ //kupack.UserInfo.SessionID = gkupack.UserInfo.GodSessionID;
+
+ //kupack.TargetBlock.TargetIP = (uint)0;
+ //kupack.TargetBlock.TargetPort = (ushort)0;
+ //kupack.UserInfo.Reason = gkupack.UserInfo.Reason;
+ //OutPacket(kupack, ThrottleOutPacketType.Task);
break;
+ #endregion
+
+ #region Economy/Transaction Packets
- case PacketType.GroupNoticesListRequest:
- GroupNoticesListRequestPacket groupNoticesListRequest =
- (GroupNoticesListRequestPacket)Pack;
+ case PacketType.MoneyBalanceRequest:
+ MoneyBalanceRequestPacket moneybalancerequestpacket = (MoneyBalanceRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupNoticesListRequest.AgentData.SessionID != SessionId ||
- groupNoticesListRequest.AgentData.AgentID != AgentId)
+ if (moneybalancerequestpacket.AgentData.SessionID != SessionId ||
+ moneybalancerequestpacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
- {
- GroupNoticeData[] gn =
- m_GroupsModule.GroupNoticesListRequest(this,
- groupNoticesListRequest.Data.GroupID);
-
- GroupNoticesListReplyPacket groupNoticesListReply = (GroupNoticesListReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupNoticesListReply);
- groupNoticesListReply.AgentData =
- new GroupNoticesListReplyPacket.AgentDataBlock();
- groupNoticesListReply.AgentData.AgentID = AgentId;
- groupNoticesListReply.AgentData.GroupID = groupNoticesListRequest.Data.GroupID;
-
- groupNoticesListReply.Data = new GroupNoticesListReplyPacket.DataBlock[gn.Length];
-
- int i = 0;
- foreach (GroupNoticeData g in gn)
- {
- groupNoticesListReply.Data[i] = new GroupNoticesListReplyPacket.DataBlock();
- groupNoticesListReply.Data[i].NoticeID =
- g.NoticeID;
- groupNoticesListReply.Data[i].Timestamp =
- g.Timestamp;
- groupNoticesListReply.Data[i].FromName =
- Utils.StringToBytes(g.FromName);
- groupNoticesListReply.Data[i].Subject =
- Utils.StringToBytes(g.Subject);
- groupNoticesListReply.Data[i].HasAttachment =
- g.HasAttachment;
- groupNoticesListReply.Data[i].AssetType =
- g.AssetType;
- i++;
- }
+ MoneyBalanceRequest handlerMoneyBalanceRequest = OnMoneyBalanceRequest;
- OutPacket(groupNoticesListReply, ThrottleOutPacketType.Task);
+ if (handlerMoneyBalanceRequest != null)
+ {
+ handlerMoneyBalanceRequest(this, moneybalancerequestpacket.AgentData.AgentID, moneybalancerequestpacket.AgentData.SessionID, moneybalancerequestpacket.MoneyData.TransactionID);
}
break;
- case PacketType.GroupNoticeRequest:
- GroupNoticeRequestPacket groupNoticeRequest =
- (GroupNoticeRequestPacket)Pack;
+ case PacketType.EconomyDataRequest:
- #region Packet Session and User Check
- if (m_checkPackets)
+
+ EconomyDataRequest handlerEconomoyDataRequest = OnEconomyDataRequest;
+ if (handlerEconomoyDataRequest != null)
{
- if (groupNoticeRequest.AgentData.SessionID != SessionId ||
- groupNoticeRequest.AgentData.AgentID != AgentId)
- break;
+ handlerEconomoyDataRequest(AgentId);
}
- #endregion
+ break;
+ case PacketType.RequestPayPrice:
+ RequestPayPricePacket requestPayPricePacket = (RequestPayPricePacket)Pack;
- if (m_GroupsModule != null)
+ RequestPayPrice handlerRequestPayPrice = OnRequestPayPrice;
+ if (handlerRequestPayPrice != null)
{
- m_GroupsModule.GroupNoticeRequest(this,
- groupNoticeRequest.Data.GroupNoticeID);
+ handlerRequestPayPrice(this, requestPayPricePacket.ObjectData.ObjectID);
}
break;
- case PacketType.GroupRoleUpdate:
- GroupRoleUpdatePacket groupRoleUpdate =
- (GroupRoleUpdatePacket)Pack;
+ case PacketType.ObjectSaleInfo:
+ ObjectSaleInfoPacket objectSaleInfoPacket = (ObjectSaleInfoPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupRoleUpdate.AgentData.SessionID != SessionId ||
- groupRoleUpdate.AgentData.AgentID != AgentId)
+ if (objectSaleInfoPacket.AgentData.SessionID != SessionId ||
+ objectSaleInfoPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ ObjectSaleInfo handlerObjectSaleInfo = OnObjectSaleInfo;
+ if (handlerObjectSaleInfo != null)
{
- foreach (GroupRoleUpdatePacket.RoleDataBlock d in
- groupRoleUpdate.RoleData)
+ foreach (ObjectSaleInfoPacket.ObjectDataBlock d
+ in objectSaleInfoPacket.ObjectData)
{
- m_GroupsModule.GroupRoleUpdate(this,
- groupRoleUpdate.AgentData.GroupID,
- d.RoleID,
- Utils.BytesToString(d.Name),
- Utils.BytesToString(d.Description),
- Utils.BytesToString(d.Title),
- d.Powers,
- d.UpdateType);
+ handlerObjectSaleInfo(this,
+ objectSaleInfoPacket.AgentData.AgentID,
+ objectSaleInfoPacket.AgentData.SessionID,
+ d.LocalID,
+ d.SaleType,
+ d.SalePrice);
}
- m_GroupsModule.NotifyChange(groupRoleUpdate.AgentData.GroupID);
}
break;
- case PacketType.GroupRoleChanges:
- GroupRoleChangesPacket groupRoleChanges =
- (GroupRoleChangesPacket)Pack;
+ case PacketType.ObjectBuy:
+ ObjectBuyPacket objectBuyPacket = (ObjectBuyPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (groupRoleChanges.AgentData.SessionID != SessionId ||
- groupRoleChanges.AgentData.AgentID != AgentId)
+ if (objectBuyPacket.AgentData.SessionID != SessionId ||
+ objectBuyPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ ObjectBuy handlerObjectBuy = OnObjectBuy;
+
+ if (handlerObjectBuy != null)
{
- foreach (GroupRoleChangesPacket.RoleChangeBlock d in
- groupRoleChanges.RoleChange)
+ foreach (ObjectBuyPacket.ObjectDataBlock d
+ in objectBuyPacket.ObjectData)
{
- m_GroupsModule.GroupRoleChanges(this,
- groupRoleChanges.AgentData.GroupID,
- d.RoleID,
- d.MemberID,
- d.Change);
+ handlerObjectBuy(this,
+ objectBuyPacket.AgentData.AgentID,
+ objectBuyPacket.AgentData.SessionID,
+ objectBuyPacket.AgentData.GroupID,
+ objectBuyPacket.AgentData.CategoryID,
+ d.ObjectLocalID,
+ d.SaleType,
+ d.SalePrice);
}
- m_GroupsModule.NotifyChange(groupRoleChanges.AgentData.GroupID);
}
break;
- case PacketType.JoinGroupRequest:
- JoinGroupRequestPacket joinGroupRequest =
- (JoinGroupRequestPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (joinGroupRequest.AgentData.SessionID != SessionId ||
- joinGroupRequest.AgentData.AgentID != AgentId)
- break;
- }
#endregion
- if (m_GroupsModule != null)
+ #region Script Packets
+
+ case PacketType.GetScriptRunning:
+ GetScriptRunningPacket scriptRunning = (GetScriptRunningPacket)Pack;
+
+ GetScriptRunning handlerGetScriptRunning = OnGetScriptRunning;
+ if (handlerGetScriptRunning != null)
{
- m_GroupsModule.JoinGroupRequest(this,
- joinGroupRequest.GroupData.GroupID);
+ handlerGetScriptRunning(this, scriptRunning.Script.ObjectID, scriptRunning.Script.ItemID);
}
break;
- case PacketType.LeaveGroupRequest:
- LeaveGroupRequestPacket leaveGroupRequest =
- (LeaveGroupRequestPacket)Pack;
+ case PacketType.SetScriptRunning:
+ SetScriptRunningPacket setScriptRunning = (SetScriptRunningPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (leaveGroupRequest.AgentData.SessionID != SessionId ||
- leaveGroupRequest.AgentData.AgentID != AgentId)
+ if (setScriptRunning.AgentData.SessionID != SessionId ||
+ setScriptRunning.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ SetScriptRunning handlerSetScriptRunning = OnSetScriptRunning;
+ if (handlerSetScriptRunning != null)
{
- m_GroupsModule.LeaveGroupRequest(this,
- leaveGroupRequest.GroupData.GroupID);
+ handlerSetScriptRunning(this, setScriptRunning.Script.ObjectID, setScriptRunning.Script.ItemID, setScriptRunning.Script.Running);
}
break;
- case PacketType.EjectGroupMemberRequest:
- EjectGroupMemberRequestPacket ejectGroupMemberRequest =
- (EjectGroupMemberRequestPacket)Pack;
+ case PacketType.ScriptReset:
+ ScriptResetPacket scriptResetPacket = (ScriptResetPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (ejectGroupMemberRequest.AgentData.SessionID != SessionId ||
- ejectGroupMemberRequest.AgentData.AgentID != AgentId)
+ if (scriptResetPacket.AgentData.SessionID != SessionId ||
+ scriptResetPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ ScriptReset handlerScriptReset = OnScriptReset;
+ if (handlerScriptReset != null)
{
- foreach (EjectGroupMemberRequestPacket.EjectDataBlock e
- in ejectGroupMemberRequest.EjectData)
- {
- m_GroupsModule.EjectGroupMemberRequest(this,
- ejectGroupMemberRequest.GroupData.GroupID,
- e.EjecteeID);
- }
+ handlerScriptReset(this, scriptResetPacket.Script.ObjectID, scriptResetPacket.Script.ItemID);
}
break;
- case PacketType.InviteGroupRequest:
- InviteGroupRequestPacket inviteGroupRequest =
- (InviteGroupRequestPacket)Pack;
+ #endregion
+
+ #region Gesture Managment
+
+ case PacketType.ActivateGestures:
+ ActivateGesturesPacket activateGesturePacket = (ActivateGesturesPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (inviteGroupRequest.AgentData.SessionID != SessionId ||
- inviteGroupRequest.AgentData.AgentID != AgentId)
+ if (activateGesturePacket.AgentData.SessionID != SessionId ||
+ activateGesturePacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- if (m_GroupsModule != null)
+ ActivateGesture handlerActivateGesture = OnActivateGesture;
+ if (handlerActivateGesture != null)
{
- foreach (InviteGroupRequestPacket.InviteDataBlock b in
- inviteGroupRequest.InviteData)
- {
- m_GroupsModule.InviteGroupRequest(this,
- inviteGroupRequest.GroupData.GroupID,
- b.InviteeID,
- b.RoleID);
- }
+ handlerActivateGesture(this,
+ activateGesturePacket.Data[0].AssetID,
+ activateGesturePacket.Data[0].ItemID);
}
+ else m_log.Error("Null pointer for activateGesture");
+
break;
- #endregion
- case PacketType.StartLure:
- StartLurePacket startLureRequest = (StartLurePacket)Pack;
+ case PacketType.DeactivateGestures:
+ DeactivateGesturesPacket deactivateGesturePacket = (DeactivateGesturesPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (startLureRequest.AgentData.SessionID != SessionId ||
- startLureRequest.AgentData.AgentID != AgentId)
+ if (deactivateGesturePacket.AgentData.SessionID != SessionId ||
+ deactivateGesturePacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerStartLure = OnStartLure;
- if (handlerStartLure != null)
- handlerStartLure(startLureRequest.Info.LureType,
- Utils.BytesToString(
- startLureRequest.Info.Message),
- startLureRequest.TargetData[0].TargetID,
- this);
- break;
-
- case PacketType.TeleportLureRequest:
- TeleportLureRequestPacket teleportLureRequest =
- (TeleportLureRequestPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
+ DeactivateGesture handlerDeactivateGesture = OnDeactivateGesture;
+ if (handlerDeactivateGesture != null)
{
- if (teleportLureRequest.Info.SessionID != SessionId ||
- teleportLureRequest.Info.AgentID != AgentId)
- break;
+ handlerDeactivateGesture(this, deactivateGesturePacket.Data[0].ItemID);
}
- #endregion
-
- handlerTeleportLureRequest = OnTeleportLureRequest;
- if (handlerTeleportLureRequest != null)
- handlerTeleportLureRequest(
- teleportLureRequest.Info.LureID,
- teleportLureRequest.Info.TeleportFlags,
- this);
break;
-
- case PacketType.ClassifiedInfoRequest:
- ClassifiedInfoRequestPacket classifiedInfoRequest =
- (ClassifiedInfoRequestPacket)Pack;
+ case PacketType.ObjectOwner:
+ ObjectOwnerPacket objectOwnerPacket = (ObjectOwnerPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (classifiedInfoRequest.AgentData.SessionID != SessionId ||
- classifiedInfoRequest.AgentData.AgentID != AgentId)
+ if (objectOwnerPacket.AgentData.SessionID != SessionId ||
+ objectOwnerPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerClassifiedInfoRequest = OnClassifiedInfoRequest;
- if (handlerClassifiedInfoRequest != null)
- handlerClassifiedInfoRequest(
- classifiedInfoRequest.Data.ClassifiedID,
- this);
- break;
+ List localIDs = new List();
- case PacketType.ClassifiedInfoUpdate:
- ClassifiedInfoUpdatePacket classifiedInfoUpdate =
- (ClassifiedInfoUpdatePacket)Pack;
+ foreach (ObjectOwnerPacket.ObjectDataBlock d in objectOwnerPacket.ObjectData)
+ localIDs.Add(d.ObjectLocalID);
- #region Packet Session and User Check
- if (m_checkPackets)
+ ObjectOwner handlerObjectOwner = OnObjectOwner;
+ if (handlerObjectOwner != null)
{
- if (classifiedInfoUpdate.AgentData.SessionID != SessionId ||
- classifiedInfoUpdate.AgentData.AgentID != AgentId)
- break;
+ handlerObjectOwner(this, objectOwnerPacket.HeaderData.OwnerID, objectOwnerPacket.HeaderData.GroupID, localIDs);
}
+ break;
+
#endregion
- handlerClassifiedInfoUpdate = OnClassifiedInfoUpdate;
- if (handlerClassifiedInfoUpdate != null)
- handlerClassifiedInfoUpdate(
- classifiedInfoUpdate.Data.ClassifiedID,
- classifiedInfoUpdate.Data.Category,
- Utils.BytesToString(
- classifiedInfoUpdate.Data.Name),
- Utils.BytesToString(
- classifiedInfoUpdate.Data.Desc),
- classifiedInfoUpdate.Data.ParcelID,
- classifiedInfoUpdate.Data.ParentEstate,
- classifiedInfoUpdate.Data.SnapshotID,
- new Vector3(
- classifiedInfoUpdate.Data.PosGlobal),
- classifiedInfoUpdate.Data.ClassifiedFlags,
- classifiedInfoUpdate.Data.PriceForListing,
- this);
- break;
- case PacketType.ClassifiedDelete:
- ClassifiedDeletePacket classifiedDelete =
- (ClassifiedDeletePacket)Pack;
+ #region unimplemented handlers
- #region Packet Session and User Check
- if (m_checkPackets)
- {
- if (classifiedDelete.AgentData.SessionID != SessionId ||
- classifiedDelete.AgentData.AgentID != AgentId)
- break;
- }
- #endregion
+ case PacketType.StartPingCheck:
+ // Send the client the ping response back
+ // Pass the same PingID in the matching packet
+ // Handled In the packet processing
+ //m_log.Debug("[CLIENT]: possibly unhandled StartPingCheck packet");
+ break;
+ case PacketType.CompletePingCheck:
+ // TODO: Perhaps this should be processed on the Sim to determine whether or not to drop a dead client
+ //m_log.Warn("[CLIENT]: unhandled CompletePingCheck packet");
+ break;
- handlerClassifiedDelete = OnClassifiedDelete;
- if (handlerClassifiedDelete != null)
- handlerClassifiedDelete(
- classifiedDelete.Data.ClassifiedID,
- this);
+ case PacketType.ViewerStats:
+ // TODO: handle this packet
+ //m_log.Warn("[CLIENT]: unhandled ViewerStats packet");
break;
- case PacketType.ClassifiedGodDelete:
- ClassifiedGodDeletePacket classifiedGodDelete =
- (ClassifiedGodDeletePacket)Pack;
+ case PacketType.MapItemRequest:
+ MapItemRequestPacket mirpk = (MapItemRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (classifiedGodDelete.AgentData.SessionID != SessionId ||
- classifiedGodDelete.AgentData.AgentID != AgentId)
+ if (mirpk.AgentData.SessionID != SessionId ||
+ mirpk.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerClassifiedGodDelete = OnClassifiedGodDelete;
- if (handlerClassifiedGodDelete != null)
- handlerClassifiedGodDelete(
- classifiedGodDelete.Data.ClassifiedID,
- this);
+ //m_log.Debug(mirpk.ToString());
+ MapItemRequest handlerMapItemRequest = OnMapItemRequest;
+ if (handlerMapItemRequest != null)
+ {
+ handlerMapItemRequest(this,mirpk.AgentData.Flags, mirpk.AgentData.EstateID,
+ mirpk.AgentData.Godlike,mirpk.RequestData.ItemType,
+ mirpk.RequestData.RegionHandle);
+
+ }
break;
- case PacketType.EventGodDelete:
- EventGodDeletePacket eventGodDelete =
- (EventGodDeletePacket)Pack;
+ case PacketType.TransferAbort:
+ // TODO: handle this packet
+ //m_log.Warn("[CLIENT]: unhandled TransferAbort packet");
+ break;
+ case PacketType.MuteListRequest:
+ MuteListRequestPacket muteListRequest =
+ (MuteListRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (eventGodDelete.AgentData.SessionID != SessionId ||
- eventGodDelete.AgentData.AgentID != AgentId)
+ if (muteListRequest.AgentData.SessionID != SessionId ||
+ muteListRequest.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerEventGodDelete = OnEventGodDelete;
- if (handlerEventGodDelete != null)
- handlerEventGodDelete(
- eventGodDelete.EventData.EventID,
- eventGodDelete.QueryData.QueryID,
- Utils.BytesToString(
- eventGodDelete.QueryData.QueryText),
- eventGodDelete.QueryData.QueryFlags,
- eventGodDelete.QueryData.QueryStart,
- this);
- break;
-
- case PacketType.EventNotificationAddRequest:
- EventNotificationAddRequestPacket eventNotificationAdd =
- (EventNotificationAddRequestPacket)Pack;
-
- #region Packet Session and User Check
- if (m_checkPackets)
+ MuteListRequest handlerMuteListRequest = OnMuteListRequest;
+ if (handlerMuteListRequest != null)
{
- if (eventNotificationAdd.AgentData.SessionID != SessionId ||
- eventNotificationAdd.AgentData.AgentID != AgentId)
- break;
+ handlerMuteListRequest(this, muteListRequest.MuteData.MuteCRC);
}
- #endregion
+ else
+ {
+ SendUseCachedMuteList();
+ }
+ break;
+ case PacketType.UseCircuitCode:
+ // Don't display this one, we handle it at a lower level
+ break;
- handlerEventNotificationAddRequest = OnEventNotificationAddRequest;
- if (handlerEventNotificationAddRequest != null)
- handlerEventNotificationAddRequest(
- eventNotificationAdd.EventData.EventID, this);
+ case PacketType.AgentHeightWidth:
+ // TODO: handle this packet
+ //m_log.Warn("[CLIENT]: unhandled AgentHeightWidth packet");
break;
- case PacketType.EventNotificationRemoveRequest:
- EventNotificationRemoveRequestPacket eventNotificationRemove =
- (EventNotificationRemoveRequestPacket)Pack;
+ case PacketType.InventoryDescendents:
+ // TODO: handle this packet
+ //m_log.Warn("[CLIENT]: unhandled InventoryDescent packet");
+
+ break;
+ case PacketType.DirPlacesQuery:
+ DirPlacesQueryPacket dirPlacesQueryPacket = (DirPlacesQueryPacket)Pack;
+ //m_log.Debug(dirPlacesQueryPacket.ToString());
#region Packet Session and User Check
if (m_checkPackets)
{
- if (eventNotificationRemove.AgentData.SessionID != SessionId ||
- eventNotificationRemove.AgentData.AgentID != AgentId)
+ if (dirPlacesQueryPacket.AgentData.SessionID != SessionId ||
+ dirPlacesQueryPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerEventNotificationRemoveRequest = OnEventNotificationRemoveRequest;
- if (handlerEventNotificationRemoveRequest != null)
- handlerEventNotificationRemoveRequest(
- eventNotificationRemove.EventData.EventID, this);
+ DirPlacesQuery handlerDirPlacesQuery = OnDirPlacesQuery;
+ if (handlerDirPlacesQuery != null)
+ {
+ handlerDirPlacesQuery(this,
+ dirPlacesQueryPacket.QueryData.QueryID,
+ Utils.BytesToString(
+ dirPlacesQueryPacket.QueryData.QueryText),
+ (int)dirPlacesQueryPacket.QueryData.QueryFlags,
+ (int)dirPlacesQueryPacket.QueryData.Category,
+ Utils.BytesToString(
+ dirPlacesQueryPacket.QueryData.SimName),
+ dirPlacesQueryPacket.QueryData.QueryStart);
+ }
break;
-
- case PacketType.RetrieveInstantMessages:
- RetrieveInstantMessagesPacket rimpInstantMessagePack = (RetrieveInstantMessagesPacket)Pack;
+ case PacketType.DirFindQuery:
+ DirFindQueryPacket dirFindQueryPacket = (DirFindQueryPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (rimpInstantMessagePack.AgentData.SessionID != SessionId ||
- rimpInstantMessagePack.AgentData.AgentID != AgentId)
+ if (dirFindQueryPacket.AgentData.SessionID != SessionId ||
+ dirFindQueryPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerRetrieveInstantMessages = OnRetrieveInstantMessages;
- if (handlerRetrieveInstantMessages != null)
- handlerRetrieveInstantMessages(this);
+ DirFindQuery handlerDirFindQuery = OnDirFindQuery;
+ if (handlerDirFindQuery != null)
+ {
+ handlerDirFindQuery(this,
+ dirFindQueryPacket.QueryData.QueryID,
+ Utils.BytesToString(
+ dirFindQueryPacket.QueryData.QueryText),
+ dirFindQueryPacket.QueryData.QueryFlags,
+ dirFindQueryPacket.QueryData.QueryStart);
+ }
break;
-
- case PacketType.PickDelete:
- PickDeletePacket pickDelete =
- (PickDeletePacket)Pack;
+ case PacketType.DirLandQuery:
+ DirLandQueryPacket dirLandQueryPacket = (DirLandQueryPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (pickDelete.AgentData.SessionID != SessionId ||
- pickDelete.AgentData.AgentID != AgentId)
+ if (dirLandQueryPacket.AgentData.SessionID != SessionId ||
+ dirLandQueryPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerPickDelete = OnPickDelete;
- if (handlerPickDelete != null)
- handlerPickDelete(this, pickDelete.Data.PickID);
+ DirLandQuery handlerDirLandQuery = OnDirLandQuery;
+ if (handlerDirLandQuery != null)
+ {
+ handlerDirLandQuery(this,
+ dirLandQueryPacket.QueryData.QueryID,
+ dirLandQueryPacket.QueryData.QueryFlags,
+ dirLandQueryPacket.QueryData.SearchType,
+ dirLandQueryPacket.QueryData.Price,
+ dirLandQueryPacket.QueryData.Area,
+ dirLandQueryPacket.QueryData.QueryStart);
+ }
break;
- case PacketType.PickGodDelete:
- PickGodDeletePacket pickGodDelete =
- (PickGodDeletePacket)Pack;
+ case PacketType.DirPopularQuery:
+ DirPopularQueryPacket dirPopularQueryPacket = (DirPopularQueryPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (pickGodDelete.AgentData.SessionID != SessionId ||
- pickGodDelete.AgentData.AgentID != AgentId)
+ if (dirPopularQueryPacket.AgentData.SessionID != SessionId ||
+ dirPopularQueryPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerPickGodDelete = OnPickGodDelete;
- if (handlerPickGodDelete != null)
- handlerPickGodDelete(this,
- pickGodDelete.AgentData.AgentID,
- pickGodDelete.Data.PickID,
- pickGodDelete.Data.QueryID);
+ DirPopularQuery handlerDirPopularQuery = OnDirPopularQuery;
+ if (handlerDirPopularQuery != null)
+ {
+ handlerDirPopularQuery(this,
+ dirPopularQueryPacket.QueryData.QueryID,
+ dirPopularQueryPacket.QueryData.QueryFlags);
+ }
break;
- case PacketType.PickInfoUpdate:
- PickInfoUpdatePacket pickInfoUpdate =
- (PickInfoUpdatePacket)Pack;
+ case PacketType.DirClassifiedQuery:
+ DirClassifiedQueryPacket dirClassifiedQueryPacket = (DirClassifiedQueryPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (pickInfoUpdate.AgentData.SessionID != SessionId ||
- pickInfoUpdate.AgentData.AgentID != AgentId)
+ if (dirClassifiedQueryPacket.AgentData.SessionID != SessionId ||
+ dirClassifiedQueryPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerPickInfoUpdate = OnPickInfoUpdate;
- if (handlerPickInfoUpdate != null)
- handlerPickInfoUpdate(this,
- pickInfoUpdate.Data.PickID,
- pickInfoUpdate.Data.CreatorID,
- pickInfoUpdate.Data.TopPick,
- Utils.BytesToString(pickInfoUpdate.Data.Name),
- Utils.BytesToString(pickInfoUpdate.Data.Desc),
- pickInfoUpdate.Data.SnapshotID,
- pickInfoUpdate.Data.SortOrder,
- pickInfoUpdate.Data.Enabled);
+ DirClassifiedQuery handlerDirClassifiedQuery = OnDirClassifiedQuery;
+ if (handlerDirClassifiedQuery != null)
+ {
+ handlerDirClassifiedQuery(this,
+ dirClassifiedQueryPacket.QueryData.QueryID,
+ Utils.BytesToString(
+ dirClassifiedQueryPacket.QueryData.QueryText),
+ dirClassifiedQueryPacket.QueryData.QueryFlags,
+ dirClassifiedQueryPacket.QueryData.Category,
+ dirClassifiedQueryPacket.QueryData.QueryStart);
+ }
break;
- case PacketType.AvatarNotesUpdate:
- AvatarNotesUpdatePacket avatarNotesUpdate =
- (AvatarNotesUpdatePacket)Pack;
+ case PacketType.EventInfoRequest:
+ EventInfoRequestPacket eventInfoRequestPacket = (EventInfoRequestPacket)Pack;
#region Packet Session and User Check
if (m_checkPackets)
{
- if (avatarNotesUpdate.AgentData.SessionID != SessionId ||
- avatarNotesUpdate.AgentData.AgentID != AgentId)
+ if (eventInfoRequestPacket.AgentData.SessionID != SessionId ||
+ eventInfoRequestPacket.AgentData.AgentID != AgentId)
break;
}
#endregion
- handlerAvatarNotesUpdate = OnAvatarNotesUpdate;
- if (handlerAvatarNotesUpdate != null)
- handlerAvatarNotesUpdate(this,
- avatarNotesUpdate.Data.TargetID,
- Utils.BytesToString(avatarNotesUpdate.Data.Notes));
- break;
-
-// case PacketType.AvatarInterestsUpdate:
-// AvatarInterestsUpdatePacket avatarInterestUpdate =
-// (AvatarInterestsUpdatePacket)Pack;
-//
-// break;
-
- case PacketType.PlacesQuery:
- PlacesQueryPacket placesQueryPacket =
- (PlacesQueryPacket)Pack;
-
- handlerPlacesQuery = OnPlacesQuery;
-
- if (handlerPlacesQuery != null)
- handlerPlacesQuery(placesQueryPacket.AgentData.QueryID,
- placesQueryPacket.TransactionData.TransactionID,
- Utils.BytesToString(
- placesQueryPacket.QueryData.QueryText),
- placesQueryPacket.QueryData.QueryFlags,
- (byte)placesQueryPacket.QueryData.Category,
- Utils.BytesToString(
- placesQueryPacket.QueryData.SimName),
- this);
- break;
- default:
- m_log.Warn("[CLIENT]: unhandled packet " + Pack);
+ if (OnEventInfoRequest != null)
+ {
+ OnEventInfoRequest(this, eventInfoRequestPacket.EventData.EventID);
+ }
break;
- #endregion
- }
-
- PacketPool.Instance.ReturnPacket(Pack);
-
- }
-
- private static PrimitiveBaseShape GetShapeFromAddPacket(ObjectAddPacket addPacket)
- {
- PrimitiveBaseShape shape = new PrimitiveBaseShape();
-
- shape.PCode = addPacket.ObjectData.PCode;
- shape.State = addPacket.ObjectData.State;
- shape.PathBegin = addPacket.ObjectData.PathBegin;
- shape.PathEnd = addPacket.ObjectData.PathEnd;
- shape.PathScaleX = addPacket.ObjectData.PathScaleX;
- shape.PathScaleY = addPacket.ObjectData.PathScaleY;
- shape.PathShearX = addPacket.ObjectData.PathShearX;
- shape.PathShearY = addPacket.ObjectData.PathShearY;
- shape.PathSkew = addPacket.ObjectData.PathSkew;
- shape.ProfileBegin = addPacket.ObjectData.ProfileBegin;
- shape.ProfileEnd = addPacket.ObjectData.ProfileEnd;
- shape.Scale = addPacket.ObjectData.Scale;
- shape.PathCurve = addPacket.ObjectData.PathCurve;
- shape.ProfileCurve = addPacket.ObjectData.ProfileCurve;
- shape.ProfileHollow = addPacket.ObjectData.ProfileHollow;
- shape.PathRadiusOffset = addPacket.ObjectData.PathRadiusOffset;
- shape.PathRevolutions = addPacket.ObjectData.PathRevolutions;
- shape.PathTaperX = addPacket.ObjectData.PathTaperX;
- shape.PathTaperY = addPacket.ObjectData.PathTaperY;
- shape.PathTwist = addPacket.ObjectData.PathTwist;
- shape.PathTwistBegin = addPacket.ObjectData.PathTwistBegin;
- Primitive.TextureEntry ntex = new Primitive.TextureEntry(new UUID("89556747-24cb-43ed-920b-47caed15465f"));
- shape.TextureEntry = ntex.GetBytes();
- //shape.Textures = ntex;
- return shape;
- }
-
- ///
- /// Send the client an Estate message blue box pop-down with a single OK button
- ///
- ///
- ///
- ///
- ///
- public void SendBlueBoxMessage(UUID FromAvatarID, String FromAvatarName, String Message)
- {
- if (!ChildAgentStatus())
- SendInstantMessage(new GridInstantMessage(null, FromAvatarID, FromAvatarName, AgentId, 1, Message, false, new Vector3()));
-
- //SendInstantMessage(FromAvatarID, fromSessionID, Message, AgentId, SessionId, FromAvatarName, (byte)21,(uint) Util.UnixTimeSinceEpoch());
- }
-
- public void SendLogoutPacket()
- {
- // I know this is a bit of a hack, however there are times when you don't
- // want to send this, but still need to do the rest of the shutdown process
- // this method gets called from the packet server.. which makes it practically
- // impossible to do any other way.
-
- if (m_SendLogoutPacketWhenClosing)
- {
- LogoutReplyPacket logReply = (LogoutReplyPacket)PacketPool.Instance.GetPacket(PacketType.LogoutReply);
- // TODO: don't create new blocks if recycling an old packet
- logReply.AgentData.AgentID = AgentId;
- logReply.AgentData.SessionID = SessionId;
- logReply.InventoryData = new LogoutReplyPacket.InventoryDataBlock[1];
- logReply.InventoryData[0] = new LogoutReplyPacket.InventoryDataBlock();
- logReply.InventoryData[0].ItemID = UUID.Zero;
-
- OutPacket(logReply, ThrottleOutPacketType.Task);
- }
- }
+ #region Calling Card
- public void SendHealth(float health)
- {
- HealthMessagePacket healthpacket = (HealthMessagePacket)PacketPool.Instance.GetPacket(PacketType.HealthMessage);
- healthpacket.HealthData.Health = health;
- OutPacket(healthpacket, ThrottleOutPacketType.Task);
- }
+ case PacketType.OfferCallingCard:
+ OfferCallingCardPacket offerCallingCardPacket = (OfferCallingCardPacket)Pack;
- public void SendAgentOnline(UUID[] agentIDs)
- {
- OnlineNotificationPacket onp = new OnlineNotificationPacket();
- OnlineNotificationPacket.AgentBlockBlock[] onpb = new OnlineNotificationPacket.AgentBlockBlock[agentIDs.Length];
- for (int i = 0; i < agentIDs.Length; i++)
- {
- OnlineNotificationPacket.AgentBlockBlock onpbl = new OnlineNotificationPacket.AgentBlockBlock();
- onpbl.AgentID = agentIDs[i];
- onpb[i] = onpbl;
- }
- onp.AgentBlock = onpb;
- onp.Header.Reliable = true;
- OutPacket(onp, ThrottleOutPacketType.Task);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (offerCallingCardPacket.AgentData.SessionID != SessionId ||
+ offerCallingCardPacket.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendAgentOffline(UUID[] agentIDs)
- {
- OfflineNotificationPacket offp = new OfflineNotificationPacket();
- OfflineNotificationPacket.AgentBlockBlock[] offpb = new OfflineNotificationPacket.AgentBlockBlock[agentIDs.Length];
- for (int i = 0; i < agentIDs.Length; i++)
- {
- OfflineNotificationPacket.AgentBlockBlock onpbl = new OfflineNotificationPacket.AgentBlockBlock();
- onpbl.AgentID = agentIDs[i];
- offpb[i] = onpbl;
- }
- offp.AgentBlock = offpb;
- offp.Header.Reliable = true;
- OutPacket(offp, ThrottleOutPacketType.Task);
- }
+ if (OnOfferCallingCard != null)
+ {
+ OnOfferCallingCard(this,
+ offerCallingCardPacket.AgentBlock.DestID,
+ offerCallingCardPacket.AgentBlock.TransactionID);
+ }
+ break;
- public void SendSitResponse(UUID TargetID, Vector3 OffsetPos, Quaternion SitOrientation, bool autopilot,
- Vector3 CameraAtOffset, Vector3 CameraEyeOffset, bool ForceMouseLook)
- {
- AvatarSitResponsePacket avatarSitResponse = new AvatarSitResponsePacket();
- avatarSitResponse.SitObject.ID = TargetID;
- if (CameraAtOffset != Vector3.Zero)
- {
- avatarSitResponse.SitTransform.CameraAtOffset = CameraAtOffset;
- avatarSitResponse.SitTransform.CameraEyeOffset = CameraEyeOffset;
- }
- avatarSitResponse.SitTransform.ForceMouselook = ForceMouseLook;
- avatarSitResponse.SitTransform.AutoPilot = autopilot;
- avatarSitResponse.SitTransform.SitPosition = OffsetPos;
- avatarSitResponse.SitTransform.SitRotation = SitOrientation;
+ case PacketType.AcceptCallingCard:
+ AcceptCallingCardPacket acceptCallingCardPacket = (AcceptCallingCardPacket)Pack;
- OutPacket(avatarSitResponse, ThrottleOutPacketType.Task);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (acceptCallingCardPacket.AgentData.SessionID != SessionId ||
+ acceptCallingCardPacket.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendAdminResponse(UUID Token, uint AdminLevel)
- {
- GrantGodlikePowersPacket respondPacket = new GrantGodlikePowersPacket();
- GrantGodlikePowersPacket.GrantDataBlock gdb = new GrantGodlikePowersPacket.GrantDataBlock();
- GrantGodlikePowersPacket.AgentDataBlock adb = new GrantGodlikePowersPacket.AgentDataBlock();
+ // according to http://wiki.secondlife.com/wiki/AcceptCallingCard FolderData should
+ // contain exactly one entry
+ if (OnAcceptCallingCard != null && acceptCallingCardPacket.FolderData.Length > 0)
+ {
+ OnAcceptCallingCard(this,
+ acceptCallingCardPacket.TransactionBlock.TransactionID,
+ acceptCallingCardPacket.FolderData[0].FolderID);
+ }
+ break;
- adb.AgentID = AgentId;
- adb.SessionID = SessionId; // More security
- gdb.GodLevel = (byte)AdminLevel;
- gdb.Token = Token;
- //respondPacket.AgentData = (GrantGodlikePowersPacket.AgentDataBlock)ablock;
- respondPacket.GrantData = gdb;
- respondPacket.AgentData = adb;
- OutPacket(respondPacket, ThrottleOutPacketType.Task);
- }
+ case PacketType.DeclineCallingCard:
+ DeclineCallingCardPacket declineCallingCardPacket = (DeclineCallingCardPacket)Pack;
- public void SendGroupMembership(GroupMembershipData[] GroupMembership)
- {
- m_groupPowers.Clear();
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (declineCallingCardPacket.AgentData.SessionID != SessionId ||
+ declineCallingCardPacket.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- AgentGroupDataUpdatePacket Groupupdate = new AgentGroupDataUpdatePacket();
- AgentGroupDataUpdatePacket.GroupDataBlock[] Groups = new AgentGroupDataUpdatePacket.GroupDataBlock[GroupMembership.Length];
- for (int i = 0; i < GroupMembership.Length; i++)
- {
- m_groupPowers[GroupMembership[i].GroupID] = GroupMembership[i].GroupPowers;
+ if (OnDeclineCallingCard != null)
+ {
+ OnDeclineCallingCard(this,
+ declineCallingCardPacket.TransactionBlock.TransactionID);
+ }
+ break;
+ #endregion
- AgentGroupDataUpdatePacket.GroupDataBlock Group = new AgentGroupDataUpdatePacket.GroupDataBlock();
- Group.AcceptNotices = GroupMembership[i].AcceptNotices;
- Group.Contribution = GroupMembership[i].Contribution;
- Group.GroupID = GroupMembership[i].GroupID;
- Group.GroupInsigniaID = GroupMembership[i].GroupPicture;
- Group.GroupName = Utils.StringToBytes(GroupMembership[i].GroupName);
- Group.GroupPowers = GroupMembership[i].GroupPowers;
- Groups[i] = Group;
-
+ #region Groups
+ case PacketType.ActivateGroup:
+ ActivateGroupPacket activateGroupPacket = (ActivateGroupPacket)Pack;
- }
- Groupupdate.GroupData = Groups;
- Groupupdate.AgentData = new AgentGroupDataUpdatePacket.AgentDataBlock();
- Groupupdate.AgentData.AgentID = AgentId;
- OutPacket(Groupupdate, ThrottleOutPacketType.Task);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (activateGroupPacket.AgentData.SessionID != SessionId ||
+ activateGroupPacket.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- try
- {
- IEventQueue eq = Scene.RequestModuleInterface();
- if (eq != null)
- {
- eq.GroupMembership(Groupupdate, this.AgentId);
- }
- }
- catch (Exception ex)
- {
- m_log.Error("Unable to send group membership data via eventqueue - exception: " + ex.ToString());
- m_log.Warn("sending group membership data via UDP");
- OutPacket(Groupupdate, ThrottleOutPacketType.Task);
- }
- }
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.ActivateGroup(this, activateGroupPacket.AgentData.GroupID);
+ m_GroupsModule.SendAgentGroupDataUpdate(this);
+ }
+ break;
+ case PacketType.GroupTitlesRequest:
+ GroupTitlesRequestPacket groupTitlesRequest =
+ (GroupTitlesRequestPacket)Pack;
- public void SendGroupNameReply(UUID groupLLUID, string GroupName)
- {
- UUIDGroupNameReplyPacket pack = new UUIDGroupNameReplyPacket();
- UUIDGroupNameReplyPacket.UUIDNameBlockBlock[] uidnameblock = new UUIDGroupNameReplyPacket.UUIDNameBlockBlock[1];
- UUIDGroupNameReplyPacket.UUIDNameBlockBlock uidnamebloc = new UUIDGroupNameReplyPacket.UUIDNameBlockBlock();
- uidnamebloc.ID = groupLLUID;
- uidnamebloc.GroupName = Utils.StringToBytes(GroupName);
- uidnameblock[0] = uidnamebloc;
- pack.UUIDNameBlock = uidnameblock;
- OutPacket(pack, ThrottleOutPacketType.Task);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupTitlesRequest.AgentData.SessionID != SessionId ||
+ groupTitlesRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendLandStatReply(uint reportType, uint requestFlags, uint resultCount, LandStatReportItem[] lsrpia)
- {
- LandStatReplyPacket lsrp = new LandStatReplyPacket();
- // LandStatReplyPacket.RequestDataBlock lsreqdpb = new LandStatReplyPacket.RequestDataBlock();
- LandStatReplyPacket.ReportDataBlock[] lsrepdba = new LandStatReplyPacket.ReportDataBlock[lsrpia.Length];
- //LandStatReplyPacket.ReportDataBlock lsrepdb = new LandStatReplyPacket.ReportDataBlock();
- // lsrepdb.
- lsrp.RequestData.ReportType = reportType;
- lsrp.RequestData.RequestFlags = requestFlags;
- lsrp.RequestData.TotalObjectCount = resultCount;
- for (int i = 0; i < lsrpia.Length; i++)
- {
- LandStatReplyPacket.ReportDataBlock lsrepdb = new LandStatReplyPacket.ReportDataBlock();
- lsrepdb.LocationX = lsrpia[i].LocationX;
- lsrepdb.LocationY = lsrpia[i].LocationY;
- lsrepdb.LocationZ = lsrpia[i].LocationZ;
- lsrepdb.Score = lsrpia[i].Score;
- lsrepdb.TaskID = lsrpia[i].TaskID;
- lsrepdb.TaskLocalID = lsrpia[i].TaskLocalID;
- lsrepdb.TaskName = Utils.StringToBytes(lsrpia[i].TaskName);
- lsrepdb.OwnerName = Utils.StringToBytes(lsrpia[i].OwnerName);
- lsrepdba[i] = lsrepdb;
- }
- lsrp.ReportData = lsrepdba;
- OutPacket(lsrp, ThrottleOutPacketType.Task);
- }
+ if (m_GroupsModule != null)
+ {
+ GroupTitlesReplyPacket groupTitlesReply = (GroupTitlesReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupTitlesReply);
- public void SendScriptRunningReply(UUID objectID, UUID itemID, bool running)
- {
- ScriptRunningReplyPacket scriptRunningReply = new ScriptRunningReplyPacket();
- scriptRunningReply.Script.ObjectID = objectID;
- scriptRunningReply.Script.ItemID = itemID;
- scriptRunningReply.Script.Running = running;
+ groupTitlesReply.AgentData =
+ new GroupTitlesReplyPacket.AgentDataBlock();
- OutPacket(scriptRunningReply, ThrottleOutPacketType.Task);
- }
+ groupTitlesReply.AgentData.AgentID = AgentId;
+ groupTitlesReply.AgentData.GroupID =
+ groupTitlesRequest.AgentData.GroupID;
- public void SendAsset(AssetRequestToClient req)
- {
- //m_log.Debug("sending asset " + req.RequestAssetID);
- TransferInfoPacket Transfer = new TransferInfoPacket();
- Transfer.TransferInfo.ChannelType = 2;
- Transfer.TransferInfo.Status = 0;
- Transfer.TransferInfo.TargetType = 0;
- if (req.AssetRequestSource == 2)
- {
- Transfer.TransferInfo.Params = new byte[20];
- Array.Copy(req.RequestAssetID.GetBytes(), 0, Transfer.TransferInfo.Params, 0, 16);
- int assType = req.AssetInf.Type;
- Array.Copy(Utils.IntToBytes(assType), 0, Transfer.TransferInfo.Params, 16, 4);
- }
- else if (req.AssetRequestSource == 3)
- {
- Transfer.TransferInfo.Params = req.Params;
- // Transfer.TransferInfo.Params = new byte[100];
- //Array.Copy(req.RequestUser.AgentId.GetBytes(), 0, Transfer.TransferInfo.Params, 0, 16);
- //Array.Copy(req.RequestUser.SessionId.GetBytes(), 0, Transfer.TransferInfo.Params, 16, 16);
- }
- Transfer.TransferInfo.Size = req.AssetInf.Data.Length;
- Transfer.TransferInfo.TransferID = req.TransferRequestID;
- Transfer.Header.Zerocoded = true;
- OutPacket(Transfer, ThrottleOutPacketType.Asset);
+ groupTitlesReply.AgentData.RequestID =
+ groupTitlesRequest.AgentData.RequestID;
- if (req.NumPackets == 1)
- {
- TransferPacketPacket TransferPacket = new TransferPacketPacket();
- TransferPacket.TransferData.Packet = 0;
- TransferPacket.TransferData.ChannelType = 2;
- TransferPacket.TransferData.TransferID = req.TransferRequestID;
- TransferPacket.TransferData.Data = req.AssetInf.Data;
- TransferPacket.TransferData.Status = 1;
- TransferPacket.Header.Zerocoded = true;
- OutPacket(TransferPacket, ThrottleOutPacketType.Asset);
- }
- else
- {
- int processedLength = 0;
- int maxChunkSize = Settings.MAX_PACKET_SIZE - 100;
- int packetNumber = 0;
+ List titles =
+ m_GroupsModule.GroupTitlesRequest(this,
+ groupTitlesRequest.AgentData.GroupID);
- while (processedLength < req.AssetInf.Data.Length)
- {
- TransferPacketPacket TransferPacket = new TransferPacketPacket();
- TransferPacket.TransferData.Packet = packetNumber;
- TransferPacket.TransferData.ChannelType = 2;
- TransferPacket.TransferData.TransferID = req.TransferRequestID;
+ groupTitlesReply.GroupData =
+ new GroupTitlesReplyPacket.GroupDataBlock[titles.Count];
- int chunkSize = Math.Min(req.AssetInf.Data.Length - processedLength, maxChunkSize);
- byte[] chunk = new byte[chunkSize];
- Array.Copy(req.AssetInf.Data, processedLength, chunk, 0, chunk.Length);
+ int i = 0;
+ foreach (GroupTitlesData d in titles)
+ {
+ groupTitlesReply.GroupData[i] =
+ new GroupTitlesReplyPacket.GroupDataBlock();
- TransferPacket.TransferData.Data = chunk;
+ groupTitlesReply.GroupData[i].Title =
+ Utils.StringToBytes(d.Name);
+ groupTitlesReply.GroupData[i].RoleID =
+ d.UUID;
+ groupTitlesReply.GroupData[i].Selected =
+ d.Selected;
+ i++;
+ }
- // 0 indicates more packets to come, 1 indicates last packet
- if (req.AssetInf.Data.Length - processedLength > maxChunkSize)
+ OutPacket(groupTitlesReply, ThrottleOutPacketType.Task);
+ }
+ break;
+
+ case PacketType.GroupProfileRequest:
+ GroupProfileRequestPacket groupProfileRequest =
+ (GroupProfileRequestPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- TransferPacket.TransferData.Status = 0;
+ if (groupProfileRequest.AgentData.SessionID != SessionId ||
+ groupProfileRequest.AgentData.AgentID != AgentId)
+ break;
}
- else
+ #endregion
+
+ if (m_GroupsModule != null)
{
- TransferPacket.TransferData.Status = 1;
+ GroupProfileReplyPacket groupProfileReply = (GroupProfileReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupProfileReply);
+
+ groupProfileReply.AgentData = new GroupProfileReplyPacket.AgentDataBlock();
+ groupProfileReply.GroupData = new GroupProfileReplyPacket.GroupDataBlock();
+ groupProfileReply.AgentData.AgentID = AgentId;
+
+ GroupProfileData d = m_GroupsModule.GroupProfileRequest(this,
+ groupProfileRequest.GroupData.GroupID);
+
+ groupProfileReply.GroupData.GroupID = d.GroupID;
+ groupProfileReply.GroupData.Name = Utils.StringToBytes(d.Name);
+ groupProfileReply.GroupData.Charter = Utils.StringToBytes(d.Charter);
+ groupProfileReply.GroupData.ShowInList = d.ShowInList;
+ groupProfileReply.GroupData.MemberTitle = Utils.StringToBytes(d.MemberTitle);
+ groupProfileReply.GroupData.PowersMask = d.PowersMask;
+ groupProfileReply.GroupData.InsigniaID = d.InsigniaID;
+ groupProfileReply.GroupData.FounderID = d.FounderID;
+ groupProfileReply.GroupData.MembershipFee = d.MembershipFee;
+ groupProfileReply.GroupData.OpenEnrollment = d.OpenEnrollment;
+ groupProfileReply.GroupData.Money = d.Money;
+ groupProfileReply.GroupData.GroupMembershipCount = d.GroupMembershipCount;
+ groupProfileReply.GroupData.GroupRolesCount = d.GroupRolesCount;
+ groupProfileReply.GroupData.AllowPublish = d.AllowPublish;
+ groupProfileReply.GroupData.MaturePublish = d.MaturePublish;
+ groupProfileReply.GroupData.OwnerRole = d.OwnerRole;
+
+ OutPacket(groupProfileReply, ThrottleOutPacketType.Task);
}
- TransferPacket.Header.Zerocoded = true;
- OutPacket(TransferPacket, ThrottleOutPacketType.Asset);
+ break;
- processedLength += chunkSize;
- packetNumber++;
- }
- }
- }
+ case PacketType.GroupMembersRequest:
+ GroupMembersRequestPacket groupMembersRequestPacket =
+ (GroupMembersRequestPacket)Pack;
- public void SendTexture(AssetBase TextureAsset)
- {
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupMembersRequestPacket.AgentData.SessionID != SessionId ||
+ groupMembersRequestPacket.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- }
+ if (m_GroupsModule != null)
+ {
+ List members =
+ m_GroupsModule.GroupMembersRequest(this, groupMembersRequestPacket.GroupData.GroupID);
- public ClientInfo GetClientInfo()
- {
- ClientInfo info = m_PacketHandler.GetClientInfo();
+ int memberCount = members.Count;
- info.userEP = m_userEndPoint;
- info.proxyEP = m_proxyEndPoint;
- info.agentcircuit = new sAgentCircuitData(RequestClientInfo());
+ while (true)
+ {
+ int blockCount = members.Count;
+ if (blockCount > 40)
+ blockCount = 40;
- return info;
- }
+ GroupMembersReplyPacket groupMembersReply = (GroupMembersReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupMembersReply);
- public EndPoint GetClientEP()
- {
- return m_userEndPoint;
- }
+ groupMembersReply.AgentData =
+ new GroupMembersReplyPacket.AgentDataBlock();
+ groupMembersReply.GroupData =
+ new GroupMembersReplyPacket.GroupDataBlock();
+ groupMembersReply.MemberData =
+ new GroupMembersReplyPacket.MemberDataBlock[
+ blockCount];
- public void SetClientInfo(ClientInfo info)
- {
- m_PacketHandler.SetClientInfo(info);
- }
+ groupMembersReply.AgentData.AgentID = AgentId;
+ groupMembersReply.GroupData.GroupID =
+ groupMembersRequestPacket.GroupData.GroupID;
+ groupMembersReply.GroupData.RequestID =
+ groupMembersRequestPacket.GroupData.RequestID;
+ groupMembersReply.GroupData.MemberCount = memberCount;
- #region Media Parcel Members
+ for (int i = 0 ; i < blockCount ; i++)
+ {
+ GroupMembersData m = members[0];
+ members.RemoveAt(0);
- public void SendParcelMediaCommand(uint flags, ParcelMediaCommandEnum command, float time)
- {
- ParcelMediaCommandMessagePacket commandMessagePacket = new ParcelMediaCommandMessagePacket();
- commandMessagePacket.CommandBlock.Flags = flags;
- commandMessagePacket.CommandBlock.Command =(uint) command;
- commandMessagePacket.CommandBlock.Time = time;
+ groupMembersReply.MemberData[i] =
+ new GroupMembersReplyPacket.MemberDataBlock();
+ groupMembersReply.MemberData[i].AgentID =
+ m.AgentID;
+ groupMembersReply.MemberData[i].Contribution =
+ m.Contribution;
+ groupMembersReply.MemberData[i].OnlineStatus =
+ Utils.StringToBytes(m.OnlineStatus);
+ groupMembersReply.MemberData[i].AgentPowers =
+ m.AgentPowers;
+ groupMembersReply.MemberData[i].Title =
+ Utils.StringToBytes(m.Title);
+ groupMembersReply.MemberData[i].IsOwner =
+ m.IsOwner;
+ }
+ OutPacket(groupMembersReply, ThrottleOutPacketType.Task);
+ if (members.Count == 0)
+ break;
+ }
+ }
+ break;
- OutPacket(commandMessagePacket, ThrottleOutPacketType.Unknown);
- }
+ case PacketType.GroupRoleDataRequest:
+ GroupRoleDataRequestPacket groupRolesRequest =
+ (GroupRoleDataRequestPacket)Pack;
- public void SendParcelMediaUpdate(string mediaUrl, UUID mediaTextureID,
- byte autoScale, string mediaType, string mediaDesc, int mediaWidth, int mediaHeight,
- byte mediaLoop)
- {
- ParcelMediaUpdatePacket updatePacket = new ParcelMediaUpdatePacket();
- updatePacket.DataBlock.MediaURL = Utils.StringToBytes(mediaUrl);
- updatePacket.DataBlock.MediaID = mediaTextureID;
- updatePacket.DataBlock.MediaAutoScale = autoScale;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupRolesRequest.AgentData.SessionID != SessionId ||
+ groupRolesRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- updatePacket.DataBlockExtended.MediaType = Utils.StringToBytes(mediaType);
- updatePacket.DataBlockExtended.MediaDesc = Utils.StringToBytes(mediaDesc);
- updatePacket.DataBlockExtended.MediaWidth = mediaWidth;
- updatePacket.DataBlockExtended.MediaHeight = mediaHeight;
- updatePacket.DataBlockExtended.MediaLoop = mediaLoop;
+ if (m_GroupsModule != null)
+ {
+ GroupRoleDataReplyPacket groupRolesReply = (GroupRoleDataReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupRoleDataReply);
- OutPacket(updatePacket, ThrottleOutPacketType.Unknown);
- }
+ groupRolesReply.AgentData =
+ new GroupRoleDataReplyPacket.AgentDataBlock();
- #endregion
+ groupRolesReply.AgentData.AgentID = AgentId;
+ groupRolesReply.GroupData =
+ new GroupRoleDataReplyPacket.GroupDataBlock();
- #region Camera
+ groupRolesReply.GroupData.GroupID =
+ groupRolesRequest.GroupData.GroupID;
- public void SendSetFollowCamProperties (UUID objectID, SortedDictionary parameters)
- {
- SetFollowCamPropertiesPacket packet = (SetFollowCamPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.SetFollowCamProperties);
- packet.ObjectData.ObjectID = objectID;
- SetFollowCamPropertiesPacket.CameraPropertyBlock[] camPropBlock = new SetFollowCamPropertiesPacket.CameraPropertyBlock[parameters.Count];
- uint idx = 0;
- foreach (KeyValuePair pair in parameters)
- {
- SetFollowCamPropertiesPacket.CameraPropertyBlock block = new SetFollowCamPropertiesPacket.CameraPropertyBlock();
- block.Type = pair.Key;
- block.Value = pair.Value;
+ groupRolesReply.GroupData.RequestID =
+ groupRolesRequest.GroupData.RequestID;
- camPropBlock[idx++] = block;
- }
- packet.CameraProperty = camPropBlock;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ List titles =
+ m_GroupsModule.GroupRoleDataRequest(this,
+ groupRolesRequest.GroupData.GroupID);
+
+ groupRolesReply.GroupData.RoleCount =
+ titles.Count;
+
+ groupRolesReply.RoleData =
+ new GroupRoleDataReplyPacket.RoleDataBlock[titles.Count];
+
+ int i = 0;
+ foreach (GroupRolesData d in titles)
+ {
+ groupRolesReply.RoleData[i] =
+ new GroupRoleDataReplyPacket.RoleDataBlock();
+
+ groupRolesReply.RoleData[i].RoleID =
+ d.RoleID;
+ groupRolesReply.RoleData[i].Name =
+ Utils.StringToBytes(d.Name);
+ groupRolesReply.RoleData[i].Title =
+ Utils.StringToBytes(d.Title);
+ groupRolesReply.RoleData[i].Description =
+ Utils.StringToBytes(d.Description);
+ groupRolesReply.RoleData[i].Powers =
+ d.Powers;
+ groupRolesReply.RoleData[i].Members =
+ (uint)d.Members;
+
+ i++;
+ }
+
+ OutPacket(groupRolesReply, ThrottleOutPacketType.Task);
+ }
+ break;
- public void SendClearFollowCamProperties (UUID objectID)
- {
- ClearFollowCamPropertiesPacket packet = (ClearFollowCamPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ClearFollowCamProperties);
- packet.ObjectData.ObjectID = objectID;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ case PacketType.GroupRoleMembersRequest:
+ GroupRoleMembersRequestPacket groupRoleMembersRequest =
+ (GroupRoleMembersRequestPacket)Pack;
- #endregion
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupRoleMembersRequest.AgentData.SessionID != SessionId ||
+ groupRoleMembersRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendRegionHandle(UUID regionID, ulong handle) {
- RegionIDAndHandleReplyPacket reply = (RegionIDAndHandleReplyPacket)PacketPool.Instance.GetPacket(PacketType.RegionIDAndHandleReply);
- reply.ReplyBlock.RegionID = regionID;
- reply.ReplyBlock.RegionHandle = handle;
- OutPacket(reply, ThrottleOutPacketType.Land);
- }
+ if (m_GroupsModule != null)
+ {
+ List mappings =
+ m_GroupsModule.GroupRoleMembersRequest(this,
+ groupRoleMembersRequest.GroupData.GroupID);
- public void SendParcelInfo(RegionInfo info, LandData land, UUID parcelID, uint x, uint y)
- {
- ParcelInfoReplyPacket reply = (ParcelInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelInfoReply);
- reply.AgentData.AgentID = m_agentId;
- reply.Data.ParcelID = parcelID;
- reply.Data.OwnerID = land.OwnerID;
- reply.Data.Name = Utils.StringToBytes(land.Name);
- reply.Data.Desc = Utils.StringToBytes(land.Description);
- reply.Data.ActualArea = land.Area;
- reply.Data.BillableArea = land.Area; // TODO: what is this?
+ int mappingsCount = mappings.Count;
- // Bit 0: Mature, bit 7: on sale, other bits: no idea
- reply.Data.Flags = (byte)(
- ((land.Flags & (uint)ParcelFlags.MaturePublish) != 0 ? (1 << 0) : 0) +
- ((land.Flags & (uint)ParcelFlags.ForSale) != 0 ? (1 << 7) : 0));
+ while (mappings.Count > 0)
+ {
+ int pairs = mappings.Count;
+ if (pairs > 32)
+ pairs = 32;
- Vector3 pos = land.UserLocation;
- if (pos.Equals(Vector3.Zero))
- {
- pos = (land.AABBMax + land.AABBMin) * 0.5f;
- }
- reply.Data.GlobalX = info.RegionLocX * Constants.RegionSize + x;
- reply.Data.GlobalY = info.RegionLocY * Constants.RegionSize + y;
- reply.Data.GlobalZ = pos.Z;
- reply.Data.SimName = Utils.StringToBytes(info.RegionName);
- reply.Data.SnapshotID = land.SnapshotID;
- reply.Data.Dwell = land.Dwell;
- reply.Data.SalePrice = land.SalePrice;
- reply.Data.AuctionID = (int)land.AuctionID;
+ GroupRoleMembersReplyPacket groupRoleMembersReply = (GroupRoleMembersReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupRoleMembersReply);
+ groupRoleMembersReply.AgentData =
+ new GroupRoleMembersReplyPacket.AgentDataBlock();
+ groupRoleMembersReply.AgentData.AgentID =
+ AgentId;
+ groupRoleMembersReply.AgentData.GroupID =
+ groupRoleMembersRequest.GroupData.GroupID;
+ groupRoleMembersReply.AgentData.RequestID =
+ groupRoleMembersRequest.GroupData.RequestID;
- OutPacket(reply, ThrottleOutPacketType.Land);
- }
+ groupRoleMembersReply.AgentData.TotalPairs =
+ (uint)mappingsCount;
- public void SendScriptTeleportRequest(string objName, string simName, Vector3 pos, Vector3 lookAt)
- {
- ScriptTeleportRequestPacket packet = (ScriptTeleportRequestPacket)PacketPool.Instance.GetPacket(PacketType.ScriptTeleportRequest);
+ groupRoleMembersReply.MemberData =
+ new GroupRoleMembersReplyPacket.MemberDataBlock[pairs];
- packet.Data.ObjectName = Utils.StringToBytes(objName);
- packet.Data.SimName = Utils.StringToBytes(simName);
- packet.Data.SimPosition = pos;
- packet.Data.LookAt = lookAt;
+ for (int i = 0 ; i < pairs ; i++)
+ {
+ GroupRoleMembersData d = mappings[0];
+ mappings.RemoveAt(0);
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ groupRoleMembersReply.MemberData[i] =
+ new GroupRoleMembersReplyPacket.MemberDataBlock();
- public void SetClientOption(string option, string value)
- {
- switch (option)
- {
- case "ReliableIsImportant":
- bool val;
+ groupRoleMembersReply.MemberData[i].RoleID =
+ d.RoleID;
+ groupRoleMembersReply.MemberData[i].MemberID =
+ d.MemberID;
+ }
- if (bool.TryParse(value, out val))
- m_PacketHandler.ReliableIsImportant = val;
- break;
- default:
- break;
- }
- }
+ OutPacket(groupRoleMembersReply, ThrottleOutPacketType.Task);
+ }
+ }
+ break;
- public string GetClientOption(string option)
- {
- switch (option)
- {
- case "ReliableIsImportant":
- return m_PacketHandler.ReliableIsImportant.ToString();
+ case PacketType.CreateGroupRequest:
+ CreateGroupRequestPacket createGroupRequest =
+ (CreateGroupRequestPacket)Pack;
- default:
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (createGroupRequest.AgentData.SessionID != SessionId ||
+ createGroupRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.CreateGroup(this,
+ Utils.BytesToString(createGroupRequest.GroupData.Name),
+ Utils.BytesToString(createGroupRequest.GroupData.Charter),
+ createGroupRequest.GroupData.ShowInList,
+ createGroupRequest.GroupData.InsigniaID,
+ createGroupRequest.GroupData.MembershipFee,
+ createGroupRequest.GroupData.OpenEnrollment,
+ createGroupRequest.GroupData.AllowPublish,
+ createGroupRequest.GroupData.MaturePublish);
+ }
break;
- }
- return string.Empty;
- }
- public void SendDirPlacesReply(UUID queryID, DirPlacesReplyData[] data)
- {
- DirPlacesReplyPacket packet = (DirPlacesReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPlacesReply);
+ case PacketType.UpdateGroupInfo:
+ UpdateGroupInfoPacket updateGroupInfo =
+ (UpdateGroupInfoPacket)Pack;
- packet.AgentData = new DirPlacesReplyPacket.AgentDataBlock();
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (updateGroupInfo.AgentData.SessionID != SessionId ||
+ updateGroupInfo.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.QueryData = new DirPlacesReplyPacket.QueryDataBlock[1];
- packet.QueryData[0] = new DirPlacesReplyPacket.QueryDataBlock();
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.UpdateGroupInfo(this,
+ updateGroupInfo.GroupData.GroupID,
+ Utils.BytesToString(updateGroupInfo.GroupData.Charter),
+ updateGroupInfo.GroupData.ShowInList,
+ updateGroupInfo.GroupData.InsigniaID,
+ updateGroupInfo.GroupData.MembershipFee,
+ updateGroupInfo.GroupData.OpenEnrollment,
+ updateGroupInfo.GroupData.AllowPublish,
+ updateGroupInfo.GroupData.MaturePublish);
+ }
- packet.QueryReplies =
- new DirPlacesReplyPacket.QueryRepliesBlock[data.Length];
+ break;
- packet.StatusData = new DirPlacesReplyPacket.StatusDataBlock[
- data.Length];
+ case PacketType.SetGroupAcceptNotices:
+ SetGroupAcceptNoticesPacket setGroupAcceptNotices =
+ (SetGroupAcceptNoticesPacket)Pack;
- packet.AgentData.AgentID = AgentId;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (setGroupAcceptNotices.AgentData.SessionID != SessionId ||
+ setGroupAcceptNotices.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.QueryData[0].QueryID = queryID;
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.SetGroupAcceptNotices(this,
+ setGroupAcceptNotices.Data.GroupID,
+ setGroupAcceptNotices.Data.AcceptNotices,
+ setGroupAcceptNotices.NewData.ListInProfile);
+ }
- int i = 0;
- foreach (DirPlacesReplyData d in data)
- {
- packet.QueryReplies[i] =
- new DirPlacesReplyPacket.QueryRepliesBlock();
- packet.StatusData[i] = new DirPlacesReplyPacket.StatusDataBlock();
- packet.QueryReplies[i].ParcelID = d.parcelID;
- packet.QueryReplies[i].Name = Utils.StringToBytes(d.name);
- packet.QueryReplies[i].ForSale = d.forSale;
- packet.QueryReplies[i].Auction = d.auction;
- packet.QueryReplies[i].Dwell = d.dwell;
- packet.StatusData[i].Status = d.Status;
- i++;
- }
+ break;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ case PacketType.GroupTitleUpdate:
+ GroupTitleUpdatePacket groupTitleUpdate =
+ (GroupTitleUpdatePacket)Pack;
- public void SendDirPeopleReply(UUID queryID, DirPeopleReplyData[] data)
- {
- DirPeopleReplyPacket packet = (DirPeopleReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPeopleReply);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupTitleUpdate.AgentData.SessionID != SessionId ||
+ groupTitleUpdate.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.AgentData = new DirPeopleReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.GroupTitleUpdate(this,
+ groupTitleUpdate.AgentData.GroupID,
+ groupTitleUpdate.AgentData.TitleRoleID);
+ }
- packet.QueryData = new DirPeopleReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ break;
- packet.QueryReplies = new DirPeopleReplyPacket.QueryRepliesBlock[
- data.Length];
- int i = 0;
- foreach (DirPeopleReplyData d in data)
- {
- packet.QueryReplies[i] = new DirPeopleReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].AgentID = d.agentID;
- packet.QueryReplies[i].FirstName =
- Utils.StringToBytes(d.firstName);
- packet.QueryReplies[i].LastName =
- Utils.StringToBytes(d.lastName);
- packet.QueryReplies[i].Group =
- Utils.StringToBytes(d.group);
- packet.QueryReplies[i].Online = d.online;
- packet.QueryReplies[i].Reputation = d.reputation;
- i++;
- }
+ case PacketType.ParcelDeedToGroup:
+ ParcelDeedToGroupPacket parcelDeedToGroup = (ParcelDeedToGroupPacket)Pack;
+ if (m_GroupsModule != null)
+ {
+ ParcelDeedToGroup handlerParcelDeedToGroup = OnParcelDeedToGroup;
+ if (handlerParcelDeedToGroup != null)
+ {
+ handlerParcelDeedToGroup(parcelDeedToGroup.Data.LocalID, parcelDeedToGroup.Data.GroupID,this);
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ }
+ }
- public void SendDirEventsReply(UUID queryID, DirEventsReplyData[] data)
- {
- DirEventsReplyPacket packet = (DirEventsReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirEventsReply);
+ break;
- packet.AgentData = new DirEventsReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
- packet.QueryData = new DirEventsReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ case PacketType.GroupNoticesListRequest:
+ GroupNoticesListRequestPacket groupNoticesListRequest =
+ (GroupNoticesListRequestPacket)Pack;
- packet.QueryReplies = new DirEventsReplyPacket.QueryRepliesBlock[
- data.Length];
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupNoticesListRequest.AgentData.SessionID != SessionId ||
+ groupNoticesListRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.StatusData = new DirEventsReplyPacket.StatusDataBlock[
- data.Length];
+ if (m_GroupsModule != null)
+ {
+ GroupNoticeData[] gn =
+ m_GroupsModule.GroupNoticesListRequest(this,
+ groupNoticesListRequest.Data.GroupID);
- int i = 0;
- foreach (DirEventsReplyData d in data)
- {
- packet.QueryReplies[i] = new DirEventsReplyPacket.QueryRepliesBlock();
- packet.StatusData[i] = new DirEventsReplyPacket.StatusDataBlock();
- packet.QueryReplies[i].OwnerID = d.ownerID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].EventID = d.eventID;
- packet.QueryReplies[i].Date =
- Utils.StringToBytes(d.date);
- packet.QueryReplies[i].UnixTime = d.unixTime;
- packet.QueryReplies[i].EventFlags = d.eventFlags;
- packet.StatusData[i].Status = d.Status;
- i++;
- }
+ GroupNoticesListReplyPacket groupNoticesListReply = (GroupNoticesListReplyPacket)PacketPool.Instance.GetPacket(PacketType.GroupNoticesListReply);
+ groupNoticesListReply.AgentData =
+ new GroupNoticesListReplyPacket.AgentDataBlock();
+ groupNoticesListReply.AgentData.AgentID = AgentId;
+ groupNoticesListReply.AgentData.GroupID = groupNoticesListRequest.Data.GroupID;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ groupNoticesListReply.Data = new GroupNoticesListReplyPacket.DataBlock[gn.Length];
- public void SendDirGroupsReply(UUID queryID, DirGroupsReplyData[] data)
- {
- DirGroupsReplyPacket packet = (DirGroupsReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirGroupsReply);
+ int i = 0;
+ foreach (GroupNoticeData g in gn)
+ {
+ groupNoticesListReply.Data[i] = new GroupNoticesListReplyPacket.DataBlock();
+ groupNoticesListReply.Data[i].NoticeID =
+ g.NoticeID;
+ groupNoticesListReply.Data[i].Timestamp =
+ g.Timestamp;
+ groupNoticesListReply.Data[i].FromName =
+ Utils.StringToBytes(g.FromName);
+ groupNoticesListReply.Data[i].Subject =
+ Utils.StringToBytes(g.Subject);
+ groupNoticesListReply.Data[i].HasAttachment =
+ g.HasAttachment;
+ groupNoticesListReply.Data[i].AssetType =
+ g.AssetType;
+ i++;
+ }
- packet.AgentData = new DirGroupsReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ OutPacket(groupNoticesListReply, ThrottleOutPacketType.Task);
+ }
- packet.QueryData = new DirGroupsReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ break;
+ case PacketType.GroupNoticeRequest:
+ GroupNoticeRequestPacket groupNoticeRequest =
+ (GroupNoticeRequestPacket)Pack;
- packet.QueryReplies = new DirGroupsReplyPacket.QueryRepliesBlock[
- data.Length];
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupNoticeRequest.AgentData.SessionID != SessionId ||
+ groupNoticeRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- int i = 0;
- foreach (DirGroupsReplyData d in data)
- {
- packet.QueryReplies[i] = new DirGroupsReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].GroupID = d.groupID;
- packet.QueryReplies[i].GroupName =
- Utils.StringToBytes(d.groupName);
- packet.QueryReplies[i].Members = d.members;
- packet.QueryReplies[i].SearchOrder = d.searchOrder;
- i++;
- }
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.GroupNoticeRequest(this,
+ groupNoticeRequest.Data.GroupNoticeID);
+ }
+ break;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ case PacketType.GroupRoleUpdate:
+ GroupRoleUpdatePacket groupRoleUpdate =
+ (GroupRoleUpdatePacket)Pack;
- public void SendDirClassifiedReply(UUID queryID, DirClassifiedReplyData[] data)
- {
- DirClassifiedReplyPacket packet = (DirClassifiedReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirClassifiedReply);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupRoleUpdate.AgentData.SessionID != SessionId ||
+ groupRoleUpdate.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.AgentData = new DirClassifiedReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ if (m_GroupsModule != null)
+ {
+ foreach (GroupRoleUpdatePacket.RoleDataBlock d in
+ groupRoleUpdate.RoleData)
+ {
+ m_GroupsModule.GroupRoleUpdate(this,
+ groupRoleUpdate.AgentData.GroupID,
+ d.RoleID,
+ Utils.BytesToString(d.Name),
+ Utils.BytesToString(d.Description),
+ Utils.BytesToString(d.Title),
+ d.Powers,
+ d.UpdateType);
+ }
+ m_GroupsModule.NotifyChange(groupRoleUpdate.AgentData.GroupID);
+ }
+ break;
- packet.QueryData = new DirClassifiedReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ case PacketType.GroupRoleChanges:
+ GroupRoleChangesPacket groupRoleChanges =
+ (GroupRoleChangesPacket)Pack;
- packet.QueryReplies = new DirClassifiedReplyPacket.QueryRepliesBlock[
- data.Length];
- packet.StatusData = new DirClassifiedReplyPacket.StatusDataBlock[
- data.Length];
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (groupRoleChanges.AgentData.SessionID != SessionId ||
+ groupRoleChanges.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- int i = 0;
- foreach (DirClassifiedReplyData d in data)
- {
- packet.QueryReplies[i] = new DirClassifiedReplyPacket.QueryRepliesBlock();
- packet.StatusData[i] = new DirClassifiedReplyPacket.StatusDataBlock();
- packet.QueryReplies[i].ClassifiedID = d.classifiedID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].ClassifiedFlags = d.classifiedFlags;
- packet.QueryReplies[i].CreationDate = d.creationDate;
- packet.QueryReplies[i].ExpirationDate = d.expirationDate;
- packet.QueryReplies[i].PriceForListing = d.price;
- packet.StatusData[i].Status = d.Status;
- i++;
- }
+ if (m_GroupsModule != null)
+ {
+ foreach (GroupRoleChangesPacket.RoleChangeBlock d in
+ groupRoleChanges.RoleChange)
+ {
+ m_GroupsModule.GroupRoleChanges(this,
+ groupRoleChanges.AgentData.GroupID,
+ d.RoleID,
+ d.MemberID,
+ d.Change);
+ }
+ m_GroupsModule.NotifyChange(groupRoleChanges.AgentData.GroupID);
+ }
+ break;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ case PacketType.JoinGroupRequest:
+ JoinGroupRequestPacket joinGroupRequest =
+ (JoinGroupRequestPacket)Pack;
- public void SendDirLandReply(UUID queryID, DirLandReplyData[] data)
- {
- DirLandReplyPacket packet = (DirLandReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirLandReply);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (joinGroupRequest.AgentData.SessionID != SessionId ||
+ joinGroupRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.AgentData = new DirLandReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.JoinGroupRequest(this,
+ joinGroupRequest.GroupData.GroupID);
+ }
+ break;
- packet.QueryData = new DirLandReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ case PacketType.LeaveGroupRequest:
+ LeaveGroupRequestPacket leaveGroupRequest =
+ (LeaveGroupRequestPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (leaveGroupRequest.AgentData.SessionID != SessionId ||
+ leaveGroupRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
+
+ if (m_GroupsModule != null)
+ {
+ m_GroupsModule.LeaveGroupRequest(this,
+ leaveGroupRequest.GroupData.GroupID);
+ }
+ break;
+
+ case PacketType.EjectGroupMemberRequest:
+ EjectGroupMemberRequestPacket ejectGroupMemberRequest =
+ (EjectGroupMemberRequestPacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (ejectGroupMemberRequest.AgentData.SessionID != SessionId ||
+ ejectGroupMemberRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.QueryReplies = new DirLandReplyPacket.QueryRepliesBlock[
- data.Length];
+ if (m_GroupsModule != null)
+ {
+ foreach (EjectGroupMemberRequestPacket.EjectDataBlock e
+ in ejectGroupMemberRequest.EjectData)
+ {
+ m_GroupsModule.EjectGroupMemberRequest(this,
+ ejectGroupMemberRequest.GroupData.GroupID,
+ e.EjecteeID);
+ }
+ }
+ break;
- int i = 0;
- foreach (DirLandReplyData d in data)
- {
- packet.QueryReplies[i] = new DirLandReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].ParcelID = d.parcelID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].Auction = d.auction;
- packet.QueryReplies[i].ForSale = d.forSale;
- packet.QueryReplies[i].SalePrice = d.salePrice;
- packet.QueryReplies[i].ActualArea = d.actualArea;
- i++;
- }
+ case PacketType.InviteGroupRequest:
+ InviteGroupRequestPacket inviteGroupRequest =
+ (InviteGroupRequestPacket)Pack;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (inviteGroupRequest.AgentData.SessionID != SessionId ||
+ inviteGroupRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendDirPopularReply(UUID queryID, DirPopularReplyData[] data)
- {
- DirPopularReplyPacket packet = (DirPopularReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPopularReply);
+ if (m_GroupsModule != null)
+ {
+ foreach (InviteGroupRequestPacket.InviteDataBlock b in
+ inviteGroupRequest.InviteData)
+ {
+ m_GroupsModule.InviteGroupRequest(this,
+ inviteGroupRequest.GroupData.GroupID,
+ b.InviteeID,
+ b.RoleID);
+ }
+ }
+ break;
- packet.AgentData = new DirPopularReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ #endregion
+ case PacketType.StartLure:
+ StartLurePacket startLureRequest = (StartLurePacket)Pack;
- packet.QueryData = new DirPopularReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (startLureRequest.AgentData.SessionID != SessionId ||
+ startLureRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- packet.QueryReplies = new DirPopularReplyPacket.QueryRepliesBlock[
- data.Length];
+ StartLure handlerStartLure = OnStartLure;
+ if (handlerStartLure != null)
+ handlerStartLure(startLureRequest.Info.LureType,
+ Utils.BytesToString(
+ startLureRequest.Info.Message),
+ startLureRequest.TargetData[0].TargetID,
+ this);
+ break;
- int i = 0;
- foreach (DirPopularReplyData d in data)
- {
- packet.QueryReplies[i] = new DirPopularReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].ParcelID = d.parcelID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].Dwell = d.dwell;
- i++;
- }
+ case PacketType.TeleportLureRequest:
+ TeleportLureRequestPacket teleportLureRequest =
+ (TeleportLureRequestPacket)Pack;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (teleportLureRequest.Info.SessionID != SessionId ||
+ teleportLureRequest.Info.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendEventInfoReply(EventData data)
- {
- EventInfoReplyPacket packet = (EventInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.EventInfoReply);
+ TeleportLureRequest handlerTeleportLureRequest = OnTeleportLureRequest;
+ if (handlerTeleportLureRequest != null)
+ handlerTeleportLureRequest(
+ teleportLureRequest.Info.LureID,
+ teleportLureRequest.Info.TeleportFlags,
+ this);
+ break;
- packet.AgentData = new EventInfoReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ case PacketType.ClassifiedInfoRequest:
+ ClassifiedInfoRequestPacket classifiedInfoRequest =
+ (ClassifiedInfoRequestPacket)Pack;
- packet.EventData = new EventInfoReplyPacket.EventDataBlock();
- packet.EventData.EventID = data.eventID;
- packet.EventData.Creator = Utils.StringToBytes(data.creator);
- packet.EventData.Name = Utils.StringToBytes(data.name);
- packet.EventData.Category = Utils.StringToBytes(data.category);
- packet.EventData.Desc = Utils.StringToBytes(data.description);
- packet.EventData.Date = Utils.StringToBytes(data.date);
- packet.EventData.DateUTC = data.dateUTC;
- packet.EventData.Duration = data.duration;
- packet.EventData.Cover = data.cover;
- packet.EventData.Amount = data.amount;
- packet.EventData.SimName = Utils.StringToBytes(data.simName);
- packet.EventData.GlobalPos = new Vector3d(data.globalPos);
- packet.EventData.EventFlags = data.eventFlags;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (classifiedInfoRequest.AgentData.SessionID != SessionId ||
+ classifiedInfoRequest.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ ClassifiedInfoRequest handlerClassifiedInfoRequest = OnClassifiedInfoRequest;
+ if (handlerClassifiedInfoRequest != null)
+ handlerClassifiedInfoRequest(
+ classifiedInfoRequest.Data.ClassifiedID,
+ this);
+ break;
- public void SendMapItemReply(mapItemReply[] replies, uint mapitemtype, uint flags)
- {
- MapItemReplyPacket mirplk = new MapItemReplyPacket();
- mirplk.AgentData.AgentID = AgentId;
- mirplk.RequestData.ItemType = mapitemtype;
- mirplk.Data = new MapItemReplyPacket.DataBlock[replies.Length];
- for (int i = 0; i < replies.Length; i++)
- {
- MapItemReplyPacket.DataBlock mrdata = new MapItemReplyPacket.DataBlock();
- mrdata.X = replies[i].x;
- mrdata.Y = replies[i].y;
- mrdata.ID = replies[i].id;
- mrdata.Extra = replies[i].Extra;
- mrdata.Extra2 = replies[i].Extra2;
- mrdata.Name = Utils.StringToBytes(replies[i].name);
- mirplk.Data[i] = mrdata;
- }
- //m_log.Debug(mirplk.ToString());
- OutPacket(mirplk, ThrottleOutPacketType.Task);
+ case PacketType.ClassifiedInfoUpdate:
+ ClassifiedInfoUpdatePacket classifiedInfoUpdate =
+ (ClassifiedInfoUpdatePacket)Pack;
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (classifiedInfoUpdate.AgentData.SessionID != SessionId ||
+ classifiedInfoUpdate.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendOfferCallingCard(UUID srcID, UUID transactionID)
- {
- // a bit special, as this uses AgentID to store the source instead
- // of the destination. The destination (the receiver) goes into destID
- OfferCallingCardPacket p = (OfferCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.OfferCallingCard);
- p.AgentData.AgentID = srcID;
- p.AgentData.SessionID = UUID.Zero;
- p.AgentBlock.DestID = AgentId;
- p.AgentBlock.TransactionID = transactionID;
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ ClassifiedInfoUpdate handlerClassifiedInfoUpdate = OnClassifiedInfoUpdate;
+ if (handlerClassifiedInfoUpdate != null)
+ handlerClassifiedInfoUpdate(
+ classifiedInfoUpdate.Data.ClassifiedID,
+ classifiedInfoUpdate.Data.Category,
+ Utils.BytesToString(
+ classifiedInfoUpdate.Data.Name),
+ Utils.BytesToString(
+ classifiedInfoUpdate.Data.Desc),
+ classifiedInfoUpdate.Data.ParcelID,
+ classifiedInfoUpdate.Data.ParentEstate,
+ classifiedInfoUpdate.Data.SnapshotID,
+ new Vector3(
+ classifiedInfoUpdate.Data.PosGlobal),
+ classifiedInfoUpdate.Data.ClassifiedFlags,
+ classifiedInfoUpdate.Data.PriceForListing,
+ this);
+ break;
- public void SendAcceptCallingCard(UUID transactionID)
- {
- AcceptCallingCardPacket p = (AcceptCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.AcceptCallingCard);
- p.AgentData.AgentID = AgentId;
- p.AgentData.SessionID = UUID.Zero;
- p.FolderData = new AcceptCallingCardPacket.FolderDataBlock[1];
- p.FolderData[0] = new AcceptCallingCardPacket.FolderDataBlock();
- p.FolderData[0].FolderID = UUID.Zero;
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ case PacketType.ClassifiedDelete:
+ ClassifiedDeletePacket classifiedDelete =
+ (ClassifiedDeletePacket)Pack;
- public void SendDeclineCallingCard(UUID transactionID)
- {
- DeclineCallingCardPacket p = (DeclineCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.DeclineCallingCard);
- p.AgentData.AgentID = AgentId;
- p.AgentData.SessionID = UUID.Zero;
- p.TransactionBlock.TransactionID = transactionID;
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (classifiedDelete.AgentData.SessionID != SessionId ||
+ classifiedDelete.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendTerminateFriend(UUID exFriendID)
- {
- TerminateFriendshipPacket p = (TerminateFriendshipPacket)PacketPool.Instance.GetPacket(PacketType.TerminateFriendship);
- p.AgentData.AgentID = AgentId;
- p.AgentData.SessionID = SessionId;
- p.ExBlock.OtherID = exFriendID;
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ ClassifiedDelete handlerClassifiedDelete = OnClassifiedDelete;
+ if (handlerClassifiedDelete != null)
+ handlerClassifiedDelete(
+ classifiedDelete.Data.ClassifiedID,
+ this);
+ break;
- public void SendAvatarGroupsReply(UUID avatarID, GroupMembershipData[] data)
- {
- AvatarGroupsReplyPacket p = (AvatarGroupsReplyPacket)PacketPool.Instance.GetPacket(PacketType.AvatarGroupsReply);
+ case PacketType.ClassifiedGodDelete:
+ ClassifiedGodDeletePacket classifiedGodDelete =
+ (ClassifiedGodDeletePacket)Pack;
+
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (classifiedGodDelete.AgentData.SessionID != SessionId ||
+ classifiedGodDelete.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- p.AgentData = new AvatarGroupsReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = AgentId;
- p.AgentData.AvatarID = avatarID;
+ ClassifiedDelete handlerClassifiedGodDelete = OnClassifiedGodDelete;
+ if (handlerClassifiedGodDelete != null)
+ handlerClassifiedGodDelete(
+ classifiedGodDelete.Data.ClassifiedID,
+ this);
+ break;
- p.GroupData = new AvatarGroupsReplyPacket.GroupDataBlock[data.Length];
- int i = 0;
- foreach (GroupMembershipData m in data)
- {
- p.GroupData[i] = new AvatarGroupsReplyPacket.GroupDataBlock();
- p.GroupData[i].GroupPowers = m.GroupPowers;
- p.GroupData[i].AcceptNotices = m.AcceptNotices;
- p.GroupData[i].GroupTitle = Utils.StringToBytes(m.GroupTitle);
- p.GroupData[i].GroupID = m.GroupID;
- p.GroupData[i].GroupName = Utils.StringToBytes(m.GroupName);
- p.GroupData[i].GroupInsigniaID = m.GroupPicture;
- i++;
- }
+ case PacketType.EventGodDelete:
+ EventGodDeletePacket eventGodDelete =
+ (EventGodDeletePacket)Pack;
- p.NewGroupData = new AvatarGroupsReplyPacket.NewGroupDataBlock();
- p.NewGroupData.ListInProfile = true;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (eventGodDelete.AgentData.SessionID != SessionId ||
+ eventGodDelete.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ EventGodDelete handlerEventGodDelete = OnEventGodDelete;
+ if (handlerEventGodDelete != null)
+ handlerEventGodDelete(
+ eventGodDelete.EventData.EventID,
+ eventGodDelete.QueryData.QueryID,
+ Utils.BytesToString(
+ eventGodDelete.QueryData.QueryText),
+ eventGodDelete.QueryData.QueryFlags,
+ eventGodDelete.QueryData.QueryStart,
+ this);
+ break;
- public void SendJoinGroupReply(UUID groupID, bool success)
- {
- JoinGroupReplyPacket p = (JoinGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.JoinGroupReply);
+ case PacketType.EventNotificationAddRequest:
+ EventNotificationAddRequestPacket eventNotificationAdd =
+ (EventNotificationAddRequestPacket)Pack;
- p.AgentData = new JoinGroupReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = AgentId;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (eventNotificationAdd.AgentData.SessionID != SessionId ||
+ eventNotificationAdd.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- p.GroupData = new JoinGroupReplyPacket.GroupDataBlock();
- p.GroupData.GroupID = groupID;
- p.GroupData.Success = success;
+ EventNotificationAddRequest handlerEventNotificationAddRequest = OnEventNotificationAddRequest;
+ if (handlerEventNotificationAddRequest != null)
+ handlerEventNotificationAddRequest(
+ eventNotificationAdd.EventData.EventID, this);
+ break;
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ case PacketType.EventNotificationRemoveRequest:
+ EventNotificationRemoveRequestPacket eventNotificationRemove =
+ (EventNotificationRemoveRequestPacket)Pack;
- public void SendEjectGroupMemberReply(UUID agentID, UUID groupID, bool success)
- {
- EjectGroupMemberReplyPacket p = (EjectGroupMemberReplyPacket)PacketPool.Instance.GetPacket(PacketType.EjectGroupMemberReply);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (eventNotificationRemove.AgentData.SessionID != SessionId ||
+ eventNotificationRemove.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- p.AgentData = new EjectGroupMemberReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = agentID;
+ EventNotificationRemoveRequest handlerEventNotificationRemoveRequest = OnEventNotificationRemoveRequest;
+ if (handlerEventNotificationRemoveRequest != null)
+ handlerEventNotificationRemoveRequest(
+ eventNotificationRemove.EventData.EventID, this);
+ break;
- p.GroupData = new EjectGroupMemberReplyPacket.GroupDataBlock();
- p.GroupData.GroupID = groupID;
+ case PacketType.RetrieveInstantMessages:
+ RetrieveInstantMessagesPacket rimpInstantMessagePack = (RetrieveInstantMessagesPacket)Pack;
- p.EjectData = new EjectGroupMemberReplyPacket.EjectDataBlock();
- p.EjectData.Success = success;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (rimpInstantMessagePack.AgentData.SessionID != SessionId ||
+ rimpInstantMessagePack.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ RetrieveInstantMessages handlerRetrieveInstantMessages = OnRetrieveInstantMessages;
+ if (handlerRetrieveInstantMessages != null)
+ handlerRetrieveInstantMessages(this);
+ break;
- public void SendLeaveGroupReply(UUID groupID, bool success)
- {
- LeaveGroupReplyPacket p = (LeaveGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.LeaveGroupReply);
+ case PacketType.PickDelete:
+ PickDeletePacket pickDelete =
+ (PickDeletePacket)Pack;
- p.AgentData = new LeaveGroupReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = AgentId;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (pickDelete.AgentData.SessionID != SessionId ||
+ pickDelete.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- p.GroupData = new LeaveGroupReplyPacket.GroupDataBlock();
- p.GroupData.GroupID = groupID;
- p.GroupData.Success = success;
+ PickDelete handlerPickDelete = OnPickDelete;
+ if (handlerPickDelete != null)
+ handlerPickDelete(this, pickDelete.Data.PickID);
+ break;
+ case PacketType.PickGodDelete:
+ PickGodDeletePacket pickGodDelete =
+ (PickGodDeletePacket)Pack;
- OutPacket(p, ThrottleOutPacketType.Task);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (pickGodDelete.AgentData.SessionID != SessionId ||
+ pickGodDelete.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- public void SendAvatarClassifiedReply(UUID targetID, UUID[] classifiedID, string[] name)
- {
- if (classifiedID.Length != name.Length)
- return;
+ PickGodDelete handlerPickGodDelete = OnPickGodDelete;
+ if (handlerPickGodDelete != null)
+ handlerPickGodDelete(this,
+ pickGodDelete.AgentData.AgentID,
+ pickGodDelete.Data.PickID,
+ pickGodDelete.Data.QueryID);
+ break;
+ case PacketType.PickInfoUpdate:
+ PickInfoUpdatePacket pickInfoUpdate =
+ (PickInfoUpdatePacket)Pack;
- AvatarClassifiedReplyPacket ac =
- (AvatarClassifiedReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarClassifiedReply);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (pickInfoUpdate.AgentData.SessionID != SessionId ||
+ pickInfoUpdate.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- ac.AgentData = new AvatarClassifiedReplyPacket.AgentDataBlock();
- ac.AgentData.AgentID = AgentId;
- ac.AgentData.TargetID = targetID;
+ PickInfoUpdate handlerPickInfoUpdate = OnPickInfoUpdate;
+ if (handlerPickInfoUpdate != null)
+ handlerPickInfoUpdate(this,
+ pickInfoUpdate.Data.PickID,
+ pickInfoUpdate.Data.CreatorID,
+ pickInfoUpdate.Data.TopPick,
+ Utils.BytesToString(pickInfoUpdate.Data.Name),
+ Utils.BytesToString(pickInfoUpdate.Data.Desc),
+ pickInfoUpdate.Data.SnapshotID,
+ pickInfoUpdate.Data.SortOrder,
+ pickInfoUpdate.Data.Enabled);
+ break;
+ case PacketType.AvatarNotesUpdate:
+ AvatarNotesUpdatePacket avatarNotesUpdate =
+ (AvatarNotesUpdatePacket)Pack;
- ac.Data = new AvatarClassifiedReplyPacket.DataBlock[classifiedID.Length];
- int i;
- for (i = 0 ; i < classifiedID.Length ; i++)
- {
- ac.Data[i].ClassifiedID = classifiedID[i];
- ac.Data[i].Name = Utils.StringToBytes(name[i]);
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (avatarNotesUpdate.AgentData.SessionID != SessionId ||
+ avatarNotesUpdate.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- OutPacket(ac, ThrottleOutPacketType.Task);
- }
+ AvatarNotesUpdate handlerAvatarNotesUpdate = OnAvatarNotesUpdate;
+ if (handlerAvatarNotesUpdate != null)
+ handlerAvatarNotesUpdate(this,
+ avatarNotesUpdate.Data.TargetID,
+ Utils.BytesToString(avatarNotesUpdate.Data.Notes));
+ break;
- public void SendClassifiedInfoReply(UUID classifiedID, UUID creatorID, uint creationDate, uint expirationDate, uint category, string name, string description, UUID parcelID, uint parentEstate, UUID snapshotID, string simName, Vector3 globalPos, string parcelName, byte classifiedFlags, int price)
- {
- ClassifiedInfoReplyPacket cr =
- (ClassifiedInfoReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.ClassifiedInfoReply);
+// case PacketType.AvatarInterestsUpdate:
+// AvatarInterestsUpdatePacket avatarInterestUpdate =
+// (AvatarInterestsUpdatePacket)Pack;
+//
+// break;
- cr.AgentData = new ClassifiedInfoReplyPacket.AgentDataBlock();
- cr.AgentData.AgentID = AgentId;
+ case PacketType.PlacesQuery:
+ PlacesQueryPacket placesQueryPacket =
+ (PlacesQueryPacket)Pack;
- cr.Data = new ClassifiedInfoReplyPacket.DataBlock();
- cr.Data.ClassifiedID = classifiedID;
- cr.Data.CreatorID = creatorID;
- cr.Data.CreationDate = creationDate;
- cr.Data.ExpirationDate = expirationDate;
- cr.Data.Category = category;
- cr.Data.Name = Utils.StringToBytes(name);
- cr.Data.Desc = Utils.StringToBytes(description);
- cr.Data.ParcelID = parcelID;
- cr.Data.ParentEstate = parentEstate;
- cr.Data.SnapshotID = snapshotID;
- cr.Data.SimName = Utils.StringToBytes(simName);
- cr.Data.PosGlobal = new Vector3d(globalPos);
- cr.Data.ParcelName = Utils.StringToBytes(parcelName);
- cr.Data.ClassifiedFlags = classifiedFlags;
- cr.Data.PriceForListing = price;
+ PlacesQuery handlerPlacesQuery = OnPlacesQuery;
- OutPacket(cr, ThrottleOutPacketType.Task);
- }
+ if (handlerPlacesQuery != null)
+ handlerPlacesQuery(placesQueryPacket.AgentData.QueryID,
+ placesQueryPacket.TransactionData.TransactionID,
+ Utils.BytesToString(
+ placesQueryPacket.QueryData.QueryText),
+ placesQueryPacket.QueryData.QueryFlags,
+ (byte)placesQueryPacket.QueryData.Category,
+ Utils.BytesToString(
+ placesQueryPacket.QueryData.SimName),
+ this);
+ break;
+ default:
+ m_log.Warn("[CLIENT]: unhandled packet " + Pack);
+ break;
- public void SendAgentDropGroup(UUID groupID)
- {
- AgentDropGroupPacket dg =
- (AgentDropGroupPacket)PacketPool.Instance.GetPacket(
- PacketType.AgentDropGroup);
+ #endregion
+ }
- dg.AgentData = new AgentDropGroupPacket.AgentDataBlock();
- dg.AgentData.AgentID = AgentId;
- dg.AgentData.GroupID = groupID;
+ PacketPool.Instance.ReturnPacket(Pack);
- OutPacket(dg, ThrottleOutPacketType.Task);
}
- public void SendAvatarNotesReply(UUID targetID, string text)
+ private static PrimitiveBaseShape GetShapeFromAddPacket(ObjectAddPacket addPacket)
{
- AvatarNotesReplyPacket an =
- (AvatarNotesReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarNotesReply);
+ PrimitiveBaseShape shape = new PrimitiveBaseShape();
- an.AgentData = new AvatarNotesReplyPacket.AgentDataBlock();
- an.AgentData.AgentID = AgentId;
+ shape.PCode = addPacket.ObjectData.PCode;
+ shape.State = addPacket.ObjectData.State;
+ shape.PathBegin = addPacket.ObjectData.PathBegin;
+ shape.PathEnd = addPacket.ObjectData.PathEnd;
+ shape.PathScaleX = addPacket.ObjectData.PathScaleX;
+ shape.PathScaleY = addPacket.ObjectData.PathScaleY;
+ shape.PathShearX = addPacket.ObjectData.PathShearX;
+ shape.PathShearY = addPacket.ObjectData.PathShearY;
+ shape.PathSkew = addPacket.ObjectData.PathSkew;
+ shape.ProfileBegin = addPacket.ObjectData.ProfileBegin;
+ shape.ProfileEnd = addPacket.ObjectData.ProfileEnd;
+ shape.Scale = addPacket.ObjectData.Scale;
+ shape.PathCurve = addPacket.ObjectData.PathCurve;
+ shape.ProfileCurve = addPacket.ObjectData.ProfileCurve;
+ shape.ProfileHollow = addPacket.ObjectData.ProfileHollow;
+ shape.PathRadiusOffset = addPacket.ObjectData.PathRadiusOffset;
+ shape.PathRevolutions = addPacket.ObjectData.PathRevolutions;
+ shape.PathTaperX = addPacket.ObjectData.PathTaperX;
+ shape.PathTaperY = addPacket.ObjectData.PathTaperY;
+ shape.PathTwist = addPacket.ObjectData.PathTwist;
+ shape.PathTwistBegin = addPacket.ObjectData.PathTwistBegin;
+ Primitive.TextureEntry ntex = new Primitive.TextureEntry(new UUID("89556747-24cb-43ed-920b-47caed15465f"));
+ shape.TextureEntry = ntex.GetBytes();
+ //shape.Textures = ntex;
+ return shape;
+ }
+
+ public ClientInfo GetClientInfo()
+ {
+ ClientInfo info = m_udpClient.GetClientInfo();
- an.Data = new AvatarNotesReplyPacket.DataBlock();
- an.Data.TargetID = targetID;
- an.Data.Notes = Utils.StringToBytes(text);
+ info.userEP = m_userEndPoint;
+ info.proxyEP = null;
+ info.agentcircuit = new sAgentCircuitData(RequestClientInfo());
- OutPacket(an, ThrottleOutPacketType.Task);
+ return info;
}
- public void SendAvatarPicksReply(UUID targetID, Dictionary picks)
+ public EndPoint GetClientEP()
{
- AvatarPicksReplyPacket ap =
- (AvatarPicksReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarPicksReply);
+ return m_userEndPoint;
+ }
- ap.AgentData = new AvatarPicksReplyPacket.AgentDataBlock();
- ap.AgentData.AgentID = AgentId;
- ap.AgentData.TargetID = targetID;
+ public void SetClientInfo(ClientInfo info)
+ {
+ m_udpClient.SetClientInfo(info);
+ }
- ap.Data = new AvatarPicksReplyPacket.DataBlock[picks.Count];
+ #region Media Parcel Members
- int i = 0;
- foreach (KeyValuePair pick in picks)
- {
- ap.Data[i] = new AvatarPicksReplyPacket.DataBlock();
- ap.Data[i].PickID = pick.Key;
- ap.Data[i].PickName = Utils.StringToBytes(pick.Value);
- i++;
- }
+ public void SendParcelMediaCommand(uint flags, ParcelMediaCommandEnum command, float time)
+ {
+ ParcelMediaCommandMessagePacket commandMessagePacket = new ParcelMediaCommandMessagePacket();
+ commandMessagePacket.CommandBlock.Flags = flags;
+ commandMessagePacket.CommandBlock.Command =(uint) command;
+ commandMessagePacket.CommandBlock.Time = time;
- OutPacket(ap, ThrottleOutPacketType.Task);
+ OutPacket(commandMessagePacket, ThrottleOutPacketType.Unknown);
}
- public void SendAvatarClassifiedReply(UUID targetID, Dictionary classifieds)
+ public void SendParcelMediaUpdate(string mediaUrl, UUID mediaTextureID,
+ byte autoScale, string mediaType, string mediaDesc, int mediaWidth, int mediaHeight,
+ byte mediaLoop)
{
- AvatarClassifiedReplyPacket ac =
- (AvatarClassifiedReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarClassifiedReply);
-
- ac.AgentData = new AvatarClassifiedReplyPacket.AgentDataBlock();
- ac.AgentData.AgentID = AgentId;
- ac.AgentData.TargetID = targetID;
-
- ac.Data = new AvatarClassifiedReplyPacket.DataBlock[classifieds.Count];
+ ParcelMediaUpdatePacket updatePacket = new ParcelMediaUpdatePacket();
+ updatePacket.DataBlock.MediaURL = Utils.StringToBytes(mediaUrl);
+ updatePacket.DataBlock.MediaID = mediaTextureID;
+ updatePacket.DataBlock.MediaAutoScale = autoScale;
- int i = 0;
- foreach (KeyValuePair classified in classifieds)
- {
- ac.Data[i] = new AvatarClassifiedReplyPacket.DataBlock();
- ac.Data[i].ClassifiedID = classified.Key;
- ac.Data[i].Name = Utils.StringToBytes(classified.Value);
- i++;
- }
+ updatePacket.DataBlockExtended.MediaType = Utils.StringToBytes(mediaType);
+ updatePacket.DataBlockExtended.MediaDesc = Utils.StringToBytes(mediaDesc);
+ updatePacket.DataBlockExtended.MediaWidth = mediaWidth;
+ updatePacket.DataBlockExtended.MediaHeight = mediaHeight;
+ updatePacket.DataBlockExtended.MediaLoop = mediaLoop;
- OutPacket(ac, ThrottleOutPacketType.Task);
+ OutPacket(updatePacket, ThrottleOutPacketType.Unknown);
}
- public void SendParcelDwellReply(int localID, UUID parcelID, float dwell)
- {
- ParcelDwellReplyPacket pd =
- (ParcelDwellReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.ParcelDwellReply);
+ #endregion
- pd.AgentData = new ParcelDwellReplyPacket.AgentDataBlock();
- pd.AgentData.AgentID = AgentId;
+ #region Camera
- pd.Data = new ParcelDwellReplyPacket.DataBlock();
- pd.Data.LocalID = localID;
- pd.Data.ParcelID = parcelID;
- pd.Data.Dwell = dwell;
+ public void SendSetFollowCamProperties (UUID objectID, SortedDictionary parameters)
+ {
+ SetFollowCamPropertiesPacket packet = (SetFollowCamPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.SetFollowCamProperties);
+ packet.ObjectData.ObjectID = objectID;
+ SetFollowCamPropertiesPacket.CameraPropertyBlock[] camPropBlock = new SetFollowCamPropertiesPacket.CameraPropertyBlock[parameters.Count];
+ uint idx = 0;
+ foreach (KeyValuePair pair in parameters)
+ {
+ SetFollowCamPropertiesPacket.CameraPropertyBlock block = new SetFollowCamPropertiesPacket.CameraPropertyBlock();
+ block.Type = pair.Key;
+ block.Value = pair.Value;
- OutPacket(pd, ThrottleOutPacketType.Land);
+ camPropBlock[idx++] = block;
+ }
+ packet.CameraProperty = camPropBlock;
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendUserInfoReply(bool imViaEmail, bool visible, string email)
+ public void SendClearFollowCamProperties (UUID objectID)
{
- UserInfoReplyPacket ur =
- (UserInfoReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.UserInfoReply);
-
- string Visible = "hidden";
- if (visible)
- Visible = "default";
+ ClearFollowCamPropertiesPacket packet = (ClearFollowCamPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ClearFollowCamProperties);
+ packet.ObjectData.ObjectID = objectID;
+ OutPacket(packet, ThrottleOutPacketType.Task);
+ }
- ur.AgentData = new UserInfoReplyPacket.AgentDataBlock();
- ur.AgentData.AgentID = AgentId;
+ #endregion
- ur.UserData = new UserInfoReplyPacket.UserDataBlock();
- ur.UserData.IMViaEMail = imViaEmail;
- ur.UserData.DirectoryVisibility = Utils.StringToBytes(Visible);
- ur.UserData.EMail = Utils.StringToBytes(email);
+ public void SetClientOption(string option, string value)
+ {
+ switch (option)
+ {
+ default:
+ break;
+ }
+ }
- OutPacket(ur, ThrottleOutPacketType.Task);
+ public string GetClientOption(string option)
+ {
+ switch (option)
+ {
+ default:
+ break;
+ }
+ return string.Empty;
}
public void KillEndDone()
{
- KillPacket kp = new KillPacket();
- OutPacket(kp, ThrottleOutPacketType.Task | ThrottleOutPacketType.LowPriority);
+ m_udpClient.Shutdown();
}
#region IClientCore
@@ -10767,13 +10324,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
}
}
- protected virtual void RegisterInterfaces()
- {
- RegisterInterface(this);
- RegisterInterface(this);
- RegisterInterface(this);
- }
-
public bool TryGet(out T iface)
{
if (m_clientInterfaces.ContainsKey(typeof(T)))
@@ -10821,78 +10371,14 @@ namespace OpenSim.Region.ClientStack.LindenUDP
}
}
- public void SendCreateGroupReply(UUID groupID, bool success, string message)
- {
- CreateGroupReplyPacket createGroupReply = (CreateGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.CreateGroupReply);
-
- createGroupReply.AgentData =
- new CreateGroupReplyPacket.AgentDataBlock();
- createGroupReply.ReplyData =
- new CreateGroupReplyPacket.ReplyDataBlock();
-
- createGroupReply.AgentData.AgentID = AgentId;
- createGroupReply.ReplyData.GroupID = groupID;
-
- createGroupReply.ReplyData.Success = success;
- createGroupReply.ReplyData.Message = Utils.StringToBytes(message);
- OutPacket(createGroupReply, ThrottleOutPacketType.Task);
- }
-
- public void SendUseCachedMuteList()
- {
- UseCachedMuteListPacket useCachedMuteList = (UseCachedMuteListPacket)PacketPool.Instance.GetPacket(PacketType.UseCachedMuteList);
-
- useCachedMuteList.AgentData = new UseCachedMuteListPacket.AgentDataBlock();
- useCachedMuteList.AgentData.AgentID = AgentId;
-
- OutPacket(useCachedMuteList, ThrottleOutPacketType.Task);
- }
-
- public void SendMuteListUpdate(string filename)
- {
- MuteListUpdatePacket muteListUpdate = (MuteListUpdatePacket)PacketPool.Instance.GetPacket(PacketType.MuteListUpdate);
-
- muteListUpdate.MuteData = new MuteListUpdatePacket.MuteDataBlock();
- muteListUpdate.MuteData.AgentID = AgentId;
- muteListUpdate.MuteData.Filename = Utils.StringToBytes(filename);
-
- OutPacket(muteListUpdate, ThrottleOutPacketType.Task);
- }
-
- public void SendPickInfoReply(UUID pickID,UUID creatorID, bool topPick, UUID parcelID, string name, string desc, UUID snapshotID, string user, string originalName, string simName, Vector3 posGlobal, int sortOrder, bool enabled)
- {
- PickInfoReplyPacket pickInfoReply = (PickInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.PickInfoReply);
-
- pickInfoReply.AgentData = new PickInfoReplyPacket.AgentDataBlock();
- pickInfoReply.AgentData.AgentID = AgentId;
-
- pickInfoReply.Data = new PickInfoReplyPacket.DataBlock();
- pickInfoReply.Data.PickID = pickID;
- pickInfoReply.Data.CreatorID = creatorID;
- pickInfoReply.Data.TopPick = topPick;
- pickInfoReply.Data.ParcelID = parcelID;
- pickInfoReply.Data.Name = Utils.StringToBytes(name);
- pickInfoReply.Data.Desc = Utils.StringToBytes(desc);
- pickInfoReply.Data.SnapshotID = snapshotID;
- pickInfoReply.Data.User = Utils.StringToBytes(user);
- pickInfoReply.Data.OriginalName = Utils.StringToBytes(originalName);
- pickInfoReply.Data.SimName = Utils.StringToBytes(simName);
- pickInfoReply.Data.PosGlobal = new Vector3d(posGlobal);
- pickInfoReply.Data.SortOrder = sortOrder;
- pickInfoReply.Data.Enabled = enabled;
-
- OutPacket(pickInfoReply, ThrottleOutPacketType.Task);
- }
-
public string Report()
{
- LLPacketHandler handler = (LLPacketHandler) m_PacketHandler;
- return handler.PacketQueue.GetStats();
+ return m_udpClient.GetStats();
}
public string XReport(string uptime, string version)
{
- return "";
+ return String.Empty;
}
public void MakeAssetRequest(TransferRequestPacket transferRequest)
@@ -10981,7 +10467,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
return numPackets;
}
-
#region IClientIPEndpoint Members
public IPAddress EndPoint
--
cgit v1.1
From e7c877407f2a72a9519eb53debca5aeef20cded9 Mon Sep 17 00:00:00 2001
From: John Hurliman
Date: Tue, 6 Oct 2009 02:38:00 -0700
Subject: * Continued work on the new LLUDP implementation. Appears to be
functioning, although not everything is reimplemented yet * Replaced logic in
ThreadTracker with a call to System.Diagnostics that does the same thing *
Added Util.StringToBytes256() and Util.StringToBytes1024() to clamp output at
byte[256] and byte[1024], respectively * Fixed formatting for a
MySQLAssetData error logging line
---
.../Region/ClientStack/LindenUDP/LLClientView.cs | 284 +++++++++------------
1 file changed, 117 insertions(+), 167 deletions(-)
(limited to 'OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs')
diff --git a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
index 31cd53f..767020f 100644
--- a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
@@ -70,28 +70,23 @@ namespace OpenSim.Region.ClientStack.LindenUDP
private readonly LLUDPServer m_udpServer;
private readonly LLUDPClient m_udpClient;
private readonly UUID m_sessionId;
- private readonly UUID m_secureSessionId = UUID.Zero;
+ private readonly UUID m_secureSessionId;
private readonly UUID m_agentId;
private readonly uint m_circuitCode;
- private readonly byte[] m_channelVersion = Utils.StringToBytes("OpenSimulator Server"); // Dummy value needed by libSL
+ private readonly byte[] m_channelVersion = Utils.EmptyBytes;
private readonly Dictionary m_defaultAnimations = new Dictionary();
private readonly IGroupsModule m_GroupsModule;
- private int m_debugPacketLevel;
private int m_cachedTextureSerial;
- private Timer m_clientPingTimer;
private Timer m_avatarTerseUpdateTimer;
private List m_avatarTerseUpdates = new List();
private Timer m_primTerseUpdateTimer;
private List m_primTerseUpdates = new List();
private Timer m_primFullUpdateTimer;
private List m_primFullUpdates = new List();
- private bool m_clientBlocked;
- private int m_probesWithNoIngressPackets;
private int m_moneyBalance;
private int m_animationSequenceNumber = 1;
private bool m_SendLogoutPacketWhenClosing = true;
- private int m_inPacketsChecked;
private AgentUpdateArgs lastarg;
private bool m_IsActive = true;
@@ -170,58 +165,72 @@ namespace OpenSim.Region.ClientStack.LindenUDP
RegisterInterface(this);
RegisterInterface(this);
RegisterInterface(this);
- m_GroupsModule = scene.RequestModuleInterface();
-
- m_moneyBalance = 1000;
-
- m_channelVersion = Utils.StringToBytes(scene.GetSimulatorVersion());
-
+
InitDefaultAnimations();
m_scene = scene;
- //m_assetCache = assetCache;
-
m_assetService = m_scene.RequestModuleInterface();
-
- m_udpServer = udpServer;
- m_udpClient = udpClient;
-
+ m_GroupsModule = scene.RequestModuleInterface();
+ m_imageManager = new LLImageManager(this, m_assetService, Scene.RequestModuleInterface());
+ m_channelVersion = Utils.StringToBytes(scene.GetSimulatorVersion());
m_agentId = agentId;
m_sessionId = sessionId;
+ m_secureSessionId = sessionInfo.LoginInfo.SecureSession;
m_circuitCode = circuitCode;
-
m_userEndPoint = remoteEP;
-
m_firstName = sessionInfo.LoginInfo.First;
m_lastName = sessionInfo.LoginInfo.Last;
m_startpos = sessionInfo.LoginInfo.StartPos;
+ m_moneyBalance = 1000;
- if (sessionInfo.LoginInfo.SecureSession != UUID.Zero)
- {
- m_secureSessionId = sessionInfo.LoginInfo.SecureSession;
- }
-
- // While working on this, the BlockingQueue had me fooled for a bit.
- // The Blocking queue causes the thread to stop until there's something
- // in it to process. It's an on-purpose threadlock though because
- // without it, the clientloop will suck up all sim resources.
-
- //m_PacketHandler = new LLPacketHandler(this, m_networkServer, userSettings);
- //m_PacketHandler.SynchronizeClient = SynchronizeClient;
- //m_PacketHandler.OnPacketStats += PopulateStats;
- //m_PacketHandler.OnQueueEmpty += HandleQueueEmpty;
+ m_udpServer = udpServer;
+ m_udpClient = udpClient;
+ m_udpClient.OnQueueEmpty += HandleQueueEmpty;
+ // FIXME: Implement this
+ //m_udpClient.OnPacketStats += PopulateStats;
RegisterLocalPacketHandlers();
- m_imageManager = new LLImageManager(this, m_assetService, Scene.RequestModuleInterface());
}
- public void SetDebugPacketLevel(int newDebugPacketLevel)
+ public void SetDebugPacketLevel(int newDebug)
{
- m_debugPacketLevel = newDebugPacketLevel;
}
#region Client Methods
+ ///
+ /// Close down the client view. This *must* be the last method called, since the last #
+ /// statement of CloseCleanup() aborts the thread.
+ ///
+ ///
+ public void Close(bool shutdownCircuit)
+ {
+ m_log.DebugFormat(
+ "[CLIENT]: Close has been called with shutdownCircuit = {0} for {1} attached to scene {2}",
+ shutdownCircuit, Name, m_scene.RegionInfo.RegionName);
+
+ if (m_imageManager != null)
+ m_imageManager.Close();
+
+ if (m_udpServer != null)
+ m_udpServer.Flush();
+
+ // raise an event on the packet server to Shutdown the circuit
+ // Now, if we raise the event then the packet server will call this method itself, so don't try cleanup
+ // here otherwise we'll end up calling it twice.
+ // FIXME: In truth, I might be wrong but this whole business of calling this method twice (with different args) looks
+ // horribly tangly. Hopefully it should be possible to greatly simplify it.
+ if (shutdownCircuit)
+ {
+ if (OnConnectionClosed != null)
+ OnConnectionClosed(this);
+ }
+ else
+ {
+ CloseCleanup(shutdownCircuit);
+ }
+ }
+
private void CloseCleanup(bool shutdownCircuit)
{
m_scene.RemoveClient(AgentId);
@@ -236,9 +245,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
Thread.Sleep(2000);
// Shut down timers. Thread Context of this method is murky. Lock all timers
- if (m_clientPingTimer.Enabled)
- lock (m_clientPingTimer)
- m_clientPingTimer.Stop();
if (m_avatarTerseUpdateTimer.Enabled)
lock (m_avatarTerseUpdateTimer)
m_avatarTerseUpdateTimer.Stop();
@@ -271,43 +277,21 @@ namespace OpenSim.Region.ClientStack.LindenUDP
// of the client thread regardless of where Close() is called.
KillEndDone();
}
-
- Terminate();
- }
- ///
- /// Close down the client view. This *must* be the last method called, since the last #
- /// statement of CloseCleanup() aborts the thread.
- ///
- ///
- public void Close(bool shutdownCircuit)
- {
- m_clientPingTimer.Enabled = false;
+ IsActive = false;
- m_log.DebugFormat(
- "[CLIENT]: Close has been called with shutdownCircuit = {0} for {1} attached to scene {2}",
- shutdownCircuit, Name, m_scene.RegionInfo.RegionName);
+ m_avatarTerseUpdateTimer.Close();
+ m_primTerseUpdateTimer.Close();
+ m_primFullUpdateTimer.Close();
- if (m_imageManager != null)
- m_imageManager.Close();
+ //m_udpServer.OnPacketStats -= PopulateStats;
+ m_udpClient.Shutdown();
- if (m_udpServer != null)
- m_udpServer.Flush();
+ // wait for thread stoped
+ // m_clientThread.Join();
- // raise an event on the packet server to Shutdown the circuit
- // Now, if we raise the event then the packet server will call this method itself, so don't try cleanup
- // here otherwise we'll end up calling it twice.
- // FIXME: In truth, I might be wrong but this whole business of calling this method twice (with different args) looks
- // horribly tangly. Hopefully it should be possible to greatly simplify it.
- if (shutdownCircuit)
- {
- if (OnConnectionClosed != null)
- OnConnectionClosed(this);
- }
- else
- {
- CloseCleanup(shutdownCircuit);
- }
+ // delete circuit code
+ //m_networkServer.CloseClient(this);
}
public void Kick(string message)
@@ -329,10 +313,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public void Stop()
{
// Shut down timers. Thread Context is Murky, lock all timers!
- if (m_clientPingTimer.Enabled)
- lock (m_clientPingTimer)
- m_clientPingTimer.Stop();
-
if (m_avatarTerseUpdateTimer.Enabled)
lock (m_avatarTerseUpdateTimer)
m_avatarTerseUpdateTimer.Stop();
@@ -346,25 +326,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_primFullUpdateTimer.Stop();
}
- private void Terminate()
- {
- IsActive = false;
-
- m_clientPingTimer.Close();
- m_avatarTerseUpdateTimer.Close();
- m_primTerseUpdateTimer.Close();
- m_primFullUpdateTimer.Close();
-
- //m_udpServer.OnPacketStats -= PopulateStats;
- m_udpClient.Shutdown();
-
- // wait for thread stoped
- // m_clientThread.Join();
-
- // delete circuit code
- //m_networkServer.CloseClient(this);
- }
-
#endregion Client Methods
#region Packet Handling
@@ -452,7 +413,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
return result;
}
- protected void DebugPacket(string direction, Packet packet)
+ /*protected void DebugPacket(string direction, Packet packet)
{
string info;
@@ -478,7 +439,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
}
Console.WriteLine(m_circuitCode + ":" + direction + ": " + info);
- }
+ }*/
#endregion Packet Handling
@@ -490,8 +451,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
///
protected virtual void InitNewClient()
{
- //this.UploadAssets = new AgentAssetUpload(this, m_assetCache, m_inventoryCache);
-
m_avatarTerseUpdateTimer = new Timer(m_avatarTerseUpdateRate);
m_avatarTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessAvatarTerseUpdates);
m_avatarTerseUpdateTimer.AutoReset = false;
@@ -511,11 +470,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public virtual void Start()
{
- m_clientThread = new Thread(RunUserSession);
- m_clientThread.Name = "ClientThread";
- m_clientThread.IsBackground = true;
- m_clientThread.Start();
- ThreadTracker.Add(m_clientThread);
+ // This sets up all the timers
+ InitNewClient();
}
///
@@ -523,14 +479,9 @@ namespace OpenSim.Region.ClientStack.LindenUDP
///
protected void RunUserSession()
{
- //tell this thread we are using the culture set up for the sim (currently hardcoded to en_US)
- //otherwise it will override this and use the system default
- Culture.SetCurrentCulture();
-
try
{
- // This sets up all the timers
- InitNewClient();
+
}
catch (Exception e)
{
@@ -1373,8 +1324,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public void SendStartPingCheck(byte seq)
{
StartPingCheckPacket pc = (StartPingCheckPacket)PacketPool.Instance.GetPacket(PacketType.StartPingCheck);
- pc.PingID.PingID = seq;
pc.Header.Reliable = false;
+
+ OutgoingPacket oldestPacket = m_udpClient.NeedAcks.GetOldest();
+
+ pc.PingID.PingID = seq;
+ pc.PingID.OldestUnacked = (oldestPacket != null) ? oldestPacket.SequenceNumber : 0;
+
OutPacket(pc, ThrottleOutPacketType.Unknown);
}
@@ -1450,12 +1406,12 @@ namespace OpenSim.Region.ClientStack.LindenUDP
descend.ItemData[i].AssetID = item.AssetID;
descend.ItemData[i].CreatorID = item.CreatorIdAsUuid;
descend.ItemData[i].BaseMask = item.BasePermissions;
- descend.ItemData[i].Description = LLUtil.StringToPacketBytes(item.Description);
+ descend.ItemData[i].Description = Util.StringToBytes256(item.Description);
descend.ItemData[i].EveryoneMask = item.EveryOnePermissions;
descend.ItemData[i].OwnerMask = item.CurrentPermissions;
descend.ItemData[i].FolderID = item.Folder;
descend.ItemData[i].InvType = (sbyte)item.InvType;
- descend.ItemData[i].Name = LLUtil.StringToPacketBytes(item.Name);
+ descend.ItemData[i].Name = Util.StringToBytes256(item.Name);
descend.ItemData[i].NextOwnerMask = item.NextPermissions;
descend.ItemData[i].OwnerID = item.Owner;
descend.ItemData[i].Type = (sbyte)item.AssetType;
@@ -1536,7 +1492,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
{
descend.FolderData[i] = new InventoryDescendentsPacket.FolderDataBlock();
descend.FolderData[i].FolderID = folder.ID;
- descend.FolderData[i].Name = LLUtil.StringToPacketBytes(folder.Name);
+ descend.FolderData[i].Name = Util.StringToBytes256(folder.Name);
descend.FolderData[i].ParentID = folder.ParentID;
descend.FolderData[i].Type = (sbyte)folder.Type;
@@ -1651,11 +1607,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
inventoryReply.InventoryData[0].BaseMask = item.BasePermissions;
inventoryReply.InventoryData[0].CreationDate = item.CreationDate;
- inventoryReply.InventoryData[0].Description = LLUtil.StringToPacketBytes(item.Description);
+ inventoryReply.InventoryData[0].Description = Util.StringToBytes256(item.Description);
inventoryReply.InventoryData[0].EveryoneMask = item.EveryOnePermissions;
inventoryReply.InventoryData[0].FolderID = item.Folder;
inventoryReply.InventoryData[0].InvType = (sbyte)item.InvType;
- inventoryReply.InventoryData[0].Name = LLUtil.StringToPacketBytes(item.Name);
+ inventoryReply.InventoryData[0].Name = Util.StringToBytes256(item.Name);
inventoryReply.InventoryData[0].NextOwnerMask = item.NextPermissions;
inventoryReply.InventoryData[0].OwnerID = item.Owner;
inventoryReply.InventoryData[0].OwnerMask = item.CurrentPermissions;
@@ -1780,7 +1736,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
folderBlock.FolderID = folder.ID;
folderBlock.ParentID = folder.ParentID;
folderBlock.Type = -1;
- folderBlock.Name = LLUtil.StringToPacketBytes(folder.Name);
+ folderBlock.Name = Util.StringToBytes256(folder.Name);
return folderBlock;
}
@@ -1798,11 +1754,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
itemBlock.AssetID = item.AssetID;
itemBlock.CreatorID = item.CreatorIdAsUuid;
itemBlock.BaseMask = item.BasePermissions;
- itemBlock.Description = LLUtil.StringToPacketBytes(item.Description);
+ itemBlock.Description = Util.StringToBytes256(item.Description);
itemBlock.EveryoneMask = item.EveryOnePermissions;
itemBlock.FolderID = item.Folder;
itemBlock.InvType = (sbyte)item.InvType;
- itemBlock.Name = LLUtil.StringToPacketBytes(item.Name);
+ itemBlock.Name = Util.StringToBytes256(item.Name);
itemBlock.NextOwnerMask = item.NextPermissions;
itemBlock.OwnerID = item.Owner;
itemBlock.OwnerMask = item.CurrentPermissions;
@@ -1862,11 +1818,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
bulkUpdate.ItemData[0].CreatorID = item.CreatorIdAsUuid;
bulkUpdate.ItemData[0].BaseMask = item.BasePermissions;
bulkUpdate.ItemData[0].CreationDate = item.CreationDate;
- bulkUpdate.ItemData[0].Description = LLUtil.StringToPacketBytes(item.Description);
+ bulkUpdate.ItemData[0].Description = Util.StringToBytes256(item.Description);
bulkUpdate.ItemData[0].EveryoneMask = item.EveryOnePermissions;
bulkUpdate.ItemData[0].FolderID = item.Folder;
bulkUpdate.ItemData[0].InvType = (sbyte)item.InvType;
- bulkUpdate.ItemData[0].Name = LLUtil.StringToPacketBytes(item.Name);
+ bulkUpdate.ItemData[0].Name = Util.StringToBytes256(item.Name);
bulkUpdate.ItemData[0].NextOwnerMask = item.NextPermissions;
bulkUpdate.ItemData[0].OwnerID = item.Owner;
bulkUpdate.ItemData[0].OwnerMask = item.CurrentPermissions;
@@ -1909,11 +1865,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
InventoryReply.InventoryData[0].AssetID = Item.AssetID;
InventoryReply.InventoryData[0].CreatorID = Item.CreatorIdAsUuid;
InventoryReply.InventoryData[0].BaseMask = Item.BasePermissions;
- InventoryReply.InventoryData[0].Description = LLUtil.StringToPacketBytes(Item.Description);
+ InventoryReply.InventoryData[0].Description = Util.StringToBytes256(Item.Description);
InventoryReply.InventoryData[0].EveryoneMask = Item.EveryOnePermissions;
InventoryReply.InventoryData[0].FolderID = Item.Folder;
InventoryReply.InventoryData[0].InvType = (sbyte)Item.InvType;
- InventoryReply.InventoryData[0].Name = LLUtil.StringToPacketBytes(Item.Name);
+ InventoryReply.InventoryData[0].Name = Util.StringToBytes256(Item.Name);
InventoryReply.InventoryData[0].NextOwnerMask = Item.NextPermissions;
InventoryReply.InventoryData[0].OwnerID = Item.Owner;
InventoryReply.InventoryData[0].OwnerMask = Item.CurrentPermissions;
@@ -2080,7 +2036,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
///
///
///
- protected AgentAlertMessagePacket BuildAgentAlertPacket(string message, bool modal)
+ public AgentAlertMessagePacket BuildAgentAlertPacket(string message, bool modal)
{
AgentAlertMessagePacket alertPack = (AgentAlertMessagePacket)PacketPool.Instance.GetPacket(PacketType.AgentAlertMessage);
alertPack.AgentData.AgentID = AgentId;
@@ -3533,7 +3489,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
objectData.FullID = objectID;
objectData.OwnerID = ownerID;
- objectData.Text = LLUtil.StringToPacketBytes(text);
+ objectData.Text = Util.StringToBytes256(text);
objectData.TextColor[0] = color[0];
objectData.TextColor[1] = color[1];
objectData.TextColor[2] = color[2];
@@ -3911,8 +3867,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
objPropDB.SalePrice = SalePrice;
objPropDB.Category = Category;
objPropDB.LastOwnerID = LastOwnerID;
- objPropDB.Name = LLUtil.StringToPacketBytes(ObjectName);
- objPropDB.Description = LLUtil.StringToPacketBytes(Description);
+ objPropDB.Name = Util.StringToBytes256(ObjectName);
+ objPropDB.Description = Util.StringToBytes256(Description);
objPropFamilyPack.ObjectData = objPropDB;
objPropFamilyPack.Header.Zerocoded = true;
OutPacket(objPropFamilyPack, ThrottleOutPacketType.Task);
@@ -3946,11 +3902,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
proper.ObjectData[0].OwnerID = UUID.Zero;
else
proper.ObjectData[0].OwnerID = OwnerUUID;
- proper.ObjectData[0].TouchName = LLUtil.StringToPacketBytes(TouchTitle);
+ proper.ObjectData[0].TouchName = Util.StringToBytes256(TouchTitle);
proper.ObjectData[0].TextureID = TextureID;
- proper.ObjectData[0].SitName = LLUtil.StringToPacketBytes(SitTitle);
- proper.ObjectData[0].Name = LLUtil.StringToPacketBytes(ItemName);
- proper.ObjectData[0].Description = LLUtil.StringToPacketBytes(ItemDescription);
+ proper.ObjectData[0].SitName = Util.StringToBytes256(SitTitle);
+ proper.ObjectData[0].Name = Util.StringToBytes256(ItemName);
+ proper.ObjectData[0].Description = Util.StringToBytes256(ItemDescription);
proper.ObjectData[0].OwnerMask = OwnerMask;
proper.ObjectData[0].NextOwnerMask = NextOwnerMask;
proper.ObjectData[0].GroupMask = GroupMask;
@@ -4191,11 +4147,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
updatePacket.ParcelData.MediaAutoScale = landData.MediaAutoScale;
updatePacket.ParcelData.MediaID = landData.MediaID;
- updatePacket.ParcelData.MediaURL = LLUtil.StringToPacketBytes(landData.MediaURL);
- updatePacket.ParcelData.MusicURL = LLUtil.StringToPacketBytes(landData.MusicURL);
- updatePacket.ParcelData.Name = Utils.StringToBytes(landData.Name);
+ updatePacket.ParcelData.MediaURL = Util.StringToBytes256(landData.MediaURL);
+ updatePacket.ParcelData.MusicURL = Util.StringToBytes256(landData.MusicURL);
+ updatePacket.ParcelData.Name = Util.StringToBytes256(landData.Name);
updatePacket.ParcelData.OtherCleanTime = landData.OtherCleanTime;
- updatePacket.ParcelData.OtherCount = 0; //unemplemented
+ updatePacket.ParcelData.OtherCount = 0; //TODO: Unimplemented
updatePacket.ParcelData.OtherPrims = landData.OtherPrims;
updatePacket.ParcelData.OwnerID = landData.OwnerID;
updatePacket.ParcelData.OwnerPrims = landData.OwnerPrims;
@@ -4203,22 +4159,18 @@ namespace OpenSim.Region.ClientStack.LindenUDP
updatePacket.ParcelData.ParcelPrimBonus = simObjectBonusFactor;
updatePacket.ParcelData.PassHours = landData.PassHours;
updatePacket.ParcelData.PassPrice = landData.PassPrice;
- updatePacket.ParcelData.PublicCount = 0; //unemplemented
+ updatePacket.ParcelData.PublicCount = 0; //TODO: Unimplemented
- updatePacket.ParcelData.RegionDenyAnonymous = ((regionFlags & (uint)RegionFlags.DenyAnonymous) >
- 0);
- updatePacket.ParcelData.RegionDenyIdentified = ((regionFlags & (uint)RegionFlags.DenyIdentified) >
- 0);
- updatePacket.ParcelData.RegionDenyTransacted = ((regionFlags & (uint)RegionFlags.DenyTransacted) >
- 0);
- updatePacket.ParcelData.RegionPushOverride = ((regionFlags & (uint)RegionFlags.RestrictPushObject) >
- 0);
+ updatePacket.ParcelData.RegionDenyAnonymous = (regionFlags & (uint)RegionFlags.DenyAnonymous) > 0;
+ updatePacket.ParcelData.RegionDenyIdentified = (regionFlags & (uint)RegionFlags.DenyIdentified) > 0;
+ updatePacket.ParcelData.RegionDenyTransacted = (regionFlags & (uint)RegionFlags.DenyTransacted) > 0;
+ updatePacket.ParcelData.RegionPushOverride = (regionFlags & (uint)RegionFlags.RestrictPushObject) > 0;
updatePacket.ParcelData.RentPrice = 0;
updatePacket.ParcelData.RequestResult = request_result;
updatePacket.ParcelData.SalePrice = landData.SalePrice;
updatePacket.ParcelData.SelectedPrims = landData.SelectedPrims;
- updatePacket.ParcelData.SelfCount = 0; //unemplemented
+ updatePacket.ParcelData.SelfCount = 0; //TODO: Unimplemented
updatePacket.ParcelData.SequenceID = sequence_id;
if (landData.SimwideArea > 0)
{
@@ -5265,18 +5217,18 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_udpClient.SetThrottles(throttles);
}
+ ///
+ /// Get the current throttles for this client as a packed byte array
+ ///
+ /// Unused
+ ///
public byte[] GetThrottlesPacked(float multiplier)
{
return m_udpClient.GetThrottlesPacked();
}
- public bool IsThrottleEmpty(ThrottleOutPacketType category)
- {
- return m_udpClient.IsThrottleEmpty(category);
- }
-
///
- /// Unused
+ /// Cruft?
///
public virtual void InPacket(object NewPack)
{
@@ -6231,14 +6183,12 @@ namespace OpenSim.Region.ClientStack.LindenUDP
break;
case PacketType.AgentPause:
- m_probesWithNoIngressPackets = 0;
- m_clientBlocked = true;
+ m_udpClient.IsPaused = true;
break;
case PacketType.AgentResume:
- m_probesWithNoIngressPackets = 0;
- m_clientBlocked = false;
- SendStartPingCheck(0);
+ m_udpClient.IsPaused = false;
+ SendStartPingCheck(m_udpClient.CurrentPingSequence++);
break;
@@ -8904,14 +8854,14 @@ namespace OpenSim.Region.ClientStack.LindenUDP
#region unimplemented handlers
case PacketType.StartPingCheck:
- // Send the client the ping response back
- // Pass the same PingID in the matching packet
- // Handled In the packet processing
- //m_log.Debug("[CLIENT]: possibly unhandled StartPingCheck packet");
+ StartPingCheckPacket pingStart = (StartPingCheckPacket)Pack;
+ CompletePingCheckPacket pingComplete = new CompletePingCheckPacket();
+ pingComplete.PingID.PingID = pingStart.PingID.PingID;
+ m_udpServer.SendPacket(m_udpClient, pingComplete, ThrottleOutPacketType.Unknown, false);
break;
+
case PacketType.CompletePingCheck:
- // TODO: Perhaps this should be processed on the Sim to determine whether or not to drop a dead client
- //m_log.Warn("[CLIENT]: unhandled CompletePingCheck packet");
+ // TODO: Do stats tracking or something with these?
break;
case PacketType.ViewerStats:
@@ -10209,14 +10159,14 @@ namespace OpenSim.Region.ClientStack.LindenUDP
return info;
}
- public EndPoint GetClientEP()
+ public void SetClientInfo(ClientInfo info)
{
- return m_userEndPoint;
+ m_udpClient.SetClientInfo(info);
}
- public void SetClientInfo(ClientInfo info)
+ public EndPoint GetClientEP()
{
- m_udpClient.SetClientInfo(info);
+ return m_userEndPoint;
}
#region Media Parcel Members
--
cgit v1.1
From fb19d1ca0a7c6e82c540c4e8d22c82c09b7bec98 Mon Sep 17 00:00:00 2001
From: John Hurliman
Date: Tue, 6 Oct 2009 10:12:59 -0700
Subject: * Try/catch around EndInvoke() when Util.FireAndForget() returns to
catch exceptions thrown in the async method * Added packet stats handling to
the new LLUDP implementation * Attempting to avoid a race condition when
creating a new LLUDPClient
---
OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs | 3 +--
1 file changed, 1 insertion(+), 2 deletions(-)
(limited to 'OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs')
diff --git a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
index 767020f..84e705a 100644
--- a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
@@ -186,8 +186,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_udpServer = udpServer;
m_udpClient = udpClient;
m_udpClient.OnQueueEmpty += HandleQueueEmpty;
- // FIXME: Implement this
- //m_udpClient.OnPacketStats += PopulateStats;
+ m_udpClient.OnPacketStats += PopulateStats;
RegisterLocalPacketHandlers();
}
--
cgit v1.1
From e992ca025571a891333a57012c2cd4419b6581e5 Mon Sep 17 00:00:00 2001
From: Diva Canto
Date: Tue, 6 Oct 2009 15:39:53 -0700
Subject: Rewrote parts of the code that were double-locking different objects.
This is about half of the code base reviewed.
---
.../Region/ClientStack/LindenUDP/LLClientView.cs | 116 ++++++++++++---------
1 file changed, 69 insertions(+), 47 deletions(-)
(limited to 'OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs')
diff --git a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
index 0052729..fe37a08 100644
--- a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
@@ -3122,6 +3122,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
objectData.TextureAnim = textureanim;
}
+ bool doUpdate = false;
lock (m_primFullUpdates)
{
if (m_primFullUpdates.Count == 0)
@@ -3130,8 +3131,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_primFullUpdates.Add(objectData);
if (m_primFullUpdates.Count >= m_primFullUpdatesPerPacket)
- ProcessPrimFullUpdates(this, null);
+ doUpdate = true;
}
+ if (doUpdate)
+ ProcessPrimFullUpdates(this, null);
}
void HandleQueueEmpty(ThrottleOutPacketType queue)
@@ -3152,35 +3155,40 @@ namespace OpenSim.Region.ClientStack.LindenUDP
void ProcessPrimFullUpdates(object sender, ElapsedEventArgs e)
{
+ bool stopTimer = false;
lock (m_primFullUpdates)
{
if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
- {
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
-
- return;
- }
+ stopTimer = true;
+ }
+ if (stopTimer)
+ {
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
+ return;
+ }
- ObjectUpdatePacket outPacket =
- (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
- PacketType.ObjectUpdate);
+ ObjectUpdatePacket outPacket =
+ (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
+ PacketType.ObjectUpdate);
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- int max = m_primFullUpdates.Count;
- if (max > m_primFullUpdatesPerPacket)
- max = m_primFullUpdatesPerPacket;
+ int max = m_primFullUpdates.Count;
+ if (max > m_primFullUpdatesPerPacket)
+ max = m_primFullUpdatesPerPacket;
- int count = 0;
- int size = 0;
+ int count = 0;
+ int size = 0;
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
+ lock (m_primFullUpdates)
+ {
for (count = 0 ; count < max ; count++)
{
int length = 0;
@@ -3204,9 +3212,12 @@ namespace OpenSim.Region.ClientStack.LindenUDP
OutPacket(outPacket, ThrottleOutPacketType.Task | ThrottleOutPacketType.LowPriority);
if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
+ stopTimer = true;
}
+
+ if (stopTimer)
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
}
///
@@ -3225,6 +3236,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
CreatePrimImprovedBlock(localID, position, rotation,
velocity, rotationalvelocity, state);
+ bool doUpdate = false;
lock (m_primTerseUpdates)
{
if (m_primTerseUpdates.Count == 0)
@@ -3233,43 +3245,51 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_primTerseUpdates.Add(objectData);
if (m_primTerseUpdates.Count >= m_primTerseUpdatesPerPacket)
- ProcessPrimTerseUpdates(this, null);
+ doUpdate = true;
}
+ if (doUpdate)
+ ProcessPrimTerseUpdates(this, null);
}
void ProcessPrimTerseUpdates(object sender, ElapsedEventArgs e)
{
+ bool stopTimer = false;
lock (m_primTerseUpdates)
{
if (m_primTerseUpdates.Count == 0)
- {
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
+ stopTimer = true;
+ }
+ if (stopTimer)
+ {
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
- return;
- }
+ return;
+ }
- ImprovedTerseObjectUpdatePacket outPacket =
- (ImprovedTerseObjectUpdatePacket)
- PacketPool.Instance.GetPacket(
- PacketType.ImprovedTerseObjectUpdate);
+ ImprovedTerseObjectUpdatePacket outPacket =
+ (ImprovedTerseObjectUpdatePacket)
+ PacketPool.Instance.GetPacket(
+ PacketType.ImprovedTerseObjectUpdate);
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- int max = m_primTerseUpdates.Count;
- if (max > m_primTerseUpdatesPerPacket)
- max = m_primTerseUpdatesPerPacket;
+ int max = m_primTerseUpdates.Count;
+ if (max > m_primTerseUpdatesPerPacket)
+ max = m_primTerseUpdatesPerPacket;
- int count = 0;
- int size = 0;
+ int count = 0;
+ int size = 0;
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
- for (count = 0 ; count < max ; count++)
+ lock (m_primTerseUpdates)
+ {
+ for (count = 0; count < max; count++)
{
int length = 0;
m_primTerseUpdates[count].ToBytes(blockbuffer, ref length);
@@ -3294,9 +3314,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
OutPacket(outPacket, ThrottleOutPacketType.Task | ThrottleOutPacketType.LowPriority);
if (m_primTerseUpdates.Count == 0)
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
+ stopTimer = true;
}
+ if (stopTimer)
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
}
public void FlushPrimUpdates()
--
cgit v1.1
From 9618c196c274fefda4437eff6d25c7a12e7a3ee1 Mon Sep 17 00:00:00 2001
From: Melanie
Date: Wed, 7 Oct 2009 01:44:36 +0100
Subject: Revert "Merging in diva's locking fixes"
This reverts commit 832cc685138b2244529f10b54b373c34adb4a633.
---
.../Region/ClientStack/LindenUDP/LLClientView.cs | 116 +++++++++------------
1 file changed, 47 insertions(+), 69 deletions(-)
(limited to 'OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs')
diff --git a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
index 60dab5f..84e705a 100644
--- a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
@@ -3546,7 +3546,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
objectData.TextureAnim = textureanim;
}
- bool doUpdate = false;
lock (m_primFullUpdates)
{
if (m_primFullUpdates.Count == 0)
@@ -3555,10 +3554,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_primFullUpdates.Add(objectData);
if (m_primFullUpdates.Count >= m_primFullUpdatesPerPacket)
- doUpdate = true;
+ ProcessPrimFullUpdates(this, null);
}
- if (doUpdate)
- ProcessPrimFullUpdates(this, null);
}
void HandleQueueEmpty(ThrottleOutPacketType queue)
@@ -3579,40 +3576,35 @@ namespace OpenSim.Region.ClientStack.LindenUDP
void ProcessPrimFullUpdates(object sender, ElapsedEventArgs e)
{
- bool stopTimer = false;
lock (m_primFullUpdates)
{
if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
- stopTimer = true;
- }
- if (stopTimer)
- {
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
- return;
- }
+ {
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
+
+ return;
+ }
- ObjectUpdatePacket outPacket =
- (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
- PacketType.ObjectUpdate);
+ ObjectUpdatePacket outPacket =
+ (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
+ PacketType.ObjectUpdate);
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- int max = m_primFullUpdates.Count;
- if (max > m_primFullUpdatesPerPacket)
- max = m_primFullUpdatesPerPacket;
+ int max = m_primFullUpdates.Count;
+ if (max > m_primFullUpdatesPerPacket)
+ max = m_primFullUpdatesPerPacket;
- int count = 0;
- int size = 0;
+ int count = 0;
+ int size = 0;
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
- lock (m_primFullUpdates)
- {
for (count = 0 ; count < max ; count++)
{
int length = 0;
@@ -3636,12 +3628,9 @@ namespace OpenSim.Region.ClientStack.LindenUDP
OutPacket(outPacket, ThrottleOutPacketType.Task);
if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
- stopTimer = true;
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
}
-
- if (stopTimer)
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
}
///
@@ -3660,7 +3649,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
CreatePrimImprovedBlock(localID, position, rotation,
velocity, rotationalvelocity, state);
- bool doUpdate = false;
lock (m_primTerseUpdates)
{
if (m_primTerseUpdates.Count == 0)
@@ -3669,51 +3657,43 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_primTerseUpdates.Add(objectData);
if (m_primTerseUpdates.Count >= m_primTerseUpdatesPerPacket)
- doUpdate = true;
+ ProcessPrimTerseUpdates(this, null);
}
- if (doUpdate)
- ProcessPrimTerseUpdates(this, null);
}
void ProcessPrimTerseUpdates(object sender, ElapsedEventArgs e)
{
- bool stopTimer = false;
lock (m_primTerseUpdates)
{
if (m_primTerseUpdates.Count == 0)
- stopTimer = true;
- }
- if (stopTimer)
- {
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
+ {
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
- return;
- }
+ return;
+ }
- ImprovedTerseObjectUpdatePacket outPacket =
- (ImprovedTerseObjectUpdatePacket)
- PacketPool.Instance.GetPacket(
- PacketType.ImprovedTerseObjectUpdate);
+ ImprovedTerseObjectUpdatePacket outPacket =
+ (ImprovedTerseObjectUpdatePacket)
+ PacketPool.Instance.GetPacket(
+ PacketType.ImprovedTerseObjectUpdate);
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- int max = m_primTerseUpdates.Count;
- if (max > m_primTerseUpdatesPerPacket)
- max = m_primTerseUpdatesPerPacket;
+ int max = m_primTerseUpdates.Count;
+ if (max > m_primTerseUpdatesPerPacket)
+ max = m_primTerseUpdatesPerPacket;
- int count = 0;
- int size = 0;
+ int count = 0;
+ int size = 0;
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
- lock (m_primTerseUpdates)
- {
- for (count = 0; count < max; count++)
+ for (count = 0 ; count < max ; count++)
{
int length = 0;
m_primTerseUpdates[count].ToBytes(blockbuffer, ref length);
@@ -3738,11 +3718,9 @@ namespace OpenSim.Region.ClientStack.LindenUDP
OutPacket(outPacket, ThrottleOutPacketType.Task);
if (m_primTerseUpdates.Count == 0)
- stopTimer = true;
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
}
- if (stopTimer)
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
}
public void FlushPrimUpdates()
--
cgit v1.1
From adc208e56872c293f31ca2a3521775b5c6b297f2 Mon Sep 17 00:00:00 2001
From: Melanie
Date: Wed, 7 Oct 2009 04:36:36 +0100
Subject: Replace LLClientView on the branch with master. UNCOMPILABLE!
---
.../Region/ClientStack/LindenUDP/LLClientView.cs | 12726 ++++++++++---------
1 file changed, 6646 insertions(+), 6080 deletions(-)
(limited to 'OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs')
diff --git a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
index 84e705a..0052729 100644
--- a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs
@@ -58,180 +58,526 @@ namespace OpenSim.Region.ClientStack.LindenUDP
///
public class LLClientView : IClientAPI, IClientCore, IClientIM, IClientChat, IClientIPEndpoint, IStatsCollector
{
- // LLClientView Only
- public delegate void BinaryGenericMessage(Object sender, string method, byte[][] args);
-
- /// Used to adjust Sun Orbit values so Linden based viewers properly position sun
- private const float m_sunPainDaHalfOrbitalCutoff = 4.712388980384689858f;
-
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
- protected static Dictionary PacketHandlers = new Dictionary(); //Global/static handlers for all clients
- private readonly LLUDPServer m_udpServer;
- private readonly LLUDPClient m_udpClient;
+ /* static variables */
+ public static SynchronizeClientHandler SynchronizeClient;
+ /* private variables */
private readonly UUID m_sessionId;
- private readonly UUID m_secureSessionId;
- private readonly UUID m_agentId;
- private readonly uint m_circuitCode;
- private readonly byte[] m_channelVersion = Utils.EmptyBytes;
- private readonly Dictionary m_defaultAnimations = new Dictionary();
- private readonly IGroupsModule m_GroupsModule;
+ private readonly UUID m_secureSessionId = UUID.Zero;
+
+ private int m_debugPacketLevel;
+ //private readonly IAssetCache m_assetCache;
private int m_cachedTextureSerial;
+ private Timer m_clientPingTimer;
+
private Timer m_avatarTerseUpdateTimer;
private List m_avatarTerseUpdates = new List();
+
private Timer m_primTerseUpdateTimer;
private List m_primTerseUpdates = new List();
private Timer m_primFullUpdateTimer;
- private List m_primFullUpdates = new List();
+ private List m_primFullUpdates =
+ new List();
+
+ private bool m_clientBlocked;
+
+ private int m_probesWithNoIngressPackets;
+
+ private readonly UUID m_agentId;
+ private readonly uint m_circuitCode;
private int m_moneyBalance;
+ private readonly ILLPacketHandler m_PacketHandler;
+
private int m_animationSequenceNumber = 1;
+
+ private readonly byte[] m_channelVersion = Utils.StringToBytes("OpenSimulator Server"); // Dummy value needed by libSL
+
+ private readonly Dictionary m_defaultAnimations = new Dictionary();
+
private bool m_SendLogoutPacketWhenClosing = true;
- private AgentUpdateArgs lastarg;
- private bool m_IsActive = true;
+
+ private int m_inPacketsChecked;
+
+ // Used to adjust Sun Orbit values so Linden based viewers properly position sun
+ private const float m_sunPainDaHalfOrbitalCutoff = 4.712388980384689858f;
+
+
+ /* protected variables */
+
+ protected static Dictionary PacketHandlers =
+ new Dictionary(); //Global/static handlers for all clients
protected Dictionary m_packetHandlers = new Dictionary();
protected Dictionary m_genericPacketHandlers = new Dictionary(); //PauPaw:Local Generic Message handlers
+
protected IScene m_scene;
+
+ protected LLPacketServer m_networkServer;
+
protected LLImageManager m_imageManager;
+
+ /* public variables */
protected string m_firstName;
protected string m_lastName;
protected Thread m_clientThread;
protected Vector3 m_startpos;
protected EndPoint m_userEndPoint;
+ protected EndPoint m_proxyEndPoint;
protected UUID m_activeGroupID = UUID.Zero;
protected string m_activeGroupName = String.Empty;
protected ulong m_activeGroupPowers;
protected Dictionary m_groupPowers = new Dictionary();
- protected int m_terrainCheckerCount;
+ protected int m_avatarTerseUpdateRate = 50;
+ protected int m_avatarTerseUpdatesPerPacket = 5;
- // LL uses these limits, apparently. Compressed terse would be 23, but we don't have that yet
+ // LL uses these limits, apparently. Compressed terse would be
+ // 23, but we don't have that yet
+ //
protected int m_primTerseUpdatesPerPacket = 10;
protected int m_primFullUpdatesPerPacket = 14;
+
protected int m_primTerseUpdateRate = 10;
protected int m_primFullUpdateRate = 14;
+
protected int m_textureSendLimit = 20;
protected int m_textureDataLimit = 10;
- protected int m_avatarTerseUpdateRate = 50;
- protected int m_avatarTerseUpdatesPerPacket = 5;
+
protected int m_packetMTU = 1400;
+
protected IAssetService m_assetService;
- #region Properties
+ // LLClientView Only
+ public delegate void BinaryGenericMessage(Object sender, string method, byte[][] args);
+
+ /* Instantiated Designated Event Delegates */
+ //- used so we don't create new objects for each incoming packet and then toss it out later */
+
+ private GenericMessage handlerGenericMessage;
+ private RequestAvatarProperties handlerRequestAvatarProperties; //OnRequestAvatarProperties;
+ private UpdateAvatarProperties handlerUpdateAvatarProperties; // OnUpdateAvatarProperties;
+ private ChatMessage handlerChatFromClient; //OnChatFromClient;
+ private ChatMessage handlerChatFromClient2; //OnChatFromClient;
+ private ImprovedInstantMessage handlerInstantMessage; //OnInstantMessage;
+ private FriendActionDelegate handlerApproveFriendRequest; //OnApproveFriendRequest;
+ private FriendshipTermination handlerTerminateFriendship; //OnTerminateFriendship;
+ private RezObject handlerRezObject; //OnRezObject;
+ private DeRezObject handlerDeRezObject; //OnDeRezObject;
+ private ModifyTerrain handlerModifyTerrain;
+ private BakeTerrain handlerBakeTerrain;
+ private EstateChangeInfo handlerEstateChangeInfo;
+ private Action handlerRegionHandShakeReply; //OnRegionHandShakeReply;
+ private GenericCall2 handlerRequestWearables; //OnRequestWearables;
+ private Action handlerRequestAvatarsData; //OnRequestAvatarsData;
+ private SetAppearance handlerSetAppearance; //OnSetAppearance;
+ private AvatarNowWearing handlerAvatarNowWearing; //OnAvatarNowWearing;
+ private RezSingleAttachmentFromInv handlerRezSingleAttachment; //OnRezSingleAttachmentFromInv;
+ private RezMultipleAttachmentsFromInv handlerRezMultipleAttachments; //OnRezMultipleAttachmentsFromInv;
+ private UUIDNameRequest handlerDetachAttachmentIntoInv; // Detach attachment!
+ private ObjectAttach handlerObjectAttach; //OnObjectAttach;
+ private SetAlwaysRun handlerSetAlwaysRun; //OnSetAlwaysRun;
+ private GenericCall2 handlerCompleteMovementToRegion; //OnCompleteMovementToRegion;
+ private UpdateAgent handlerAgentUpdate; //OnAgentUpdate;
+ private StartAnim handlerStartAnim;
+ private StopAnim handlerStopAnim;
+ private AgentRequestSit handlerAgentRequestSit; //OnAgentRequestSit;
+ private AgentSit handlerAgentSit; //OnAgentSit;
+ private AvatarPickerRequest handlerAvatarPickerRequest; //OnAvatarPickerRequest;
+ private FetchInventory handlerAgentDataUpdateRequest; //OnAgentDataUpdateRequest;
+ private TeleportLocationRequest handlerSetStartLocationRequest; //OnSetStartLocationRequest;
+ private TeleportLandmarkRequest handlerTeleportLandmarkRequest; //OnTeleportLandmarkRequest;
+ private LinkObjects handlerLinkObjects; //OnLinkObjects;
+ private DelinkObjects handlerDelinkObjects; //OnDelinkObjects;
+ private AddNewPrim handlerAddPrim; //OnAddPrim;
+ private UpdateShape handlerUpdatePrimShape; //null;
+ private ObjectExtraParams handlerUpdateExtraParams; //OnUpdateExtraParams;
+ private ObjectDuplicate handlerObjectDuplicate;
+ private ObjectDuplicateOnRay handlerObjectDuplicateOnRay;
+ private ObjectRequest handlerObjectRequest;
+ private ObjectSelect handlerObjectSelect;
+ private ObjectDeselect handlerObjectDeselect;
+ private ObjectIncludeInSearch handlerObjectIncludeInSearch;
+ private UpdatePrimFlags handlerUpdatePrimFlags; //OnUpdatePrimFlags;
+ private UpdatePrimTexture handlerUpdatePrimTexture;
+ private GrabObject handlerGrabObject; //OnGrabObject;
+ private MoveObject handlerGrabUpdate; //OnGrabUpdate;
+ private DeGrabObject handlerDeGrabObject; //OnDeGrabObject;
+ private SpinStart handlerSpinStart; //OnSpinStart;
+ private SpinObject handlerSpinUpdate; //OnSpinUpdate;
+ private SpinStop handlerSpinStop; //OnSpinStop;
+ private GenericCall7 handlerObjectDescription;
+ private GenericCall7 handlerObjectName;
+ private GenericCall7 handlerObjectClickAction;
+ private GenericCall7 handlerObjectMaterial;
+ private ObjectPermissions handlerObjectPermissions;
+ private RequestObjectPropertiesFamily handlerRequestObjectPropertiesFamily; //OnRequestObjectPropertiesFamily;
+ //private TextureRequest handlerTextureRequest;
+ private UDPAssetUploadRequest handlerAssetUploadRequest; //OnAssetUploadRequest;
+ private RequestXfer handlerRequestXfer; //OnRequestXfer;
+ private XferReceive handlerXferReceive; //OnXferReceive;
+ private ConfirmXfer handlerConfirmXfer; //OnConfirmXfer;
+ private AbortXfer handlerAbortXfer;
+ private CreateInventoryFolder handlerCreateInventoryFolder; //OnCreateNewInventoryFolder;
+ private UpdateInventoryFolder handlerUpdateInventoryFolder;
+ private MoveInventoryFolder handlerMoveInventoryFolder;
+ private CreateNewInventoryItem handlerCreateNewInventoryItem; //OnCreateNewInventoryItem;
+ private FetchInventory handlerFetchInventory;
+ private FetchInventoryDescendents handlerFetchInventoryDescendents; //OnFetchInventoryDescendents;
+ private PurgeInventoryDescendents handlerPurgeInventoryDescendents; //OnPurgeInventoryDescendents;
+ private UpdateInventoryItem handlerUpdateInventoryItem;
+ private CopyInventoryItem handlerCopyInventoryItem;
+ private MoveInventoryItem handlerMoveInventoryItem;
+ private RemoveInventoryItem handlerRemoveInventoryItem;
+ private RemoveInventoryFolder handlerRemoveInventoryFolder;
+ private RequestTaskInventory handlerRequestTaskInventory; //OnRequestTaskInventory;
+ private UpdateTaskInventory handlerUpdateTaskInventory; //OnUpdateTaskInventory;
+ private MoveTaskInventory handlerMoveTaskItem;
+ private RemoveTaskInventory handlerRemoveTaskItem; //OnRemoveTaskItem;
+ private RezScript handlerRezScript; //OnRezScript;
+ private RequestMapBlocks handlerRequestMapBlocks; //OnRequestMapBlocks;
+ private RequestMapName handlerMapNameRequest; //OnMapNameRequest;
+ private TeleportLocationRequest handlerTeleportLocationRequest; //OnTeleportLocationRequest;
+ private MoneyBalanceRequest handlerMoneyBalanceRequest; //OnMoneyBalanceRequest;
+ private UUIDNameRequest handlerNameRequest;
+ private ParcelAccessListRequest handlerParcelAccessListRequest; //OnParcelAccessListRequest;
+ private ParcelAccessListUpdateRequest handlerParcelAccessListUpdateRequest; //OnParcelAccessListUpdateRequest;
+ private ParcelPropertiesRequest handlerParcelPropertiesRequest; //OnParcelPropertiesRequest;
+ private ParcelDivideRequest handlerParcelDivideRequest; //OnParcelDivideRequest;
+ private ParcelJoinRequest handlerParcelJoinRequest; //OnParcelJoinRequest;
+ private ParcelPropertiesUpdateRequest handlerParcelPropertiesUpdateRequest; //OnParcelPropertiesUpdateRequest;
+ private ParcelSelectObjects handlerParcelSelectObjects; //OnParcelSelectObjects;
+ private ParcelObjectOwnerRequest handlerParcelObjectOwnerRequest; //OnParcelObjectOwnerRequest;
+ private ParcelAbandonRequest handlerParcelAbandonRequest;
+ private ParcelGodForceOwner handlerParcelGodForceOwner;
+ private ParcelReclaim handlerParcelReclaim;
+ private RequestTerrain handlerRequestTerrain;
+ private RequestTerrain handlerUploadTerrain;
+ private ParcelReturnObjectsRequest handlerParcelReturnObjectsRequest;
+ private RegionInfoRequest handlerRegionInfoRequest; //OnRegionInfoRequest;
+ private EstateCovenantRequest handlerEstateCovenantRequest; //OnEstateCovenantRequest;
+ private RequestGodlikePowers handlerReqGodlikePowers; //OnRequestGodlikePowers;
+ private GodKickUser handlerGodKickUser; //OnGodKickUser;
+ private ViewerEffectEventHandler handlerViewerEffect; //OnViewerEffect;
+ private Action handlerLogout; //OnLogout;
+ private MoneyTransferRequest handlerMoneyTransferRequest; //OnMoneyTransferRequest;
+ private ParcelBuy handlerParcelBuy;
+ private EconomyDataRequest handlerEconomoyDataRequest;
+
+ private UpdateVector handlerUpdatePrimSinglePosition; //OnUpdatePrimSinglePosition;
+ private UpdatePrimSingleRotation handlerUpdatePrimSingleRotation; //OnUpdatePrimSingleRotation;
+ private UpdatePrimSingleRotationPosition handlerUpdatePrimSingleRotationPosition; //OnUpdatePrimSingleRotation;
+ private UpdateVector handlerUpdatePrimScale; //OnUpdatePrimScale;
+ private UpdateVector handlerUpdatePrimGroupScale; //OnUpdateGroupScale;
+ private UpdateVector handlerUpdateVector; //OnUpdatePrimGroupPosition;
+ private UpdatePrimRotation handlerUpdatePrimRotation; //OnUpdatePrimGroupRotation;
+ // private UpdatePrimGroupRotation handlerUpdatePrimGroupRotation; //OnUpdatePrimGroupMouseRotation;
+ // private RequestAsset handlerRequestAsset; // OnRequestAsset;
+ private UUIDNameRequest handlerTeleportHomeRequest;
+
+ private RegionHandleRequest handlerRegionHandleRequest; // OnRegionHandleRequest
+ private ParcelInfoRequest handlerParcelInfoRequest; // OnParcelInfoRequest
+
+ private ScriptAnswer handlerScriptAnswer;
+ private RequestPayPrice handlerRequestPayPrice;
+ private ObjectSaleInfo handlerObjectSaleInfo;
+ private ObjectBuy handlerObjectBuy;
+ //private BuyObjectInventory handlerBuyObjectInventory;
+ private ObjectDeselect handlerObjectDetach;
+ private ObjectDrop handlerObjectDrop;
+ private AgentSit handlerOnUndo;
+
+ private ForceReleaseControls handlerForceReleaseControls;
+
+ private GodLandStatRequest handlerLandStatRequest;
+
+ private UUIDNameRequest handlerUUIDGroupNameRequest;
+
+ private ParcelDeedToGroup handlerParcelDeedToGroup;
+
+ private RequestObjectPropertiesFamily handlerObjectGroupRequest;
+ private ScriptReset handlerScriptReset;
+ private GetScriptRunning handlerGetScriptRunning;
+ private SetScriptRunning handlerSetScriptRunning;
+ private UpdateVector handlerAutoPilotGo;
+ //Gesture
+ private ActivateGesture handlerActivateGesture;
+ private DeactivateGesture handlerDeactivateGesture;
+ //Sound
+ private SoundTrigger handlerSoundTrigger;
+ private ObjectOwner handlerObjectOwner;
+
+ private DirPlacesQuery handlerDirPlacesQuery;
+ private DirFindQuery handlerDirFindQuery;
+ private DirLandQuery handlerDirLandQuery;
+ private DirPopularQuery handlerDirPopularQuery;
+ private DirClassifiedQuery handlerDirClassifiedQuery;
+ private ParcelSetOtherCleanTime handlerParcelSetOtherCleanTime;
+
+ private MapItemRequest handlerMapItemRequest;
+
+ private StartLure handlerStartLure;
+ private TeleportLureRequest handlerTeleportLureRequest;
+
+ private NetworkStats handlerNetworkStatsUpdate;
+
+ private ClassifiedInfoRequest handlerClassifiedInfoRequest;
+ private ClassifiedInfoUpdate handlerClassifiedInfoUpdate;
+ private ClassifiedDelete handlerClassifiedDelete;
+ private ClassifiedDelete handlerClassifiedGodDelete;
+
+ private EventNotificationAddRequest handlerEventNotificationAddRequest;
+ private EventNotificationRemoveRequest handlerEventNotificationRemoveRequest;
+ private EventGodDelete handlerEventGodDelete;
+
+ private ParcelDwellRequest handlerParcelDwellRequest;
+
+ private UserInfoRequest handlerUserInfoRequest;
+ private UpdateUserInfo handlerUpdateUserInfo;
+
+ private RetrieveInstantMessages handlerRetrieveInstantMessages;
+
+ private PickDelete handlerPickDelete;
+ private PickGodDelete handlerPickGodDelete;
+ private PickInfoUpdate handlerPickInfoUpdate;
+ private AvatarNotesUpdate handlerAvatarNotesUpdate;
+
+ private MuteListRequest handlerMuteListRequest;
+
+ //private AvatarInterestUpdate handlerAvatarInterestUpdate;
+
+ private PlacesQuery handlerPlacesQuery;
+
+ private readonly IGroupsModule m_GroupsModule;
+
+ private AgentUpdateArgs lastarg = null;
+
+ //private TerrainUnacked handlerUnackedTerrain = null;
+
+ //**
+
+ /* Properties */
+
+ public UUID SecureSessionId
+ {
+ get { return m_secureSessionId; }
+ }
+
+ public IScene Scene
+ {
+ get { return m_scene; }
+ }
+
+ public UUID SessionId
+ {
+ get { return m_sessionId; }
+ }
- public UUID SecureSessionId { get { return m_secureSessionId; } }
- public IScene Scene { get { return m_scene; } }
- public UUID SessionId { get { return m_sessionId; } }
public Vector3 StartPos
{
get { return m_startpos; }
set { m_startpos = value; }
}
- public UUID AgentId { get { return m_agentId; } }
- public UUID ActiveGroupId { get { return m_activeGroupID; } }
- public string ActiveGroupName { get { return m_activeGroupName; } }
- public ulong ActiveGroupPowers { get { return m_activeGroupPowers; } }
- public bool IsGroupMember(UUID groupID) { return m_groupPowers.ContainsKey(groupID); }
+
+ public UUID AgentId
+ {
+ get { return m_agentId; }
+ }
+
+ public UUID ActiveGroupId
+ {
+ get { return m_activeGroupID; }
+ }
+
+ public string ActiveGroupName
+ {
+ get { return m_activeGroupName; }
+ }
+
+ public ulong ActiveGroupPowers
+ {
+ get { return m_activeGroupPowers; }
+ }
+
+ public bool IsGroupMember(UUID groupID)
+ {
+ return m_groupPowers.ContainsKey(groupID);
+ }
+
+ public ulong GetGroupPowers(UUID groupID)
+ {
+ if (groupID == m_activeGroupID)
+ return m_activeGroupPowers;
+
+ if (m_groupPowers.ContainsKey(groupID))
+ return m_groupPowers[groupID];
+
+ return 0;
+ }
+
+ ///
+ /// This is a utility method used by single states to not duplicate kicks and blue card of death messages.
+ ///
+ public bool ChildAgentStatus()
+ {
+ return m_scene.PresenceChildStatus(AgentId);
+ }
+
///
/// First name of the agent/avatar represented by the client
///
- public string FirstName { get { return m_firstName; } }
+ public string FirstName
+ {
+ get { return m_firstName; }
+ }
+
///
/// Last name of the agent/avatar represented by the client
///
- public string LastName { get { return m_lastName; } }
+ public string LastName
+ {
+ get { return m_lastName; }
+ }
+
///
/// Full name of the client (first name and last name)
///
- public string Name { get { return FirstName + " " + LastName; } }
- public uint CircuitCode { get { return m_circuitCode; } }
- public int MoneyBalance { get { return m_moneyBalance; } }
- public int NextAnimationSequenceNumber { get { return m_animationSequenceNumber++; } }
+ public string Name
+ {
+ get { return FirstName + " " + LastName; }
+ }
+
+ public uint CircuitCode
+ {
+ get { return m_circuitCode; }
+ }
+
+ public int MoneyBalance
+ {
+ get { return m_moneyBalance; }
+ }
+
+ public int NextAnimationSequenceNumber
+ {
+ get { return m_animationSequenceNumber++; }
+ }
+
+ public ILLPacketHandler PacketHandler
+ {
+ get { return m_PacketHandler; }
+ }
+
+ bool m_IsActive = true;
+
public bool IsActive
{
get { return m_IsActive; }
set { m_IsActive = value; }
}
- public bool SendLogoutPacketWhenClosing { set { m_SendLogoutPacketWhenClosing = value; } }
- #endregion Properties
+ public bool SendLogoutPacketWhenClosing
+ {
+ set { m_SendLogoutPacketWhenClosing = value; }
+ }
+
+ /* METHODS */
///
/// Constructor
///
- public LLClientView(EndPoint remoteEP, IScene scene, LLUDPServer udpServer, LLUDPClient udpClient, AuthenticateResponse sessionInfo,
- UUID agentId, UUID sessionId, uint circuitCode)
+ public LLClientView(
+ EndPoint remoteEP, IScene scene, LLPacketServer packServer,
+ AuthenticateResponse sessionInfo, UUID agentId, UUID sessionId, uint circuitCode, EndPoint proxyEP,
+ ClientStackUserSettings userSettings)
{
- RegisterInterface(this);
- RegisterInterface(this);
- RegisterInterface(this);
-
+ // Should be called first?
+ RegisterInterfaces();
+
+ m_GroupsModule = scene.RequestModuleInterface();
+ m_moneyBalance = 1000;
+
+ m_channelVersion = Utils.StringToBytes(scene.GetSimulatorVersion());
+
InitDefaultAnimations();
m_scene = scene;
+ //m_assetCache = assetCache;
+
m_assetService = m_scene.RequestModuleInterface();
- m_GroupsModule = scene.RequestModuleInterface();
- m_imageManager = new LLImageManager(this, m_assetService, Scene.RequestModuleInterface());
- m_channelVersion = Utils.StringToBytes(scene.GetSimulatorVersion());
+
+ m_networkServer = packServer;
+
m_agentId = agentId;
m_sessionId = sessionId;
- m_secureSessionId = sessionInfo.LoginInfo.SecureSession;
m_circuitCode = circuitCode;
+
m_userEndPoint = remoteEP;
+ m_proxyEndPoint = proxyEP;
+
m_firstName = sessionInfo.LoginInfo.First;
m_lastName = sessionInfo.LoginInfo.Last;
m_startpos = sessionInfo.LoginInfo.StartPos;
- m_moneyBalance = 1000;
- m_udpServer = udpServer;
- m_udpClient = udpClient;
- m_udpClient.OnQueueEmpty += HandleQueueEmpty;
- m_udpClient.OnPacketStats += PopulateStats;
+ if (sessionInfo.LoginInfo.SecureSession != UUID.Zero)
+ {
+ m_secureSessionId = sessionInfo.LoginInfo.SecureSession;
+ }
+
+ // While working on this, the BlockingQueue had me fooled for a bit.
+ // The Blocking queue causes the thread to stop until there's something
+ // in it to process. It's an on-purpose threadlock though because
+ // without it, the clientloop will suck up all sim resources.
+
+ m_PacketHandler = new LLPacketHandler(this, m_networkServer, userSettings);
+ m_PacketHandler.SynchronizeClient = SynchronizeClient;
+ m_PacketHandler.OnPacketStats += PopulateStats;
+ m_PacketHandler.OnQueueEmpty += HandleQueueEmpty;
+
+ if (scene.Config != null)
+ {
+ IConfig clientConfig = scene.Config.Configs["LLClient"];
+ if (clientConfig != null)
+ {
+ m_PacketHandler.ReliableIsImportant =
+ clientConfig.GetBoolean("ReliableIsImportant",
+ false);
+ m_PacketHandler.MaxReliableResends = clientConfig.GetInt("MaxReliableResends",
+ m_PacketHandler.MaxReliableResends);
+ m_primTerseUpdatesPerPacket = clientConfig.GetInt("TerseUpdatesPerPacket",
+ m_primTerseUpdatesPerPacket);
+ m_primFullUpdatesPerPacket = clientConfig.GetInt("FullUpdatesPerPacket",
+ m_primFullUpdatesPerPacket);
+
+ m_primTerseUpdateRate = clientConfig.GetInt("TerseUpdateRate",
+ m_primTerseUpdateRate);
+ m_primFullUpdateRate = clientConfig.GetInt("FullUpdateRate",
+ m_primFullUpdateRate);
+
+ m_textureSendLimit = clientConfig.GetInt("TextureSendLimit",
+ m_textureSendLimit);
+
+ m_textureDataLimit = clientConfig.GetInt("TextureDataLimit",
+ m_textureDataLimit);
+
+ m_packetMTU = clientConfig.GetInt("PacketMTU", 1400);
+ }
+ }
RegisterLocalPacketHandlers();
+ m_imageManager = new LLImageManager(this, m_assetService, Scene.RequestModuleInterface());
}
- public void SetDebugPacketLevel(int newDebug)
+ public void SetDebugPacketLevel(int newDebugPacketLevel)
{
+ m_debugPacketLevel = newDebugPacketLevel;
}
- #region Client Methods
-
- ///
- /// Close down the client view. This *must* be the last method called, since the last #
- /// statement of CloseCleanup() aborts the thread.
- ///
- ///
- public void Close(bool shutdownCircuit)
- {
- m_log.DebugFormat(
- "[CLIENT]: Close has been called with shutdownCircuit = {0} for {1} attached to scene {2}",
- shutdownCircuit, Name, m_scene.RegionInfo.RegionName);
-
- if (m_imageManager != null)
- m_imageManager.Close();
-
- if (m_udpServer != null)
- m_udpServer.Flush();
-
- // raise an event on the packet server to Shutdown the circuit
- // Now, if we raise the event then the packet server will call this method itself, so don't try cleanup
- // here otherwise we'll end up calling it twice.
- // FIXME: In truth, I might be wrong but this whole business of calling this method twice (with different args) looks
- // horribly tangly. Hopefully it should be possible to greatly simplify it.
- if (shutdownCircuit)
- {
- if (OnConnectionClosed != null)
- OnConnectionClosed(this);
- }
- else
- {
- CloseCleanup(shutdownCircuit);
- }
- }
+ # region Client Methods
private void CloseCleanup(bool shutdownCircuit)
{
+
+
m_scene.RemoveClient(AgentId);
//m_log.InfoFormat("[CLIENTVIEW] Memory pre GC {0}", System.GC.GetTotalMemory(false));
@@ -244,6 +590,9 @@ namespace OpenSim.Region.ClientStack.LindenUDP
Thread.Sleep(2000);
// Shut down timers. Thread Context of this method is murky. Lock all timers
+ if (m_clientPingTimer.Enabled)
+ lock (m_clientPingTimer)
+ m_clientPingTimer.Stop();
if (m_avatarTerseUpdateTimer.Enabled)
lock (m_avatarTerseUpdateTimer)
m_avatarTerseUpdateTimer.Stop();
@@ -276,21 +625,43 @@ namespace OpenSim.Region.ClientStack.LindenUDP
// of the client thread regardless of where Close() is called.
KillEndDone();
}
+
+ Terminate();
+ }
- IsActive = false;
+ ///
+ /// Close down the client view. This *must* be the last method called, since the last #
+ /// statement of CloseCleanup() aborts the thread.
+ ///
+ ///
+ public void Close(bool shutdownCircuit)
+ {
+ m_clientPingTimer.Enabled = false;
- m_avatarTerseUpdateTimer.Close();
- m_primTerseUpdateTimer.Close();
- m_primFullUpdateTimer.Close();
+ m_log.DebugFormat(
+ "[CLIENT]: Close has been called with shutdownCircuit = {0} for {1} attached to scene {2}",
+ shutdownCircuit, Name, m_scene.RegionInfo.RegionName);
- //m_udpServer.OnPacketStats -= PopulateStats;
- m_udpClient.Shutdown();
+ if (m_imageManager != null)
+ m_imageManager.Close();
- // wait for thread stoped
- // m_clientThread.Join();
+ if (m_PacketHandler != null)
+ m_PacketHandler.Flush();
- // delete circuit code
- //m_networkServer.CloseClient(this);
+ // raise an event on the packet server to Shutdown the circuit
+ // Now, if we raise the event then the packet server will call this method itself, so don't try cleanup
+ // here otherwise we'll end up calling it twice.
+ // FIXME: In truth, I might be wrong but this whole business of calling this method twice (with different args) looks
+ // horribly tangly. Hopefully it should be possible to greatly simplify it.
+ if (shutdownCircuit)
+ {
+ if (OnConnectionClosed != null)
+ OnConnectionClosed(this);
+ }
+ else
+ {
+ CloseCleanup(shutdownCircuit);
+ }
}
public void Kick(string message)
@@ -312,6 +683,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public void Stop()
{
// Shut down timers. Thread Context is Murky, lock all timers!
+ if (m_clientPingTimer.Enabled)
+ lock (m_clientPingTimer)
+ m_clientPingTimer.Stop();
+
if (m_avatarTerseUpdateTimer.Enabled)
lock (m_avatarTerseUpdateTimer)
m_avatarTerseUpdateTimer.Stop();
@@ -325,13 +700,54 @@ namespace OpenSim.Region.ClientStack.LindenUDP
m_primFullUpdateTimer.Stop();
}
- #endregion Client Methods
+ public void Restart()
+ {
+ // re-construct
+ m_PacketHandler.Clear();
+
+ m_clientPingTimer = new Timer(5000);
+ m_clientPingTimer.Elapsed += CheckClientConnectivity;
+ m_clientPingTimer.Enabled = true;
+
+ m_avatarTerseUpdateTimer = new Timer(m_avatarTerseUpdateRate);
+ m_avatarTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessAvatarTerseUpdates);
+ m_avatarTerseUpdateTimer.AutoReset = false;
+
+ m_primTerseUpdateTimer = new Timer(m_primTerseUpdateRate);
+ m_primTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessPrimTerseUpdates);
+ m_primTerseUpdateTimer.AutoReset = false;
+
+ m_primFullUpdateTimer = new Timer(m_primFullUpdateRate);
+ m_primFullUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessPrimFullUpdates);
+ m_primFullUpdateTimer.AutoReset = false;
+ }
+
+ private void Terminate()
+ {
+ IsActive = false;
+
+ m_clientPingTimer.Close();
+ m_avatarTerseUpdateTimer.Close();
+ m_primTerseUpdateTimer.Close();
+ m_primFullUpdateTimer.Close();
+
+ m_PacketHandler.OnPacketStats -= PopulateStats;
+ m_PacketHandler.Dispose();
+
+ // wait for thread stoped
+ // m_clientThread.Join();
+
+ // delete circuit code
+ //m_networkServer.CloseClient(this);
+ }
+
+ #endregion
- #region Packet Handling
+ # region Packet Handling
public void PopulateStats(int inPackets, int outPackets, int unAckedBytes)
{
- NetworkStats handlerNetworkStatsUpdate = OnNetworkStatsUpdate;
+ handlerNetworkStatsUpdate = OnNetworkStatsUpdate;
if (handlerNetworkStatsUpdate != null)
{
handlerNetworkStatsUpdate(inPackets, outPackets, unAckedBytes);
@@ -412,7 +828,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
return result;
}
- /*protected void DebugPacket(string direction, Packet packet)
+ protected void DebugPacket(string direction, Packet packet)
{
string info;
@@ -438,27 +854,113 @@ namespace OpenSim.Region.ClientStack.LindenUDP
}
Console.WriteLine(m_circuitCode + ":" + direction + ": " + info);
- }*/
-
- #endregion Packet Handling
-
- # region Setup
+ }
///
- /// Starts up the timers to check the client and resend unacked packets
- /// Adds the client to the OpenSim.Region.Framework.Scenes.Scene
+ /// Main packet processing loop for the UDP component of the client session. Both incoming and outgoing
+ /// packets are processed here.
///
- protected virtual void InitNewClient()
+ protected virtual void ClientLoop()
{
- m_avatarTerseUpdateTimer = new Timer(m_avatarTerseUpdateRate);
- m_avatarTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessAvatarTerseUpdates);
- m_avatarTerseUpdateTimer.AutoReset = false;
+ m_log.DebugFormat(
+ "[CLIENT]: Entered main packet processing loop for {0} in {1}", Name, Scene.RegionInfo.RegionName);
- m_primTerseUpdateTimer = new Timer(m_primTerseUpdateRate);
- m_primTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessPrimTerseUpdates);
- m_primTerseUpdateTimer.AutoReset = false;
+ while (IsActive)
+ {
+ LLQueItem nextPacket = m_PacketHandler.PacketQueue.Dequeue();
+
+ if (nextPacket == null) {
+ m_log.DebugFormat("[CLIENT]: PacketQueue return null LLQueItem");
+ continue;
+ }
- m_primFullUpdateTimer = new Timer(m_primFullUpdateRate);
+ if (nextPacket.Incoming)
+ {
+ if (m_debugPacketLevel > 0)
+ DebugPacket("IN", nextPacket.Packet);
+ m_PacketHandler.ProcessInPacket(nextPacket);
+ }
+ else
+ {
+ if (m_debugPacketLevel > 0)
+ DebugPacket("OUT", nextPacket.Packet);
+ m_PacketHandler.ProcessOutPacket(nextPacket);
+ }
+ }
+ }
+
+ # endregion
+
+ protected int m_terrainCheckerCount;
+
+ ///
+ /// Event handler for check client timer
+ /// Checks to ensure that the client is still connected. If the client has failed to respond to many pings
+ /// in succession then close down the connection.
+ ///
+ ///
+ ///
+ protected void CheckClientConnectivity(object sender, ElapsedEventArgs e)
+ {
+ if (m_PacketHandler.PacketsReceived == m_inPacketsChecked)
+ {
+ // no packet came in since the last time we checked...
+
+ m_probesWithNoIngressPackets++;
+ if ((m_probesWithNoIngressPackets > 30 && !m_clientBlocked) // agent active
+ || (m_probesWithNoIngressPackets > 90 && m_clientBlocked)) // agent paused
+ {
+ m_clientPingTimer.Enabled = false;
+
+ m_log.WarnFormat(
+ "[CLIENT]: Client for agent {0} {1} has stopped responding to pings. Closing connection",
+ Name, AgentId);
+
+ if (OnConnectionClosed != null)
+ {
+ OnConnectionClosed(this);
+ }
+ }
+ else
+ {
+ // this will normally trigger at least one packet (ping response)
+ SendStartPingCheck(0);
+ }
+ }
+ else
+ {
+ // Something received in the meantime - we can reset the counters
+ m_probesWithNoIngressPackets = 0;
+ // ... and store the current number of packets received to find out if another one got in on the next cycle
+ m_inPacketsChecked = m_PacketHandler.PacketsReceived;
+ }
+
+ }
+
+ # region Setup
+
+ ///
+ /// Starts up the timers to check the client and resend unacked packets
+ /// Adds the client to the OpenSim.Region.Framework.Scenes.Scene
+ ///
+ protected virtual void InitNewClient()
+ {
+ //this.UploadAssets = new AgentAssetUpload(this, m_assetCache, m_inventoryCache);
+
+ // Ping the client regularly to check that it's still there
+ m_clientPingTimer = new Timer(5000);
+ m_clientPingTimer.Elapsed += CheckClientConnectivity;
+ m_clientPingTimer.Enabled = true;
+
+ m_avatarTerseUpdateTimer = new Timer(m_avatarTerseUpdateRate);
+ m_avatarTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessAvatarTerseUpdates);
+ m_avatarTerseUpdateTimer.AutoReset = false;
+
+ m_primTerseUpdateTimer = new Timer(m_primTerseUpdateRate);
+ m_primTerseUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessPrimTerseUpdates);
+ m_primTerseUpdateTimer.AutoReset = false;
+
+ m_primFullUpdateTimer = new Timer(m_primFullUpdateRate);
m_primFullUpdateTimer.Elapsed += new ElapsedEventHandler(ProcessPrimFullUpdates);
m_primFullUpdateTimer.AutoReset = false;
@@ -469,18 +971,27 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public virtual void Start()
{
- // This sets up all the timers
- InitNewClient();
+ m_clientThread = new Thread(RunUserSession);
+ m_clientThread.Name = "ClientThread";
+ m_clientThread.IsBackground = true;
+ m_clientThread.Start();
+ ThreadTracker.Add(m_clientThread);
}
///
/// Run a user session. This method lies at the base of the entire client thread.
///
- protected void RunUserSession()
+ protected virtual void RunUserSession()
{
+ //tell this thread we are using the culture set up for the sim (currently hardcoded to en_US)
+ //otherwise it will override this and use the system default
+ Culture.SetCurrentCulture();
+
try
{
-
+ // This sets up all the timers
+ InitNewClient();
+ ClientLoop();
}
catch (Exception e)
{
@@ -504,7 +1015,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
+ "Any further actions taken will not be processed.\n"
+ "Please relog", true);
- m_udpServer.SendPacket(m_agentId, packet, ThrottleOutPacketType.Unknown, false);
+ LLQueItem item = new LLQueItem();
+ item.Packet = packet;
+ item.Sequence = packet.Header.Sequence;
+
+ m_PacketHandler.ProcessOutPacket(item);
// There may be a better way to do this. Perhaps kick? Not sure this propogates notifications to
// listeners yet, though.
@@ -522,8 +1037,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
# endregion
- #region Events
-
+ // Previously ClientView.API partial class
public event GenericMessage OnGenericMessage;
public event BinaryGenericMessage OnBinaryGenericMessage;
public event Action OnLogout;
@@ -683,10 +1197,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public event GetScriptRunning OnGetScriptRunning;
public event SetScriptRunning OnSetScriptRunning;
public event UpdateVector OnAutoPilotGo;
+
public event TerrainUnacked OnUnackedTerrain;
+
public event ActivateGesture OnActivateGesture;
public event DeactivateGesture OnDeactivateGesture;
public event ObjectOwner OnObjectOwner;
+
public event DirPlacesQuery OnDirPlacesQuery;
public event DirFindQuery OnDirFindQuery;
public event DirLandQuery OnDirLandQuery;
@@ -694,34 +1211,44 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public event DirClassifiedQuery OnDirClassifiedQuery;
public event EventInfoRequest OnEventInfoRequest;
public event ParcelSetOtherCleanTime OnParcelSetOtherCleanTime;
+
public event MapItemRequest OnMapItemRequest;
+
public event OfferCallingCard OnOfferCallingCard;
public event AcceptCallingCard OnAcceptCallingCard;
public event DeclineCallingCard OnDeclineCallingCard;
public event SoundTrigger OnSoundTrigger;
+
public event StartLure OnStartLure;
public event TeleportLureRequest OnTeleportLureRequest;
public event NetworkStats OnNetworkStatsUpdate;
+
public event ClassifiedInfoRequest OnClassifiedInfoRequest;
public event ClassifiedInfoUpdate OnClassifiedInfoUpdate;
public event ClassifiedDelete OnClassifiedDelete;
public event ClassifiedDelete OnClassifiedGodDelete;
+
public event EventNotificationAddRequest OnEventNotificationAddRequest;
public event EventNotificationRemoveRequest OnEventNotificationRemoveRequest;
public event EventGodDelete OnEventGodDelete;
+
public event ParcelDwellRequest OnParcelDwellRequest;
+
public event UserInfoRequest OnUserInfoRequest;
public event UpdateUserInfo OnUpdateUserInfo;
+
public event RetrieveInstantMessages OnRetrieveInstantMessages;
+
public event PickDelete OnPickDelete;
public event PickGodDelete OnPickGodDelete;
public event PickInfoUpdate OnPickInfoUpdate;
public event AvatarNotesUpdate OnAvatarNotesUpdate;
+
public event MuteListRequest OnMuteListRequest;
- public event AvatarInterestUpdate OnAvatarInterestUpdate;
- public event PlacesQuery OnPlacesQuery;
- #endregion Events
+ //public event AvatarInterestUpdate OnAvatarInterestUpdate;
+
+ public event PlacesQuery OnPlacesQuery;
public void ActivateGesture(UUID assetId, UUID gestureId)
{
@@ -1323,13 +1850,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
public void SendStartPingCheck(byte seq)
{
StartPingCheckPacket pc = (StartPingCheckPacket)PacketPool.Instance.GetPacket(PacketType.StartPingCheck);
- pc.Header.Reliable = false;
-
- OutgoingPacket oldestPacket = m_udpClient.NeedAcks.GetOldest();
-
pc.PingID.PingID = seq;
- pc.PingID.OldestUnacked = (oldestPacket != null) ? oldestPacket.SequenceNumber : 0;
-
+ pc.Header.Reliable = false;
OutPacket(pc, ThrottleOutPacketType.Unknown);
}
@@ -1405,12 +1927,12 @@ namespace OpenSim.Region.ClientStack.LindenUDP
descend.ItemData[i].AssetID = item.AssetID;
descend.ItemData[i].CreatorID = item.CreatorIdAsUuid;
descend.ItemData[i].BaseMask = item.BasePermissions;
- descend.ItemData[i].Description = Util.StringToBytes256(item.Description);
+ descend.ItemData[i].Description = LLUtil.StringToPacketBytes(item.Description);
descend.ItemData[i].EveryoneMask = item.EveryOnePermissions;
descend.ItemData[i].OwnerMask = item.CurrentPermissions;
descend.ItemData[i].FolderID = item.Folder;
descend.ItemData[i].InvType = (sbyte)item.InvType;
- descend.ItemData[i].Name = Util.StringToBytes256(item.Name);
+ descend.ItemData[i].Name = LLUtil.StringToPacketBytes(item.Name);
descend.ItemData[i].NextOwnerMask = item.NextPermissions;
descend.ItemData[i].OwnerID = item.Owner;
descend.ItemData[i].Type = (sbyte)item.AssetType;
@@ -1491,7 +2013,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
{
descend.FolderData[i] = new InventoryDescendentsPacket.FolderDataBlock();
descend.FolderData[i].FolderID = folder.ID;
- descend.FolderData[i].Name = Util.StringToBytes256(folder.Name);
+ descend.FolderData[i].Name = LLUtil.StringToPacketBytes(folder.Name);
descend.FolderData[i].ParentID = folder.ParentID;
descend.FolderData[i].Type = (sbyte)folder.Type;
@@ -1606,11 +2128,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
inventoryReply.InventoryData[0].BaseMask = item.BasePermissions;
inventoryReply.InventoryData[0].CreationDate = item.CreationDate;
- inventoryReply.InventoryData[0].Description = Util.StringToBytes256(item.Description);
+ inventoryReply.InventoryData[0].Description = LLUtil.StringToPacketBytes(item.Description);
inventoryReply.InventoryData[0].EveryoneMask = item.EveryOnePermissions;
inventoryReply.InventoryData[0].FolderID = item.Folder;
inventoryReply.InventoryData[0].InvType = (sbyte)item.InvType;
- inventoryReply.InventoryData[0].Name = Util.StringToBytes256(item.Name);
+ inventoryReply.InventoryData[0].Name = LLUtil.StringToPacketBytes(item.Name);
inventoryReply.InventoryData[0].NextOwnerMask = item.NextPermissions;
inventoryReply.InventoryData[0].OwnerID = item.Owner;
inventoryReply.InventoryData[0].OwnerMask = item.CurrentPermissions;
@@ -1735,7 +2257,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
folderBlock.FolderID = folder.ID;
folderBlock.ParentID = folder.ParentID;
folderBlock.Type = -1;
- folderBlock.Name = Util.StringToBytes256(folder.Name);
+ folderBlock.Name = LLUtil.StringToPacketBytes(folder.Name);
return folderBlock;
}
@@ -1753,11 +2275,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
itemBlock.AssetID = item.AssetID;
itemBlock.CreatorID = item.CreatorIdAsUuid;
itemBlock.BaseMask = item.BasePermissions;
- itemBlock.Description = Util.StringToBytes256(item.Description);
+ itemBlock.Description = LLUtil.StringToPacketBytes(item.Description);
itemBlock.EveryoneMask = item.EveryOnePermissions;
itemBlock.FolderID = item.Folder;
itemBlock.InvType = (sbyte)item.InvType;
- itemBlock.Name = Util.StringToBytes256(item.Name);
+ itemBlock.Name = LLUtil.StringToPacketBytes(item.Name);
itemBlock.NextOwnerMask = item.NextPermissions;
itemBlock.OwnerID = item.Owner;
itemBlock.OwnerMask = item.CurrentPermissions;
@@ -1817,11 +2339,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
bulkUpdate.ItemData[0].CreatorID = item.CreatorIdAsUuid;
bulkUpdate.ItemData[0].BaseMask = item.BasePermissions;
bulkUpdate.ItemData[0].CreationDate = item.CreationDate;
- bulkUpdate.ItemData[0].Description = Util.StringToBytes256(item.Description);
+ bulkUpdate.ItemData[0].Description = LLUtil.StringToPacketBytes(item.Description);
bulkUpdate.ItemData[0].EveryoneMask = item.EveryOnePermissions;
bulkUpdate.ItemData[0].FolderID = item.Folder;
bulkUpdate.ItemData[0].InvType = (sbyte)item.InvType;
- bulkUpdate.ItemData[0].Name = Util.StringToBytes256(item.Name);
+ bulkUpdate.ItemData[0].Name = LLUtil.StringToPacketBytes(item.Name);
bulkUpdate.ItemData[0].NextOwnerMask = item.NextPermissions;
bulkUpdate.ItemData[0].OwnerID = item.Owner;
bulkUpdate.ItemData[0].OwnerMask = item.CurrentPermissions;
@@ -1864,11 +2386,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
InventoryReply.InventoryData[0].AssetID = Item.AssetID;
InventoryReply.InventoryData[0].CreatorID = Item.CreatorIdAsUuid;
InventoryReply.InventoryData[0].BaseMask = Item.BasePermissions;
- InventoryReply.InventoryData[0].Description = Util.StringToBytes256(Item.Description);
+ InventoryReply.InventoryData[0].Description = LLUtil.StringToPacketBytes(Item.Description);
InventoryReply.InventoryData[0].EveryoneMask = Item.EveryOnePermissions;
InventoryReply.InventoryData[0].FolderID = Item.Folder;
InventoryReply.InventoryData[0].InvType = (sbyte)Item.InvType;
- InventoryReply.InventoryData[0].Name = Util.StringToBytes256(Item.Name);
+ InventoryReply.InventoryData[0].Name = LLUtil.StringToPacketBytes(Item.Name);
InventoryReply.InventoryData[0].NextOwnerMask = Item.NextPermissions;
InventoryReply.InventoryData[0].OwnerID = Item.Owner;
InventoryReply.InventoryData[0].OwnerMask = Item.CurrentPermissions;
@@ -2035,7 +2557,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
///
///
///
- public AgentAlertMessagePacket BuildAgentAlertPacket(string message, bool modal)
+ protected AgentAlertMessagePacket BuildAgentAlertPacket(string message, bool modal)
{
AgentAlertMessagePacket alertPack = (AgentAlertMessagePacket)PacketPool.Instance.GetPacket(PacketType.AgentAlertMessage);
alertPack.AgentData.AgentID = AgentId;
@@ -2246,8011 +2768,7983 @@ namespace OpenSim.Region.ClientStack.LindenUDP
OutPacket(avatarReply, ThrottleOutPacketType.Task);
}
- ///
- /// Send the client an Estate message blue box pop-down with a single OK button
- ///
- ///
- ///
- ///
- ///
- public void SendBlueBoxMessage(UUID FromAvatarID, String FromAvatarName, String Message)
- {
- if (!ChildAgentStatus())
- SendInstantMessage(new GridInstantMessage(null, FromAvatarID, FromAvatarName, AgentId, 1, Message, false, new Vector3()));
+ #endregion
- //SendInstantMessage(FromAvatarID, fromSessionID, Message, AgentId, SessionId, FromAvatarName, (byte)21,(uint) Util.UnixTimeSinceEpoch());
- }
+ // Gesture
- public void SendLogoutPacket()
+ #region Appearance/ Wearables Methods
+
+ public void SendWearables(AvatarWearable[] wearables, int serial)
{
- // I know this is a bit of a hack, however there are times when you don't
- // want to send this, but still need to do the rest of the shutdown process
- // this method gets called from the packet server.. which makes it practically
- // impossible to do any other way.
+ AgentWearablesUpdatePacket aw = (AgentWearablesUpdatePacket)PacketPool.Instance.GetPacket(PacketType.AgentWearablesUpdate);
+ aw.AgentData.AgentID = AgentId;
+ aw.AgentData.SerialNum = (uint)serial;
+ aw.AgentData.SessionID = m_sessionId;
- if (m_SendLogoutPacketWhenClosing)
+ // TODO: don't create new blocks if recycling an old packet
+ aw.WearableData = new AgentWearablesUpdatePacket.WearableDataBlock[13];
+ AgentWearablesUpdatePacket.WearableDataBlock awb;
+ for (int i = 0; i < wearables.Length; i++)
{
- LogoutReplyPacket logReply = (LogoutReplyPacket)PacketPool.Instance.GetPacket(PacketType.LogoutReply);
- // TODO: don't create new blocks if recycling an old packet
- logReply.AgentData.AgentID = AgentId;
- logReply.AgentData.SessionID = SessionId;
- logReply.InventoryData = new LogoutReplyPacket.InventoryDataBlock[1];
- logReply.InventoryData[0] = new LogoutReplyPacket.InventoryDataBlock();
- logReply.InventoryData[0].ItemID = UUID.Zero;
+ awb = new AgentWearablesUpdatePacket.WearableDataBlock();
+ awb.WearableType = (byte)i;
+ awb.AssetID = wearables[i].AssetID;
+ awb.ItemID = wearables[i].ItemID;
+ aw.WearableData[i] = awb;
- OutPacket(logReply, ThrottleOutPacketType.Task);
+// m_log.DebugFormat(
+// "[APPEARANCE]: Sending wearable item/asset {0} {1} (index {2}) for {3}",
+// awb.ItemID, awb.AssetID, i, Name);
}
- }
- public void SendHealth(float health)
- {
- HealthMessagePacket healthpacket = (HealthMessagePacket)PacketPool.Instance.GetPacket(PacketType.HealthMessage);
- healthpacket.HealthData.Health = health;
- OutPacket(healthpacket, ThrottleOutPacketType.Task);
+ OutPacket(aw, ThrottleOutPacketType.Task);
}
- public void SendAgentOnline(UUID[] agentIDs)
+ public void SendAppearance(UUID agentID, byte[] visualParams, byte[] textureEntry)
{
- OnlineNotificationPacket onp = new OnlineNotificationPacket();
- OnlineNotificationPacket.AgentBlockBlock[] onpb = new OnlineNotificationPacket.AgentBlockBlock[agentIDs.Length];
- for (int i = 0; i < agentIDs.Length; i++)
- {
- OnlineNotificationPacket.AgentBlockBlock onpbl = new OnlineNotificationPacket.AgentBlockBlock();
- onpbl.AgentID = agentIDs[i];
- onpb[i] = onpbl;
- }
- onp.AgentBlock = onpb;
- onp.Header.Reliable = true;
- OutPacket(onp, ThrottleOutPacketType.Task);
- }
+ AvatarAppearancePacket avp = (AvatarAppearancePacket)PacketPool.Instance.GetPacket(PacketType.AvatarAppearance);
+ // TODO: don't create new blocks if recycling an old packet
+ avp.VisualParam = new AvatarAppearancePacket.VisualParamBlock[218];
+ avp.ObjectData.TextureEntry = textureEntry;
- public void SendAgentOffline(UUID[] agentIDs)
- {
- OfflineNotificationPacket offp = new OfflineNotificationPacket();
- OfflineNotificationPacket.AgentBlockBlock[] offpb = new OfflineNotificationPacket.AgentBlockBlock[agentIDs.Length];
- for (int i = 0; i < agentIDs.Length; i++)
+ AvatarAppearancePacket.VisualParamBlock avblock = null;
+ for (int i = 0; i < visualParams.Length; i++)
{
- OfflineNotificationPacket.AgentBlockBlock onpbl = new OfflineNotificationPacket.AgentBlockBlock();
- onpbl.AgentID = agentIDs[i];
- offpb[i] = onpbl;
+ avblock = new AvatarAppearancePacket.VisualParamBlock();
+ avblock.ParamValue = visualParams[i];
+ avp.VisualParam[i] = avblock;
}
- offp.AgentBlock = offpb;
- offp.Header.Reliable = true;
- OutPacket(offp, ThrottleOutPacketType.Task);
+
+ avp.Sender.IsTrial = false;
+ avp.Sender.ID = agentID;
+ OutPacket(avp, ThrottleOutPacketType.Task);
}
- public void SendSitResponse(UUID TargetID, Vector3 OffsetPos, Quaternion SitOrientation, bool autopilot,
- Vector3 CameraAtOffset, Vector3 CameraEyeOffset, bool ForceMouseLook)
+ public void SendAnimations(UUID[] animations, int[] seqs, UUID sourceAgentId, UUID[] objectIDs)
{
- AvatarSitResponsePacket avatarSitResponse = new AvatarSitResponsePacket();
- avatarSitResponse.SitObject.ID = TargetID;
- if (CameraAtOffset != Vector3.Zero)
+ //m_log.DebugFormat("[CLIENT]: Sending animations to {0}", Name);
+
+ AvatarAnimationPacket ani = (AvatarAnimationPacket)PacketPool.Instance.GetPacket(PacketType.AvatarAnimation);
+ // TODO: don't create new blocks if recycling an old packet
+ ani.AnimationSourceList = new AvatarAnimationPacket.AnimationSourceListBlock[animations.Length];
+ ani.Sender = new AvatarAnimationPacket.SenderBlock();
+ ani.Sender.ID = sourceAgentId;
+ ani.AnimationList = new AvatarAnimationPacket.AnimationListBlock[animations.Length];
+ ani.PhysicalAvatarEventList = new AvatarAnimationPacket.PhysicalAvatarEventListBlock[0];
+
+ for (int i = 0; i < animations.Length; ++i)
{
- avatarSitResponse.SitTransform.CameraAtOffset = CameraAtOffset;
- avatarSitResponse.SitTransform.CameraEyeOffset = CameraEyeOffset;
- }
- avatarSitResponse.SitTransform.ForceMouselook = ForceMouseLook;
- avatarSitResponse.SitTransform.AutoPilot = autopilot;
- avatarSitResponse.SitTransform.SitPosition = OffsetPos;
- avatarSitResponse.SitTransform.SitRotation = SitOrientation;
+ ani.AnimationList[i] = new AvatarAnimationPacket.AnimationListBlock();
+ ani.AnimationList[i].AnimID = animations[i];
+ ani.AnimationList[i].AnimSequenceID = seqs[i];
- OutPacket(avatarSitResponse, ThrottleOutPacketType.Task);
+ ani.AnimationSourceList[i] = new AvatarAnimationPacket.AnimationSourceListBlock();
+ ani.AnimationSourceList[i].ObjectID = objectIDs[i];
+ if (objectIDs[i] == UUID.Zero)
+ ani.AnimationSourceList[i].ObjectID = sourceAgentId;
+ }
+ ani.Header.Reliable = false;
+ OutPacket(ani, ThrottleOutPacketType.Task);
}
- public void SendAdminResponse(UUID Token, uint AdminLevel)
- {
- GrantGodlikePowersPacket respondPacket = new GrantGodlikePowersPacket();
- GrantGodlikePowersPacket.GrantDataBlock gdb = new GrantGodlikePowersPacket.GrantDataBlock();
- GrantGodlikePowersPacket.AgentDataBlock adb = new GrantGodlikePowersPacket.AgentDataBlock();
+ #endregion
- adb.AgentID = AgentId;
- adb.SessionID = SessionId; // More security
- gdb.GodLevel = (byte)AdminLevel;
- gdb.Token = Token;
- //respondPacket.AgentData = (GrantGodlikePowersPacket.AgentDataBlock)ablock;
- respondPacket.GrantData = gdb;
- respondPacket.AgentData = adb;
- OutPacket(respondPacket, ThrottleOutPacketType.Task);
- }
+ #region Avatar Packet/data sending Methods
- public void SendGroupMembership(GroupMembershipData[] GroupMembership)
+ ///
+ /// send a objectupdate packet with information about the clients avatar
+ ///
+ public void SendAvatarData(ulong regionHandle, string firstName, string lastName, string grouptitle, UUID avatarID,
+ uint avatarLocalID, Vector3 Pos, byte[] textureEntry, uint parentID, Quaternion rotation)
{
- m_groupPowers.Clear();
+ ObjectUpdatePacket objupdate = (ObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdate);
+ // TODO: don't create new blocks if recycling an old packet
+ objupdate.RegionData.RegionHandle = regionHandle;
+ objupdate.RegionData.TimeDilation = ushort.MaxValue;
+ objupdate.ObjectData = new ObjectUpdatePacket.ObjectDataBlock[1];
+ objupdate.ObjectData[0] = CreateDefaultAvatarPacket(textureEntry);
- AgentGroupDataUpdatePacket Groupupdate = new AgentGroupDataUpdatePacket();
- AgentGroupDataUpdatePacket.GroupDataBlock[] Groups = new AgentGroupDataUpdatePacket.GroupDataBlock[GroupMembership.Length];
- for (int i = 0; i < GroupMembership.Length; i++)
- {
- m_groupPowers[GroupMembership[i].GroupID] = GroupMembership[i].GroupPowers;
+ //give this avatar object a local id and assign the user a name
+ objupdate.ObjectData[0].ID = avatarLocalID;
+ objupdate.ObjectData[0].FullID = avatarID;
+ objupdate.ObjectData[0].ParentID = parentID;
+ objupdate.ObjectData[0].NameValue =
+ Utils.StringToBytes("FirstName STRING RW SV " + firstName + "\nLastName STRING RW SV " + lastName + "\nTitle STRING RW SV " + grouptitle);
- AgentGroupDataUpdatePacket.GroupDataBlock Group = new AgentGroupDataUpdatePacket.GroupDataBlock();
- Group.AcceptNotices = GroupMembership[i].AcceptNotices;
- Group.Contribution = GroupMembership[i].Contribution;
- Group.GroupID = GroupMembership[i].GroupID;
- Group.GroupInsigniaID = GroupMembership[i].GroupPicture;
- Group.GroupName = Utils.StringToBytes(GroupMembership[i].GroupName);
- Group.GroupPowers = GroupMembership[i].GroupPowers;
- Groups[i] = Group;
+ Vector3 pos2 = new Vector3(Pos.X, Pos.Y, Pos.Z);
+ byte[] pb = pos2.GetBytes();
+ Array.Copy(pb, 0, objupdate.ObjectData[0].ObjectData, 16, pb.Length);
+ byte[] rot = rotation.GetBytes();
+ Array.Copy(rot, 0, objupdate.ObjectData[0].ObjectData, 52, rot.Length);
- }
- Groupupdate.GroupData = Groups;
- Groupupdate.AgentData = new AgentGroupDataUpdatePacket.AgentDataBlock();
- Groupupdate.AgentData.AgentID = AgentId;
- OutPacket(Groupupdate, ThrottleOutPacketType.Task);
+ objupdate.Header.Zerocoded = true;
+ OutPacket(objupdate, ThrottleOutPacketType.Task);
+ }
- try
+ ///
+ /// Send a terse positional/rotation/velocity update about an avatar
+ /// to the client. This avatar can be that of the client itself.
+ ///
+ public virtual void SendAvatarTerseUpdate(ulong regionHandle,
+ ushort timeDilation, uint localID, Vector3 position,
+ Vector3 velocity, Quaternion rotation, UUID agentid)
+ {
+ if (rotation.X == rotation.Y &&
+ rotation.Y == rotation.Z &&
+ rotation.Z == rotation.W && rotation.W == 0)
+ rotation = Quaternion.Identity;
+
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock terseBlock =
+ CreateAvatarImprovedBlock(localID, position, velocity,rotation);
+
+ lock (m_avatarTerseUpdates)
{
- IEventQueue eq = Scene.RequestModuleInterface();
- if (eq != null)
+ m_avatarTerseUpdates.Add(terseBlock);
+
+ // If packet is full or own movement packet, send it.
+ if (m_avatarTerseUpdates.Count >= m_avatarTerseUpdatesPerPacket)
{
- eq.GroupMembership(Groupupdate, this.AgentId);
+ ProcessAvatarTerseUpdates(this, null);
+ }
+ else if (m_avatarTerseUpdates.Count == 1)
+ {
+ lock (m_avatarTerseUpdateTimer)
+ m_avatarTerseUpdateTimer.Start();
}
}
- catch (Exception ex)
- {
- m_log.Error("Unable to send group membership data via eventqueue - exception: " + ex.ToString());
- m_log.Warn("sending group membership data via UDP");
- OutPacket(Groupupdate, ThrottleOutPacketType.Task);
- }
- }
-
-
- public void SendGroupNameReply(UUID groupLLUID, string GroupName)
- {
- UUIDGroupNameReplyPacket pack = new UUIDGroupNameReplyPacket();
- UUIDGroupNameReplyPacket.UUIDNameBlockBlock[] uidnameblock = new UUIDGroupNameReplyPacket.UUIDNameBlockBlock[1];
- UUIDGroupNameReplyPacket.UUIDNameBlockBlock uidnamebloc = new UUIDGroupNameReplyPacket.UUIDNameBlockBlock();
- uidnamebloc.ID = groupLLUID;
- uidnamebloc.GroupName = Utils.StringToBytes(GroupName);
- uidnameblock[0] = uidnamebloc;
- pack.UUIDNameBlock = uidnameblock;
- OutPacket(pack, ThrottleOutPacketType.Task);
}
- public void SendLandStatReply(uint reportType, uint requestFlags, uint resultCount, LandStatReportItem[] lsrpia)
+ private void ProcessAvatarTerseUpdates(object sender, ElapsedEventArgs e)
{
- LandStatReplyPacket lsrp = new LandStatReplyPacket();
- // LandStatReplyPacket.RequestDataBlock lsreqdpb = new LandStatReplyPacket.RequestDataBlock();
- LandStatReplyPacket.ReportDataBlock[] lsrepdba = new LandStatReplyPacket.ReportDataBlock[lsrpia.Length];
- //LandStatReplyPacket.ReportDataBlock lsrepdb = new LandStatReplyPacket.ReportDataBlock();
- // lsrepdb.
- lsrp.RequestData.ReportType = reportType;
- lsrp.RequestData.RequestFlags = requestFlags;
- lsrp.RequestData.TotalObjectCount = resultCount;
- for (int i = 0; i < lsrpia.Length; i++)
+ lock (m_avatarTerseUpdates)
{
- LandStatReplyPacket.ReportDataBlock lsrepdb = new LandStatReplyPacket.ReportDataBlock();
- lsrepdb.LocationX = lsrpia[i].LocationX;
- lsrepdb.LocationY = lsrpia[i].LocationY;
- lsrepdb.LocationZ = lsrpia[i].LocationZ;
- lsrepdb.Score = lsrpia[i].Score;
- lsrepdb.TaskID = lsrpia[i].TaskID;
- lsrepdb.TaskLocalID = lsrpia[i].TaskLocalID;
- lsrepdb.TaskName = Utils.StringToBytes(lsrpia[i].TaskName);
- lsrepdb.OwnerName = Utils.StringToBytes(lsrpia[i].OwnerName);
- lsrepdba[i] = lsrepdb;
- }
- lsrp.ReportData = lsrepdba;
- OutPacket(lsrp, ThrottleOutPacketType.Task);
- }
+ ImprovedTerseObjectUpdatePacket terse = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ImprovedTerseObjectUpdate);
- public void SendScriptRunningReply(UUID objectID, UUID itemID, bool running)
- {
- ScriptRunningReplyPacket scriptRunningReply = new ScriptRunningReplyPacket();
- scriptRunningReply.Script.ObjectID = objectID;
- scriptRunningReply.Script.ItemID = itemID;
- scriptRunningReply.Script.Running = running;
+ terse.RegionData = new ImprovedTerseObjectUpdatePacket.RegionDataBlock();
- OutPacket(scriptRunningReply, ThrottleOutPacketType.Task);
- }
+ terse.RegionData.RegionHandle = Scene.RegionInfo.RegionHandle;
+ terse.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- public void SendAsset(AssetRequestToClient req)
- {
- //m_log.Debug("sending asset " + req.RequestAssetID);
- TransferInfoPacket Transfer = new TransferInfoPacket();
- Transfer.TransferInfo.ChannelType = 2;
- Transfer.TransferInfo.Status = 0;
- Transfer.TransferInfo.TargetType = 0;
- if (req.AssetRequestSource == 2)
- {
- Transfer.TransferInfo.Params = new byte[20];
- Array.Copy(req.RequestAssetID.GetBytes(), 0, Transfer.TransferInfo.Params, 0, 16);
- int assType = req.AssetInf.Type;
- Array.Copy(Utils.IntToBytes(assType), 0, Transfer.TransferInfo.Params, 16, 4);
- }
- else if (req.AssetRequestSource == 3)
- {
- Transfer.TransferInfo.Params = req.Params;
- // Transfer.TransferInfo.Params = new byte[100];
- //Array.Copy(req.RequestUser.AgentId.GetBytes(), 0, Transfer.TransferInfo.Params, 0, 16);
- //Array.Copy(req.RequestUser.SessionId.GetBytes(), 0, Transfer.TransferInfo.Params, 16, 16);
- }
- Transfer.TransferInfo.Size = req.AssetInf.Data.Length;
- Transfer.TransferInfo.TransferID = req.TransferRequestID;
- Transfer.Header.Zerocoded = true;
- OutPacket(Transfer, ThrottleOutPacketType.Asset);
+ int max = m_avatarTerseUpdatesPerPacket;
+ if (max > m_avatarTerseUpdates.Count)
+ max = m_avatarTerseUpdates.Count;
- if (req.NumPackets == 1)
- {
- TransferPacketPacket TransferPacket = new TransferPacketPacket();
- TransferPacket.TransferData.Packet = 0;
- TransferPacket.TransferData.ChannelType = 2;
- TransferPacket.TransferData.TransferID = req.TransferRequestID;
- TransferPacket.TransferData.Data = req.AssetInf.Data;
- TransferPacket.TransferData.Status = 1;
- TransferPacket.Header.Zerocoded = true;
- OutPacket(TransferPacket, ThrottleOutPacketType.Asset);
- }
- else
- {
- int processedLength = 0;
- int maxChunkSize = Settings.MAX_PACKET_SIZE - 100;
- int packetNumber = 0;
+ int count = 0;
+ int size = 0;
- while (processedLength < req.AssetInf.Data.Length)
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
+
+ for (count = 0 ; count < max ; count++)
{
- TransferPacketPacket TransferPacket = new TransferPacketPacket();
- TransferPacket.TransferData.Packet = packetNumber;
- TransferPacket.TransferData.ChannelType = 2;
- TransferPacket.TransferData.TransferID = req.TransferRequestID;
+ int length = 0;
+ m_avatarTerseUpdates[count].ToBytes(blockbuffer, ref length);
+ length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
+ if (size + length > m_packetMTU)
+ break;
+ size += length;
+ }
- int chunkSize = Math.Min(req.AssetInf.Data.Length - processedLength, maxChunkSize);
- byte[] chunk = new byte[chunkSize];
- Array.Copy(req.AssetInf.Data, processedLength, chunk, 0, chunk.Length);
+ terse.ObjectData = new ImprovedTerseObjectUpdatePacket.ObjectDataBlock[count];
- TransferPacket.TransferData.Data = chunk;
+ for (int i = 0 ; i < count ; i++)
+ {
+ terse.ObjectData[i] = m_avatarTerseUpdates[0];
+ m_avatarTerseUpdates.RemoveAt(0);
+ }
- // 0 indicates more packets to come, 1 indicates last packet
- if (req.AssetInf.Data.Length - processedLength > maxChunkSize)
- {
- TransferPacket.TransferData.Status = 0;
- }
- else
- {
- TransferPacket.TransferData.Status = 1;
- }
- TransferPacket.Header.Zerocoded = true;
- OutPacket(TransferPacket, ThrottleOutPacketType.Asset);
+ terse.Header.Reliable = false;
+ terse.Header.Zerocoded = true;
+ OutPacket(terse, ThrottleOutPacketType.Task);
- processedLength += chunkSize;
- packetNumber++;
+ if (m_avatarTerseUpdates.Count == 0)
+ {
+ lock (m_avatarTerseUpdateTimer)
+ m_avatarTerseUpdateTimer.Stop();
}
}
}
- public void SendTexture(AssetBase TextureAsset)
- {
-
- }
-
- public void SendRegionHandle(UUID regionID, ulong handle)
- {
- RegionIDAndHandleReplyPacket reply = (RegionIDAndHandleReplyPacket)PacketPool.Instance.GetPacket(PacketType.RegionIDAndHandleReply);
- reply.ReplyBlock.RegionID = regionID;
- reply.ReplyBlock.RegionHandle = handle;
- OutPacket(reply, ThrottleOutPacketType.Land);
- }
-
- public void SendParcelInfo(RegionInfo info, LandData land, UUID parcelID, uint x, uint y)
+ public void SendCoarseLocationUpdate(List users, List CoarseLocations)
{
- ParcelInfoReplyPacket reply = (ParcelInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelInfoReply);
- reply.AgentData.AgentID = m_agentId;
- reply.Data.ParcelID = parcelID;
- reply.Data.OwnerID = land.OwnerID;
- reply.Data.Name = Utils.StringToBytes(land.Name);
- reply.Data.Desc = Utils.StringToBytes(land.Description);
- reply.Data.ActualArea = land.Area;
- reply.Data.BillableArea = land.Area; // TODO: what is this?
+ if (!IsActive) return; // We don't need to update inactive clients.
- // Bit 0: Mature, bit 7: on sale, other bits: no idea
- reply.Data.Flags = (byte)(
- ((land.Flags & (uint)ParcelFlags.MaturePublish) != 0 ? (1 << 0) : 0) +
- ((land.Flags & (uint)ParcelFlags.ForSale) != 0 ? (1 << 7) : 0));
+ CoarseLocationUpdatePacket loc = (CoarseLocationUpdatePacket)PacketPool.Instance.GetPacket(PacketType.CoarseLocationUpdate);
+ // TODO: don't create new blocks if recycling an old packet
+ int total = CoarseLocations.Count;
+ CoarseLocationUpdatePacket.IndexBlock ib =
+ new CoarseLocationUpdatePacket.IndexBlock();
+ loc.Location = new CoarseLocationUpdatePacket.LocationBlock[total];
+ loc.AgentData = new CoarseLocationUpdatePacket.AgentDataBlock[total];
- Vector3 pos = land.UserLocation;
- if (pos.Equals(Vector3.Zero))
+ for (int i = 0; i < total; i++)
{
- pos = (land.AABBMax + land.AABBMin) * 0.5f;
+ CoarseLocationUpdatePacket.LocationBlock lb =
+ new CoarseLocationUpdatePacket.LocationBlock();
+ lb.X = (byte)CoarseLocations[i].X;
+ lb.Y = (byte)CoarseLocations[i].Y;
+
+ lb.Z = CoarseLocations[i].Z > 1024 ? (byte)0 : (byte)(CoarseLocations[i].Z * 0.25);
+ loc.Location[i] = lb;
+ loc.AgentData[i] = new CoarseLocationUpdatePacket.AgentDataBlock();
+ loc.AgentData[i].AgentID = users[i];
}
- reply.Data.GlobalX = info.RegionLocX * Constants.RegionSize + x;
- reply.Data.GlobalY = info.RegionLocY * Constants.RegionSize + y;
- reply.Data.GlobalZ = pos.Z;
- reply.Data.SimName = Utils.StringToBytes(info.RegionName);
- reply.Data.SnapshotID = land.SnapshotID;
- reply.Data.Dwell = land.Dwell;
- reply.Data.SalePrice = land.SalePrice;
- reply.Data.AuctionID = (int)land.AuctionID;
+ ib.You = -1;
+ ib.Prey = -1;
+ loc.Index = ib;
+ loc.Header.Reliable = false;
+ loc.Header.Zerocoded = true;
- OutPacket(reply, ThrottleOutPacketType.Land);
+ OutPacket(loc, ThrottleOutPacketType.Task);
}
- public void SendScriptTeleportRequest(string objName, string simName, Vector3 pos, Vector3 lookAt)
- {
- ScriptTeleportRequestPacket packet = (ScriptTeleportRequestPacket)PacketPool.Instance.GetPacket(PacketType.ScriptTeleportRequest);
+ #endregion
- packet.Data.ObjectName = Utils.StringToBytes(objName);
- packet.Data.SimName = Utils.StringToBytes(simName);
- packet.Data.SimPosition = pos;
- packet.Data.LookAt = lookAt;
+ #region Primitive Packet/data Sending Methods
- OutPacket(packet, ThrottleOutPacketType.Task);
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void AttachObject(uint localID, Quaternion rotation, byte attachPoint, UUID ownerID)
+ {
+ if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
+ return;
+
+ ObjectAttachPacket attach = (ObjectAttachPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAttach);
+ // TODO: don't create new blocks if recycling an old packet
+ attach.AgentData.AgentID = AgentId;
+ attach.AgentData.SessionID = m_sessionId;
+ attach.AgentData.AttachmentPoint = attachPoint;
+ attach.ObjectData = new ObjectAttachPacket.ObjectDataBlock[1];
+ attach.ObjectData[0] = new ObjectAttachPacket.ObjectDataBlock();
+ attach.ObjectData[0].ObjectLocalID = localID;
+ attach.ObjectData[0].Rotation = rotation;
+ attach.Header.Zerocoded = true;
+ OutPacket(attach, ThrottleOutPacketType.Task);
}
- public void SendDirPlacesReply(UUID queryID, DirPlacesReplyData[] data)
+ public void SendPrimitiveToClient(
+ ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
+ Vector3 pos, Vector3 vel, Vector3 acc, Quaternion rotation, Vector3 rvel,
+ uint flags, UUID objectID, UUID ownerID, string text, byte[] color,
+ uint parentID, byte[] particleSystem, byte clickAction, byte material)
{
- DirPlacesReplyPacket packet = (DirPlacesReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPlacesReply);
+ byte[] textureanim = new byte[0];
- packet.AgentData = new DirPlacesReplyPacket.AgentDataBlock();
+ SendPrimitiveToClient(regionHandle, timeDilation, localID, primShape, pos, vel,
+ acc, rotation, rvel, flags,
+ objectID, ownerID, text, color, parentID, particleSystem,
+ clickAction, material, textureanim, false, 0, UUID.Zero, UUID.Zero, 0, 0, 0);
+ }
- packet.QueryData = new DirPlacesReplyPacket.QueryDataBlock[1];
- packet.QueryData[0] = new DirPlacesReplyPacket.QueryDataBlock();
+ public void SendPrimitiveToClient(
+ ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
+ Vector3 pos, Vector3 velocity, Vector3 acceleration, Quaternion rotation, Vector3 rotational_velocity,
+ uint flags,
+ UUID objectID, UUID ownerID, string text, byte[] color, uint parentID, byte[] particleSystem,
+ byte clickAction, byte material, byte[] textureanim, bool attachment, uint AttachPoint, UUID AssetId, UUID SoundId, double SoundGain, byte SoundFlags, double SoundRadius)
+ {
- packet.QueryReplies =
- new DirPlacesReplyPacket.QueryRepliesBlock[data.Length];
+ if (AttachPoint > 30 && ownerID != AgentId) // Someone else's HUD
+ return;
+ if (primShape.PCode == 9 && primShape.State != 0 && parentID == 0)
+ return;
- packet.StatusData = new DirPlacesReplyPacket.StatusDataBlock[
- data.Length];
+ if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
+ rotation = Quaternion.Identity;
- packet.AgentData.AgentID = AgentId;
+ ObjectUpdatePacket.ObjectDataBlock objectData = CreatePrimUpdateBlock(primShape, flags);
- packet.QueryData[0].QueryID = queryID;
+ objectData.ID = localID;
+ objectData.FullID = objectID;
+ objectData.OwnerID = ownerID;
- int i = 0;
- foreach (DirPlacesReplyData d in data)
+ objectData.Text = LLUtil.StringToPacketBytes(text);
+ objectData.TextColor[0] = color[0];
+ objectData.TextColor[1] = color[1];
+ objectData.TextColor[2] = color[2];
+ objectData.TextColor[3] = color[3];
+ objectData.ParentID = parentID;
+ objectData.PSBlock = particleSystem;
+ objectData.ClickAction = clickAction;
+ objectData.Material = material;
+ objectData.Flags = 0;
+
+ if (attachment)
{
- packet.QueryReplies[i] =
- new DirPlacesReplyPacket.QueryRepliesBlock();
- packet.StatusData[i] = new DirPlacesReplyPacket.StatusDataBlock();
- packet.QueryReplies[i].ParcelID = d.parcelID;
- packet.QueryReplies[i].Name = Utils.StringToBytes(d.name);
- packet.QueryReplies[i].ForSale = d.forSale;
- packet.QueryReplies[i].Auction = d.auction;
- packet.QueryReplies[i].Dwell = d.dwell;
- packet.StatusData[i].Status = d.Status;
- i++;
+ // Necessary???
+ objectData.JointAxisOrAnchor = new Vector3(0, 0, 2);
+ objectData.JointPivot = new Vector3(0, 0, 0);
+
+ // Item from inventory???
+ objectData.NameValue =
+ Utils.StringToBytes("AttachItemID STRING RW SV " + AssetId.Guid);
+ objectData.State = (byte)((AttachPoint % 16) * 16 + (AttachPoint / 16));
}
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ // Xantor 20080528: Send sound info as well
+ // Xantor 20080530: Zero out everything if there's no SoundId, so zerocompression will work again
+ objectData.Sound = SoundId;
+ if (SoundId == UUID.Zero)
+ {
+ objectData.OwnerID = UUID.Zero;
+ objectData.Gain = 0.0f;
+ objectData.Radius = 0.0f;
+ objectData.Flags = 0;
+ }
+ else
+ {
+ objectData.OwnerID = ownerID;
+ objectData.Gain = (float)SoundGain;
+ objectData.Radius = (float)SoundRadius;
+ objectData.Flags = SoundFlags;
+ }
- public void SendDirPeopleReply(UUID queryID, DirPeopleReplyData[] data)
- {
- DirPeopleReplyPacket packet = (DirPeopleReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPeopleReply);
+ byte[] pb = pos.GetBytes();
+ Array.Copy(pb, 0, objectData.ObjectData, 0, pb.Length);
- packet.AgentData = new DirPeopleReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ byte[] vel = velocity.GetBytes();
+ Array.Copy(vel, 0, objectData.ObjectData, pb.Length, vel.Length);
- packet.QueryData = new DirPeopleReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ byte[] rot = rotation.GetBytes();
+ Array.Copy(rot, 0, objectData.ObjectData, 36, rot.Length);
- packet.QueryReplies = new DirPeopleReplyPacket.QueryRepliesBlock[
- data.Length];
+ byte[] rvel = rotational_velocity.GetBytes();
+ Array.Copy(rvel, 0, objectData.ObjectData, 36 + rot.Length, rvel.Length);
- int i = 0;
- foreach (DirPeopleReplyData d in data)
+ if (textureanim.Length > 0)
{
- packet.QueryReplies[i] = new DirPeopleReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].AgentID = d.agentID;
- packet.QueryReplies[i].FirstName =
- Utils.StringToBytes(d.firstName);
- packet.QueryReplies[i].LastName =
- Utils.StringToBytes(d.lastName);
- packet.QueryReplies[i].Group =
- Utils.StringToBytes(d.group);
- packet.QueryReplies[i].Online = d.online;
- packet.QueryReplies[i].Reputation = d.reputation;
- i++;
+ objectData.TextureAnim = textureanim;
}
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
-
- public void SendDirEventsReply(UUID queryID, DirEventsReplyData[] data)
- {
- DirEventsReplyPacket packet = (DirEventsReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirEventsReply);
-
- packet.AgentData = new DirEventsReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
-
- packet.QueryData = new DirEventsReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
-
- packet.QueryReplies = new DirEventsReplyPacket.QueryRepliesBlock[
- data.Length];
+ lock (m_primFullUpdates)
+ {
+ if (m_primFullUpdates.Count == 0)
+ m_primFullUpdateTimer.Start();
- packet.StatusData = new DirEventsReplyPacket.StatusDataBlock[
- data.Length];
+ m_primFullUpdates.Add(objectData);
- int i = 0;
- foreach (DirEventsReplyData d in data)
- {
- packet.QueryReplies[i] = new DirEventsReplyPacket.QueryRepliesBlock();
- packet.StatusData[i] = new DirEventsReplyPacket.StatusDataBlock();
- packet.QueryReplies[i].OwnerID = d.ownerID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].EventID = d.eventID;
- packet.QueryReplies[i].Date =
- Utils.StringToBytes(d.date);
- packet.QueryReplies[i].UnixTime = d.unixTime;
- packet.QueryReplies[i].EventFlags = d.eventFlags;
- packet.StatusData[i].Status = d.Status;
- i++;
+ if (m_primFullUpdates.Count >= m_primFullUpdatesPerPacket)
+ ProcessPrimFullUpdates(this, null);
}
-
- OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendDirGroupsReply(UUID queryID, DirGroupsReplyData[] data)
+ void HandleQueueEmpty(ThrottleOutPacketType queue)
{
- DirGroupsReplyPacket packet = (DirGroupsReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirGroupsReply);
-
- packet.AgentData = new DirGroupsReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
-
- packet.QueryData = new DirGroupsReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
-
- packet.QueryReplies = new DirGroupsReplyPacket.QueryRepliesBlock[
- data.Length];
-
- int i = 0;
- foreach (DirGroupsReplyData d in data)
+ switch (queue)
{
- packet.QueryReplies[i] = new DirGroupsReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].GroupID = d.groupID;
- packet.QueryReplies[i].GroupName =
- Utils.StringToBytes(d.groupName);
- packet.QueryReplies[i].Members = d.members;
- packet.QueryReplies[i].SearchOrder = d.searchOrder;
- i++;
+ case ThrottleOutPacketType.Texture:
+ ProcessTextureRequests();
+ break;
}
+ }
- OutPacket(packet, ThrottleOutPacketType.Task);
+ void ProcessTextureRequests()
+ {
+ if (m_imageManager != null)
+ m_imageManager.ProcessImageQueue(m_textureSendLimit, m_textureDataLimit);
}
- public void SendDirClassifiedReply(UUID queryID, DirClassifiedReplyData[] data)
+ void ProcessPrimFullUpdates(object sender, ElapsedEventArgs e)
{
- DirClassifiedReplyPacket packet = (DirClassifiedReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirClassifiedReply);
+ lock (m_primFullUpdates)
+ {
+ if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
+ {
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
- packet.AgentData = new DirClassifiedReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ return;
+ }
- packet.QueryData = new DirClassifiedReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ ObjectUpdatePacket outPacket =
+ (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
+ PacketType.ObjectUpdate);
- packet.QueryReplies = new DirClassifiedReplyPacket.QueryRepliesBlock[
- data.Length];
- packet.StatusData = new DirClassifiedReplyPacket.StatusDataBlock[
- data.Length];
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
- int i = 0;
- foreach (DirClassifiedReplyData d in data)
- {
- packet.QueryReplies[i] = new DirClassifiedReplyPacket.QueryRepliesBlock();
- packet.StatusData[i] = new DirClassifiedReplyPacket.StatusDataBlock();
- packet.QueryReplies[i].ClassifiedID = d.classifiedID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].ClassifiedFlags = d.classifiedFlags;
- packet.QueryReplies[i].CreationDate = d.creationDate;
- packet.QueryReplies[i].ExpirationDate = d.expirationDate;
- packet.QueryReplies[i].PriceForListing = d.price;
- packet.StatusData[i].Status = d.Status;
- i++;
- }
+ int max = m_primFullUpdates.Count;
+ if (max > m_primFullUpdatesPerPacket)
+ max = m_primFullUpdatesPerPacket;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ int count = 0;
+ int size = 0;
- public void SendDirLandReply(UUID queryID, DirLandReplyData[] data)
- {
- DirLandReplyPacket packet = (DirLandReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirLandReply);
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
- packet.AgentData = new DirLandReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ for (count = 0 ; count < max ; count++)
+ {
+ int length = 0;
+ m_primFullUpdates[count].ToBytes(blockbuffer, ref length);
+ length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
+ if (size + length > m_packetMTU)
+ break;
+ size += length;
+ }
- packet.QueryData = new DirLandReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ outPacket.ObjectData =
+ new ObjectUpdatePacket.ObjectDataBlock[count];
- packet.QueryReplies = new DirLandReplyPacket.QueryRepliesBlock[
- data.Length];
+ for (int index = 0 ; index < count ; index++)
+ {
+ outPacket.ObjectData[index] = m_primFullUpdates[0];
+ m_primFullUpdates.RemoveAt(0);
+ }
- int i = 0;
- foreach (DirLandReplyData d in data)
- {
- packet.QueryReplies[i] = new DirLandReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].ParcelID = d.parcelID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].Auction = d.auction;
- packet.QueryReplies[i].ForSale = d.forSale;
- packet.QueryReplies[i].SalePrice = d.salePrice;
- packet.QueryReplies[i].ActualArea = d.actualArea;
- i++;
- }
+ outPacket.Header.Zerocoded = true;
+ OutPacket(outPacket, ThrottleOutPacketType.Task | ThrottleOutPacketType.LowPriority);
- OutPacket(packet, ThrottleOutPacketType.Task);
+ if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
+ lock (m_primFullUpdateTimer)
+ m_primFullUpdateTimer.Stop();
+ }
}
- public void SendDirPopularReply(UUID queryID, DirPopularReplyData[] data)
+ ///
+ ///
+ ///
+ public void SendPrimTerseUpdate(ulong regionHandle, ushort timeDilation, uint localID, Vector3 position,
+ Quaternion rotation, Vector3 velocity, Vector3 rotationalvelocity, byte state, UUID AssetId, UUID ownerID, int attachPoint)
{
- DirPopularReplyPacket packet = (DirPopularReplyPacket)PacketPool.Instance.GetPacket(PacketType.DirPopularReply);
-
- packet.AgentData = new DirPopularReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
+ return;
- packet.QueryData = new DirPopularReplyPacket.QueryDataBlock();
- packet.QueryData.QueryID = queryID;
+ if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
+ rotation = Quaternion.Identity;
- packet.QueryReplies = new DirPopularReplyPacket.QueryRepliesBlock[
- data.Length];
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock objectData =
+ CreatePrimImprovedBlock(localID, position, rotation,
+ velocity, rotationalvelocity, state);
- int i = 0;
- foreach (DirPopularReplyData d in data)
+ lock (m_primTerseUpdates)
{
- packet.QueryReplies[i] = new DirPopularReplyPacket.QueryRepliesBlock();
- packet.QueryReplies[i].ParcelID = d.parcelID;
- packet.QueryReplies[i].Name =
- Utils.StringToBytes(d.name);
- packet.QueryReplies[i].Dwell = d.dwell;
- i++;
- }
+ if (m_primTerseUpdates.Count == 0)
+ m_primTerseUpdateTimer.Start();
- OutPacket(packet, ThrottleOutPacketType.Task);
+ m_primTerseUpdates.Add(objectData);
+
+ if (m_primTerseUpdates.Count >= m_primTerseUpdatesPerPacket)
+ ProcessPrimTerseUpdates(this, null);
+ }
}
- public void SendEventInfoReply(EventData data)
+ void ProcessPrimTerseUpdates(object sender, ElapsedEventArgs e)
{
- EventInfoReplyPacket packet = (EventInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.EventInfoReply);
+ lock (m_primTerseUpdates)
+ {
+ if (m_primTerseUpdates.Count == 0)
+ {
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
- packet.AgentData = new EventInfoReplyPacket.AgentDataBlock();
- packet.AgentData.AgentID = AgentId;
+ return;
+ }
- packet.EventData = new EventInfoReplyPacket.EventDataBlock();
- packet.EventData.EventID = data.eventID;
- packet.EventData.Creator = Utils.StringToBytes(data.creator);
- packet.EventData.Name = Utils.StringToBytes(data.name);
- packet.EventData.Category = Utils.StringToBytes(data.category);
- packet.EventData.Desc = Utils.StringToBytes(data.description);
- packet.EventData.Date = Utils.StringToBytes(data.date);
- packet.EventData.DateUTC = data.dateUTC;
- packet.EventData.Duration = data.duration;
- packet.EventData.Cover = data.cover;
- packet.EventData.Amount = data.amount;
- packet.EventData.SimName = Utils.StringToBytes(data.simName);
- packet.EventData.GlobalPos = new Vector3d(data.globalPos);
- packet.EventData.EventFlags = data.eventFlags;
+ ImprovedTerseObjectUpdatePacket outPacket =
+ (ImprovedTerseObjectUpdatePacket)
+ PacketPool.Instance.GetPacket(
+ PacketType.ImprovedTerseObjectUpdate);
- OutPacket(packet, ThrottleOutPacketType.Task);
+ outPacket.RegionData.RegionHandle =
+ Scene.RegionInfo.RegionHandle;
+ outPacket.RegionData.TimeDilation =
+ (ushort)(Scene.TimeDilation * ushort.MaxValue);
+
+ int max = m_primTerseUpdates.Count;
+ if (max > m_primTerseUpdatesPerPacket)
+ max = m_primTerseUpdatesPerPacket;
+
+ int count = 0;
+ int size = 0;
+
+ byte[] zerobuffer = new byte[1024];
+ byte[] blockbuffer = new byte[1024];
+
+ for (count = 0 ; count < max ; count++)
+ {
+ int length = 0;
+ m_primTerseUpdates[count].ToBytes(blockbuffer, ref length);
+ length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
+ if (size + length > m_packetMTU)
+ break;
+ size += length;
+ }
+
+ outPacket.ObjectData =
+ new ImprovedTerseObjectUpdatePacket.
+ ObjectDataBlock[count];
+
+ for (int index = 0 ; index < count ; index++)
+ {
+ outPacket.ObjectData[index] = m_primTerseUpdates[0];
+ m_primTerseUpdates.RemoveAt(0);
+ }
+
+ outPacket.Header.Reliable = false;
+ outPacket.Header.Zerocoded = true;
+ OutPacket(outPacket, ThrottleOutPacketType.Task | ThrottleOutPacketType.LowPriority);
+
+ if (m_primTerseUpdates.Count == 0)
+ lock (m_primTerseUpdateTimer)
+ m_primTerseUpdateTimer.Stop();
+ }
}
- public void SendMapItemReply(mapItemReply[] replies, uint mapitemtype, uint flags)
+ public void FlushPrimUpdates()
{
- MapItemReplyPacket mirplk = new MapItemReplyPacket();
- mirplk.AgentData.AgentID = AgentId;
- mirplk.RequestData.ItemType = mapitemtype;
- mirplk.Data = new MapItemReplyPacket.DataBlock[replies.Length];
- for (int i = 0; i < replies.Length; i++)
+ while (m_primFullUpdates.Count > 0)
{
- MapItemReplyPacket.DataBlock mrdata = new MapItemReplyPacket.DataBlock();
- mrdata.X = replies[i].x;
- mrdata.Y = replies[i].y;
- mrdata.ID = replies[i].id;
- mrdata.Extra = replies[i].Extra;
- mrdata.Extra2 = replies[i].Extra2;
- mrdata.Name = Utils.StringToBytes(replies[i].name);
- mirplk.Data[i] = mrdata;
+ ProcessPrimFullUpdates(this, null);
+ }
+ while (m_primTerseUpdates.Count > 0)
+ {
+ ProcessPrimTerseUpdates(this, null);
+ }
+ while (m_avatarTerseUpdates.Count > 0)
+ {
+ ProcessAvatarTerseUpdates(this, null);
}
- //m_log.Debug(mirplk.ToString());
- OutPacket(mirplk, ThrottleOutPacketType.Task);
-
}
- public void SendOfferCallingCard(UUID srcID, UUID transactionID)
+ public void SendAssetUploadCompleteMessage(sbyte AssetType, bool Success, UUID AssetFullID)
{
- // a bit special, as this uses AgentID to store the source instead
- // of the destination. The destination (the receiver) goes into destID
- OfferCallingCardPacket p = (OfferCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.OfferCallingCard);
- p.AgentData.AgentID = srcID;
- p.AgentData.SessionID = UUID.Zero;
- p.AgentBlock.DestID = AgentId;
- p.AgentBlock.TransactionID = transactionID;
- OutPacket(p, ThrottleOutPacketType.Task);
+ AssetUploadCompletePacket newPack = new AssetUploadCompletePacket();
+ newPack.AssetBlock.Type = AssetType;
+ newPack.AssetBlock.Success = Success;
+ newPack.AssetBlock.UUID = AssetFullID;
+ newPack.Header.Zerocoded = true;
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
}
- public void SendAcceptCallingCard(UUID transactionID)
+ public void SendXferRequest(ulong XferID, short AssetType, UUID vFileID, byte FilePath, byte[] FileName)
{
- AcceptCallingCardPacket p = (AcceptCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.AcceptCallingCard);
- p.AgentData.AgentID = AgentId;
- p.AgentData.SessionID = UUID.Zero;
- p.FolderData = new AcceptCallingCardPacket.FolderDataBlock[1];
- p.FolderData[0] = new AcceptCallingCardPacket.FolderDataBlock();
- p.FolderData[0].FolderID = UUID.Zero;
- OutPacket(p, ThrottleOutPacketType.Task);
+ RequestXferPacket newPack = new RequestXferPacket();
+ newPack.XferID.ID = XferID;
+ newPack.XferID.VFileType = AssetType;
+ newPack.XferID.VFileID = vFileID;
+ newPack.XferID.FilePath = FilePath;
+ newPack.XferID.Filename = FileName;
+ newPack.Header.Zerocoded = true;
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
}
- public void SendDeclineCallingCard(UUID transactionID)
+ public void SendConfirmXfer(ulong xferID, uint PacketID)
{
- DeclineCallingCardPacket p = (DeclineCallingCardPacket)PacketPool.Instance.GetPacket(PacketType.DeclineCallingCard);
- p.AgentData.AgentID = AgentId;
- p.AgentData.SessionID = UUID.Zero;
- p.TransactionBlock.TransactionID = transactionID;
- OutPacket(p, ThrottleOutPacketType.Task);
+ ConfirmXferPacketPacket newPack = new ConfirmXferPacketPacket();
+ newPack.XferID.ID = xferID;
+ newPack.XferID.Packet = PacketID;
+ newPack.Header.Zerocoded = true;
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
}
-
- public void SendTerminateFriend(UUID exFriendID)
+
+ public void SendInitiateDownload(string simFileName, string clientFileName)
{
- TerminateFriendshipPacket p = (TerminateFriendshipPacket)PacketPool.Instance.GetPacket(PacketType.TerminateFriendship);
- p.AgentData.AgentID = AgentId;
- p.AgentData.SessionID = SessionId;
- p.ExBlock.OtherID = exFriendID;
- OutPacket(p, ThrottleOutPacketType.Task);
+ InitiateDownloadPacket newPack = new InitiateDownloadPacket();
+ newPack.AgentData.AgentID = AgentId;
+ newPack.FileData.SimFilename = Utils.StringToBytes(simFileName);
+ newPack.FileData.ViewerFilename = Utils.StringToBytes(clientFileName);
+ OutPacket(newPack, ThrottleOutPacketType.Asset);
}
-
- public void SendAvatarGroupsReply(UUID avatarID, GroupMembershipData[] data)
+
+ public void SendImageFirstPart(
+ ushort numParts, UUID ImageUUID, uint ImageSize, byte[] ImageData, byte imageCodec)
{
- AvatarGroupsReplyPacket p = (AvatarGroupsReplyPacket)PacketPool.Instance.GetPacket(PacketType.AvatarGroupsReply);
+ ImageDataPacket im = new ImageDataPacket();
+ im.Header.Reliable = false;
+ im.ImageID.Packets = numParts;
+ im.ImageID.ID = ImageUUID;
- p.AgentData = new AvatarGroupsReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = AgentId;
- p.AgentData.AvatarID = avatarID;
+ if (ImageSize > 0)
+ im.ImageID.Size = ImageSize;
- p.GroupData = new AvatarGroupsReplyPacket.GroupDataBlock[data.Length];
- int i = 0;
- foreach (GroupMembershipData m in data)
- {
- p.GroupData[i] = new AvatarGroupsReplyPacket.GroupDataBlock();
- p.GroupData[i].GroupPowers = m.GroupPowers;
- p.GroupData[i].AcceptNotices = m.AcceptNotices;
- p.GroupData[i].GroupTitle = Utils.StringToBytes(m.GroupTitle);
- p.GroupData[i].GroupID = m.GroupID;
- p.GroupData[i].GroupName = Utils.StringToBytes(m.GroupName);
- p.GroupData[i].GroupInsigniaID = m.GroupPicture;
- i++;
- }
+ im.ImageData.Data = ImageData;
+ im.ImageID.Codec = imageCodec;
+ im.Header.Zerocoded = true;
+ OutPacket(im, ThrottleOutPacketType.Texture);
+ }
- p.NewGroupData = new AvatarGroupsReplyPacket.NewGroupDataBlock();
- p.NewGroupData.ListInProfile = true;
+ public void SendImageNextPart(ushort partNumber, UUID imageUuid, byte[] imageData)
+ {
+ ImagePacketPacket im = new ImagePacketPacket();
+ im.Header.Reliable = false;
+ im.ImageID.Packet = partNumber;
+ im.ImageID.ID = imageUuid;
+ im.ImageData.Data = imageData;
- OutPacket(p, ThrottleOutPacketType.Task);
+ OutPacket(im, ThrottleOutPacketType.Texture);
}
- public void SendJoinGroupReply(UUID groupID, bool success)
+ public void SendImageNotFound(UUID imageid)
{
- JoinGroupReplyPacket p = (JoinGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.JoinGroupReply);
+ ImageNotInDatabasePacket notFoundPacket
+ = (ImageNotInDatabasePacket)PacketPool.Instance.GetPacket(PacketType.ImageNotInDatabase);
- p.AgentData = new JoinGroupReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = AgentId;
+ notFoundPacket.ImageID.ID = imageid;
- p.GroupData = new JoinGroupReplyPacket.GroupDataBlock();
- p.GroupData.GroupID = groupID;
- p.GroupData.Success = success;
+ OutPacket(notFoundPacket, ThrottleOutPacketType.Texture);
+ }
- OutPacket(p, ThrottleOutPacketType.Task);
+ public void SendShutdownConnectionNotice()
+ {
+ OutPacket(PacketPool.Instance.GetPacket(PacketType.DisableSimulator), ThrottleOutPacketType.Unknown);
}
- public void SendEjectGroupMemberReply(UUID agentID, UUID groupID, bool success)
+ public void SendSimStats(SimStats stats)
{
- EjectGroupMemberReplyPacket p = (EjectGroupMemberReplyPacket)PacketPool.Instance.GetPacket(PacketType.EjectGroupMemberReply);
+ SimStatsPacket pack = new SimStatsPacket();
+ pack.Region = new SimStatsPacket.RegionBlock();
+ pack.Region.RegionX = stats.RegionX;
+ pack.Region.RegionY = stats.RegionY;
+ pack.Region.RegionFlags = stats.RegionFlags;
+ pack.Region.ObjectCapacity = stats.ObjectCapacity;
+ //pack.Region = //stats.RegionBlock;
+ pack.Stat = stats.StatsBlock;
- p.AgentData = new EjectGroupMemberReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = agentID;
+ pack.Header.Reliable = false;
- p.GroupData = new EjectGroupMemberReplyPacket.GroupDataBlock();
- p.GroupData.GroupID = groupID;
+ OutPacket(pack, ThrottleOutPacketType.Task);
+ }
- p.EjectData = new EjectGroupMemberReplyPacket.EjectDataBlock();
- p.EjectData.Success = success;
+ public void SendObjectPropertiesFamilyData(uint RequestFlags, UUID ObjectUUID, UUID OwnerID, UUID GroupID,
+ uint BaseMask, uint OwnerMask, uint GroupMask, uint EveryoneMask,
+ uint NextOwnerMask, int OwnershipCost, byte SaleType, int SalePrice, uint Category,
+ UUID LastOwnerID, string ObjectName, string Description)
+ {
+ ObjectPropertiesFamilyPacket objPropFamilyPack = (ObjectPropertiesFamilyPacket)PacketPool.Instance.GetPacket(PacketType.ObjectPropertiesFamily);
+ // TODO: don't create new blocks if recycling an old packet
- OutPacket(p, ThrottleOutPacketType.Task);
+ ObjectPropertiesFamilyPacket.ObjectDataBlock objPropDB = new ObjectPropertiesFamilyPacket.ObjectDataBlock();
+ objPropDB.RequestFlags = RequestFlags;
+ objPropDB.ObjectID = ObjectUUID;
+ if (OwnerID == GroupID)
+ objPropDB.OwnerID = UUID.Zero;
+ else
+ objPropDB.OwnerID = OwnerID;
+ objPropDB.GroupID = GroupID;
+ objPropDB.BaseMask = BaseMask;
+ objPropDB.OwnerMask = OwnerMask;
+ objPropDB.GroupMask = GroupMask;
+ objPropDB.EveryoneMask = EveryoneMask;
+ objPropDB.NextOwnerMask = NextOwnerMask;
+
+ // TODO: More properties are needed in SceneObjectPart!
+ objPropDB.OwnershipCost = OwnershipCost;
+ objPropDB.SaleType = SaleType;
+ objPropDB.SalePrice = SalePrice;
+ objPropDB.Category = Category;
+ objPropDB.LastOwnerID = LastOwnerID;
+ objPropDB.Name = LLUtil.StringToPacketBytes(ObjectName);
+ objPropDB.Description = LLUtil.StringToPacketBytes(Description);
+ objPropFamilyPack.ObjectData = objPropDB;
+ objPropFamilyPack.Header.Zerocoded = true;
+ OutPacket(objPropFamilyPack, ThrottleOutPacketType.Task);
}
- public void SendLeaveGroupReply(UUID groupID, bool success)
+ public void SendObjectPropertiesReply(
+ UUID ItemID, ulong CreationDate, UUID CreatorUUID, UUID FolderUUID, UUID FromTaskUUID,
+ UUID GroupUUID, short InventorySerial, UUID LastOwnerUUID, UUID ObjectUUID,
+ UUID OwnerUUID, string TouchTitle, byte[] TextureID, string SitTitle, string ItemName,
+ string ItemDescription, uint OwnerMask, uint NextOwnerMask, uint GroupMask, uint EveryoneMask,
+ uint BaseMask, byte saleType, int salePrice)
{
- LeaveGroupReplyPacket p = (LeaveGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.LeaveGroupReply);
+ ObjectPropertiesPacket proper = (ObjectPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ObjectProperties);
+ // TODO: don't create new blocks if recycling an old packet
- p.AgentData = new LeaveGroupReplyPacket.AgentDataBlock();
- p.AgentData.AgentID = AgentId;
+ proper.ObjectData = new ObjectPropertiesPacket.ObjectDataBlock[1];
+ proper.ObjectData[0] = new ObjectPropertiesPacket.ObjectDataBlock();
+ proper.ObjectData[0].ItemID = ItemID;
+ proper.ObjectData[0].CreationDate = CreationDate;
+ proper.ObjectData[0].CreatorID = CreatorUUID;
+ proper.ObjectData[0].FolderID = FolderUUID;
+ proper.ObjectData[0].FromTaskID = FromTaskUUID;
+ proper.ObjectData[0].GroupID = GroupUUID;
+ proper.ObjectData[0].InventorySerial = InventorySerial;
- p.GroupData = new LeaveGroupReplyPacket.GroupDataBlock();
- p.GroupData.GroupID = groupID;
- p.GroupData.Success = success;
+ proper.ObjectData[0].LastOwnerID = LastOwnerUUID;
+ // proper.ObjectData[0].LastOwnerID = UUID.Zero;
- OutPacket(p, ThrottleOutPacketType.Task);
+ proper.ObjectData[0].ObjectID = ObjectUUID;
+ if (OwnerUUID == GroupUUID)
+ proper.ObjectData[0].OwnerID = UUID.Zero;
+ else
+ proper.ObjectData[0].OwnerID = OwnerUUID;
+ proper.ObjectData[0].TouchName = LLUtil.StringToPacketBytes(TouchTitle);
+ proper.ObjectData[0].TextureID = TextureID;
+ proper.ObjectData[0].SitName = LLUtil.StringToPacketBytes(SitTitle);
+ proper.ObjectData[0].Name = LLUtil.StringToPacketBytes(ItemName);
+ proper.ObjectData[0].Description = LLUtil.StringToPacketBytes(ItemDescription);
+ proper.ObjectData[0].OwnerMask = OwnerMask;
+ proper.ObjectData[0].NextOwnerMask = NextOwnerMask;
+ proper.ObjectData[0].GroupMask = GroupMask;
+ proper.ObjectData[0].EveryoneMask = EveryoneMask;
+ proper.ObjectData[0].BaseMask = BaseMask;
+ // proper.ObjectData[0].AggregatePerms = 53;
+ // proper.ObjectData[0].AggregatePermTextures = 0;
+ // proper.ObjectData[0].AggregatePermTexturesOwner = 0;
+ proper.ObjectData[0].SaleType = saleType;
+ proper.ObjectData[0].SalePrice = salePrice;
+ proper.Header.Zerocoded = true;
+ OutPacket(proper, ThrottleOutPacketType.Task);
}
- public void SendAvatarClassifiedReply(UUID targetID, UUID[] classifiedID, string[] name)
- {
- if (classifiedID.Length != name.Length)
- return;
-
- AvatarClassifiedReplyPacket ac =
- (AvatarClassifiedReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarClassifiedReply);
+ #endregion
- ac.AgentData = new AvatarClassifiedReplyPacket.AgentDataBlock();
- ac.AgentData.AgentID = AgentId;
- ac.AgentData.TargetID = targetID;
+ #region Estate Data Sending Methods
- ac.Data = new AvatarClassifiedReplyPacket.DataBlock[classifiedID.Length];
- int i;
- for (i = 0; i < classifiedID.Length; i++)
+ private static bool convertParamStringToBool(byte[] field)
+ {
+ string s = Utils.BytesToString(field);
+ if (s == "1" || s.ToLower() == "y" || s.ToLower() == "yes" || s.ToLower() == "t" || s.ToLower() == "true")
{
- ac.Data[i].ClassifiedID = classifiedID[i];
- ac.Data[i].Name = Utils.StringToBytes(name[i]);
+ return true;
}
-
- OutPacket(ac, ThrottleOutPacketType.Task);
+ return false;
}
- public void SendClassifiedInfoReply(UUID classifiedID, UUID creatorID, uint creationDate, uint expirationDate, uint category, string name, string description, UUID parcelID, uint parentEstate, UUID snapshotID, string simName, Vector3 globalPos, string parcelName, byte classifiedFlags, int price)
+ public void SendEstateManagersList(UUID invoice, UUID[] EstateManagers, uint estateID)
{
- ClassifiedInfoReplyPacket cr =
- (ClassifiedInfoReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.ClassifiedInfoReply);
+ EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
+ packet.AgentData.TransactionID = UUID.Random();
+ packet.AgentData.AgentID = AgentId;
+ packet.AgentData.SessionID = SessionId;
+ packet.MethodData.Invoice = invoice;
+ packet.MethodData.Method = Utils.StringToBytes("setaccess");
- cr.AgentData = new ClassifiedInfoReplyPacket.AgentDataBlock();
- cr.AgentData.AgentID = AgentId;
+ EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + EstateManagers.Length];
- cr.Data = new ClassifiedInfoReplyPacket.DataBlock();
- cr.Data.ClassifiedID = classifiedID;
- cr.Data.CreatorID = creatorID;
- cr.Data.CreationDate = creationDate;
- cr.Data.ExpirationDate = expirationDate;
- cr.Data.Category = category;
- cr.Data.Name = Utils.StringToBytes(name);
- cr.Data.Desc = Utils.StringToBytes(description);
- cr.Data.ParcelID = parcelID;
- cr.Data.ParentEstate = parentEstate;
- cr.Data.SnapshotID = snapshotID;
- cr.Data.SimName = Utils.StringToBytes(simName);
- cr.Data.PosGlobal = new Vector3d(globalPos);
- cr.Data.ParcelName = Utils.StringToBytes(parcelName);
- cr.Data.ClassifiedFlags = classifiedFlags;
- cr.Data.PriceForListing = price;
+ for (int i = 0; i < (6 + EstateManagers.Length); i++)
+ {
+ returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
+ }
+ int j = 0;
- OutPacket(cr, ThrottleOutPacketType.Task);
+ returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateManagers).ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(EstateManagers.Length.ToString()); j++;
+ for (int i = 0; i < EstateManagers.Length; i++)
+ {
+ returnblock[j].Parameter = EstateManagers[i].GetBytes(); j++;
+ }
+ packet.ParamList = returnblock;
+ packet.Header.Reliable = false;
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendAgentDropGroup(UUID groupID)
+ public void SendBannedUserList(UUID invoice, EstateBan[] bl, uint estateID)
{
- AgentDropGroupPacket dg =
- (AgentDropGroupPacket)PacketPool.Instance.GetPacket(
- PacketType.AgentDropGroup);
-
- dg.AgentData = new AgentDropGroupPacket.AgentDataBlock();
- dg.AgentData.AgentID = AgentId;
- dg.AgentData.GroupID = groupID;
+ ListBannedUsers = new List();
- OutPacket(dg, ThrottleOutPacketType.Task);
- }
+ for (int i = 0; i < bl.Length; i++)
+ {
+ if (bl[i] == null)
+ continue;
+ if (bl[i].BannedUserID == UUID.Zero)
+ continue;
+ BannedUsers.Add(bl[i].BannedUserID);
+ }
- public void SendAvatarNotesReply(UUID targetID, string text)
- {
- AvatarNotesReplyPacket an =
- (AvatarNotesReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarNotesReply);
-
- an.AgentData = new AvatarNotesReplyPacket.AgentDataBlock();
- an.AgentData.AgentID = AgentId;
-
- an.Data = new AvatarNotesReplyPacket.DataBlock();
- an.Data.TargetID = targetID;
- an.Data.Notes = Utils.StringToBytes(text);
-
- OutPacket(an, ThrottleOutPacketType.Task);
- }
+ EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
+ packet.AgentData.TransactionID = UUID.Random();
+ packet.AgentData.AgentID = AgentId;
+ packet.AgentData.SessionID = SessionId;
+ packet.MethodData.Invoice = invoice;
+ packet.MethodData.Method = Utils.StringToBytes("setaccess");
- public void SendAvatarPicksReply(UUID targetID, Dictionary picks)
- {
- AvatarPicksReplyPacket ap =
- (AvatarPicksReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarPicksReply);
+ EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + BannedUsers.Count];
- ap.AgentData = new AvatarPicksReplyPacket.AgentDataBlock();
- ap.AgentData.AgentID = AgentId;
- ap.AgentData.TargetID = targetID;
+ for (int i = 0; i < (6 + BannedUsers.Count); i++)
+ {
+ returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
+ }
+ int j = 0;
- ap.Data = new AvatarPicksReplyPacket.DataBlock[picks.Count];
+ returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateBans).ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ returnblock[j].Parameter = Utils.StringToBytes(BannedUsers.Count.ToString()); j++;
+ returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- int i = 0;
- foreach (KeyValuePair pick in picks)
+ foreach (UUID banned in BannedUsers)
{
- ap.Data[i] = new AvatarPicksReplyPacket.DataBlock();
- ap.Data[i].PickID = pick.Key;
- ap.Data[i].PickName = Utils.StringToBytes(pick.Value);
- i++;
+ returnblock[j].Parameter = banned.GetBytes(); j++;
}
-
- OutPacket(ap, ThrottleOutPacketType.Task);
+ packet.ParamList = returnblock;
+ packet.Header.Reliable = false;
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendAvatarClassifiedReply(UUID targetID, Dictionary classifieds)
+ public void SendRegionInfoToEstateMenu(RegionInfoForEstateMenuArgs args)
{
- AvatarClassifiedReplyPacket ac =
- (AvatarClassifiedReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.AvatarClassifiedReply);
-
- ac.AgentData = new AvatarClassifiedReplyPacket.AgentDataBlock();
- ac.AgentData.AgentID = AgentId;
- ac.AgentData.TargetID = targetID;
+ RegionInfoPacket rinfopack = new RegionInfoPacket();
+ RegionInfoPacket.RegionInfoBlock rinfoblk = new RegionInfoPacket.RegionInfoBlock();
+ rinfopack.AgentData.AgentID = AgentId;
+ rinfopack.AgentData.SessionID = SessionId;
+ rinfoblk.BillableFactor = args.billableFactor;
+ rinfoblk.EstateID = args.estateID;
+ rinfoblk.MaxAgents = args.maxAgents;
+ rinfoblk.ObjectBonusFactor = args.objectBonusFactor;
+ rinfoblk.ParentEstateID = args.parentEstateID;
+ rinfoblk.PricePerMeter = args.pricePerMeter;
+ rinfoblk.RedirectGridX = args.redirectGridX;
+ rinfoblk.RedirectGridY = args.redirectGridY;
+ rinfoblk.RegionFlags = args.regionFlags;
+ rinfoblk.SimAccess = args.simAccess;
+ rinfoblk.SunHour = args.sunHour;
+ rinfoblk.TerrainLowerLimit = args.terrainLowerLimit;
+ rinfoblk.TerrainRaiseLimit = args.terrainRaiseLimit;
+ rinfoblk.UseEstateSun = args.useEstateSun;
+ rinfoblk.WaterHeight = args.waterHeight;
+ rinfoblk.SimName = Utils.StringToBytes(args.simName);
+
+ rinfopack.RegionInfo2 = new RegionInfoPacket.RegionInfo2Block();
+ rinfopack.RegionInfo2.HardMaxAgents = uint.MaxValue;
+ rinfopack.RegionInfo2.HardMaxObjects = uint.MaxValue;
+ rinfopack.RegionInfo2.MaxAgents32 = uint.MaxValue;
+ rinfopack.RegionInfo2.ProductName = Utils.EmptyBytes;
+ rinfopack.RegionInfo2.ProductSKU = Utils.EmptyBytes;
- ac.Data = new AvatarClassifiedReplyPacket.DataBlock[classifieds.Count];
+ rinfopack.HasVariableBlocks = true;
+ rinfopack.RegionInfo = rinfoblk;
+ rinfopack.AgentData = new RegionInfoPacket.AgentDataBlock();
+ rinfopack.AgentData.AgentID = AgentId;
+ rinfopack.AgentData.SessionID = SessionId;
- int i = 0;
- foreach (KeyValuePair classified in classifieds)
- {
- ac.Data[i] = new AvatarClassifiedReplyPacket.DataBlock();
- ac.Data[i].ClassifiedID = classified.Key;
- ac.Data[i].Name = Utils.StringToBytes(classified.Value);
- i++;
- }
- OutPacket(ac, ThrottleOutPacketType.Task);
+ OutPacket(rinfopack, ThrottleOutPacketType.Task);
}
- public void SendParcelDwellReply(int localID, UUID parcelID, float dwell)
+ public void SendEstateCovenantInformation(UUID covenant)
{
- ParcelDwellReplyPacket pd =
- (ParcelDwellReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.ParcelDwellReply);
-
- pd.AgentData = new ParcelDwellReplyPacket.AgentDataBlock();
- pd.AgentData.AgentID = AgentId;
-
- pd.Data = new ParcelDwellReplyPacket.DataBlock();
- pd.Data.LocalID = localID;
- pd.Data.ParcelID = parcelID;
- pd.Data.Dwell = dwell;
-
- OutPacket(pd, ThrottleOutPacketType.Land);
+ EstateCovenantReplyPacket einfopack = new EstateCovenantReplyPacket();
+ EstateCovenantReplyPacket.DataBlock edata = new EstateCovenantReplyPacket.DataBlock();
+ edata.CovenantID = covenant;
+ edata.CovenantTimestamp = 0;
+ if (m_scene.RegionInfo.EstateSettings.EstateOwner != UUID.Zero)
+ edata.EstateOwnerID = m_scene.RegionInfo.EstateSettings.EstateOwner;
+ else
+ edata.EstateOwnerID = m_scene.RegionInfo.MasterAvatarAssignedUUID;
+ edata.EstateName = Utils.StringToBytes(m_scene.RegionInfo.EstateSettings.EstateName);
+ einfopack.Data = edata;
+ OutPacket(einfopack, ThrottleOutPacketType.Task);
}
- public void SendUserInfoReply(bool imViaEmail, bool visible, string email)
+ public void SendDetailedEstateData(UUID invoice, string estateName, uint estateID, uint parentEstate, uint estateFlags, uint sunPosition, UUID covenant, string abuseEmail, UUID estateOwner)
{
- UserInfoReplyPacket ur =
- (UserInfoReplyPacket)PacketPool.Instance.GetPacket(
- PacketType.UserInfoReply);
+ EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
+ packet.MethodData.Invoice = invoice;
+ packet.AgentData.TransactionID = UUID.Random();
+ packet.MethodData.Method = Utils.StringToBytes("estateupdateinfo");
+ EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[10];
- string Visible = "hidden";
- if (visible)
- Visible = "default";
+ for (int i = 0; i < 10; i++)
+ {
+ returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
+ }
- ur.AgentData = new UserInfoReplyPacket.AgentDataBlock();
- ur.AgentData.AgentID = AgentId;
+ //Sending Estate Settings
+ returnblock[0].Parameter = Utils.StringToBytes(estateName);
+ // TODO: remove this cruft once MasterAvatar is fully deprecated
+ //
+ returnblock[1].Parameter = Utils.StringToBytes(estateOwner.ToString());
+ returnblock[2].Parameter = Utils.StringToBytes(estateID.ToString());
- ur.UserData = new UserInfoReplyPacket.UserDataBlock();
- ur.UserData.IMViaEMail = imViaEmail;
- ur.UserData.DirectoryVisibility = Utils.StringToBytes(Visible);
- ur.UserData.EMail = Utils.StringToBytes(email);
+ returnblock[3].Parameter = Utils.StringToBytes(estateFlags.ToString());
+ returnblock[4].Parameter = Utils.StringToBytes(sunPosition.ToString());
+ returnblock[5].Parameter = Utils.StringToBytes(parentEstate.ToString());
+ returnblock[6].Parameter = Utils.StringToBytes(covenant.ToString());
+ returnblock[7].Parameter = Utils.StringToBytes("1160895077"); // what is this?
+ returnblock[8].Parameter = Utils.StringToBytes("1"); // what is this?
+ returnblock[9].Parameter = Utils.StringToBytes(abuseEmail);
- OutPacket(ur, ThrottleOutPacketType.Task);
+ packet.ParamList = returnblock;
+ packet.Header.Reliable = false;
+ //m_log.Debug("[ESTATE]: SIM--->" + packet.ToString());
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendCreateGroupReply(UUID groupID, bool success, string message)
- {
- CreateGroupReplyPacket createGroupReply = (CreateGroupReplyPacket)PacketPool.Instance.GetPacket(PacketType.CreateGroupReply);
-
- createGroupReply.AgentData =
- new CreateGroupReplyPacket.AgentDataBlock();
- createGroupReply.ReplyData =
- new CreateGroupReplyPacket.ReplyDataBlock();
+ #endregion
- createGroupReply.AgentData.AgentID = AgentId;
- createGroupReply.ReplyData.GroupID = groupID;
+ #region Land Data Sending Methods
- createGroupReply.ReplyData.Success = success;
- createGroupReply.ReplyData.Message = Utils.StringToBytes(message);
- OutPacket(createGroupReply, ThrottleOutPacketType.Task);
+ public void SendLandParcelOverlay(byte[] data, int sequence_id)
+ {
+ ParcelOverlayPacket packet = (ParcelOverlayPacket)PacketPool.Instance.GetPacket(PacketType.ParcelOverlay);
+ packet.ParcelData.Data = data;
+ packet.ParcelData.SequenceID = sequence_id;
+ packet.Header.Zerocoded = true;
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- public void SendUseCachedMuteList()
+ public void SendLandProperties(int sequence_id, bool snap_selection, int request_result, LandData landData, float simObjectBonusFactor, int parcelObjectCapacity, int simObjectCapacity, uint regionFlags)
{
- UseCachedMuteListPacket useCachedMuteList = (UseCachedMuteListPacket)PacketPool.Instance.GetPacket(PacketType.UseCachedMuteList);
-
- useCachedMuteList.AgentData = new UseCachedMuteListPacket.AgentDataBlock();
- useCachedMuteList.AgentData.AgentID = AgentId;
+ ParcelPropertiesPacket updatePacket = (ParcelPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ParcelProperties);
+ // TODO: don't create new blocks if recycling an old packet
- OutPacket(useCachedMuteList, ThrottleOutPacketType.Task);
- }
+ updatePacket.ParcelData.AABBMax = landData.AABBMax;
+ updatePacket.ParcelData.AABBMin = landData.AABBMin;
+ updatePacket.ParcelData.Area = landData.Area;
+ updatePacket.ParcelData.AuctionID = landData.AuctionID;
+ updatePacket.ParcelData.AuthBuyerID = landData.AuthBuyerID;
- public void SendMuteListUpdate(string filename)
- {
- MuteListUpdatePacket muteListUpdate = (MuteListUpdatePacket)PacketPool.Instance.GetPacket(PacketType.MuteListUpdate);
+ updatePacket.ParcelData.Bitmap = landData.Bitmap;
- muteListUpdate.MuteData = new MuteListUpdatePacket.MuteDataBlock();
- muteListUpdate.MuteData.AgentID = AgentId;
- muteListUpdate.MuteData.Filename = Utils.StringToBytes(filename);
+ updatePacket.ParcelData.Desc = Utils.StringToBytes(landData.Description);
+ updatePacket.ParcelData.Category = (byte)landData.Category;
+ updatePacket.ParcelData.ClaimDate = landData.ClaimDate;
+ updatePacket.ParcelData.ClaimPrice = landData.ClaimPrice;
+ updatePacket.ParcelData.GroupID = landData.GroupID;
+ updatePacket.ParcelData.GroupPrims = landData.GroupPrims;
+ updatePacket.ParcelData.IsGroupOwned = landData.IsGroupOwned;
+ updatePacket.ParcelData.LandingType = landData.LandingType;
+ updatePacket.ParcelData.LocalID = landData.LocalID;
- OutPacket(muteListUpdate, ThrottleOutPacketType.Task);
- }
+ if (landData.Area > 0)
+ {
+ updatePacket.ParcelData.MaxPrims = parcelObjectCapacity;
+ }
+ else
+ {
+ updatePacket.ParcelData.MaxPrims = 0;
+ }
- public void SendPickInfoReply(UUID pickID, UUID creatorID, bool topPick, UUID parcelID, string name, string desc, UUID snapshotID, string user, string originalName, string simName, Vector3 posGlobal, int sortOrder, bool enabled)
- {
- PickInfoReplyPacket pickInfoReply = (PickInfoReplyPacket)PacketPool.Instance.GetPacket(PacketType.PickInfoReply);
+ updatePacket.ParcelData.MediaAutoScale = landData.MediaAutoScale;
+ updatePacket.ParcelData.MediaID = landData.MediaID;
+ updatePacket.ParcelData.MediaURL = LLUtil.StringToPacketBytes(landData.MediaURL);
+ updatePacket.ParcelData.MusicURL = LLUtil.StringToPacketBytes(landData.MusicURL);
+ updatePacket.ParcelData.Name = Utils.StringToBytes(landData.Name);
+ updatePacket.ParcelData.OtherCleanTime = landData.OtherCleanTime;
+ updatePacket.ParcelData.OtherCount = 0; //unemplemented
+ updatePacket.ParcelData.OtherPrims = landData.OtherPrims;
+ updatePacket.ParcelData.OwnerID = landData.OwnerID;
+ updatePacket.ParcelData.OwnerPrims = landData.OwnerPrims;
+ updatePacket.ParcelData.ParcelFlags = landData.Flags;
+ updatePacket.ParcelData.ParcelPrimBonus = simObjectBonusFactor;
+ updatePacket.ParcelData.PassHours = landData.PassHours;
+ updatePacket.ParcelData.PassPrice = landData.PassPrice;
+ updatePacket.ParcelData.PublicCount = 0; //unemplemented
- pickInfoReply.AgentData = new PickInfoReplyPacket.AgentDataBlock();
- pickInfoReply.AgentData.AgentID = AgentId;
+ updatePacket.ParcelData.RegionDenyAnonymous = ((regionFlags & (uint)RegionFlags.DenyAnonymous) >
+ 0);
+ updatePacket.ParcelData.RegionDenyIdentified = ((regionFlags & (uint)RegionFlags.DenyIdentified) >
+ 0);
+ updatePacket.ParcelData.RegionDenyTransacted = ((regionFlags & (uint)RegionFlags.DenyTransacted) >
+ 0);
+ updatePacket.ParcelData.RegionPushOverride = ((regionFlags & (uint)RegionFlags.RestrictPushObject) >
+ 0);
- pickInfoReply.Data = new PickInfoReplyPacket.DataBlock();
- pickInfoReply.Data.PickID = pickID;
- pickInfoReply.Data.CreatorID = creatorID;
- pickInfoReply.Data.TopPick = topPick;
- pickInfoReply.Data.ParcelID = parcelID;
- pickInfoReply.Data.Name = Utils.StringToBytes(name);
- pickInfoReply.Data.Desc = Utils.StringToBytes(desc);
- pickInfoReply.Data.SnapshotID = snapshotID;
- pickInfoReply.Data.User = Utils.StringToBytes(user);
- pickInfoReply.Data.OriginalName = Utils.StringToBytes(originalName);
- pickInfoReply.Data.SimName = Utils.StringToBytes(simName);
- pickInfoReply.Data.PosGlobal = new Vector3d(posGlobal);
- pickInfoReply.Data.SortOrder = sortOrder;
- pickInfoReply.Data.Enabled = enabled;
+ updatePacket.ParcelData.RentPrice = 0;
+ updatePacket.ParcelData.RequestResult = request_result;
+ updatePacket.ParcelData.SalePrice = landData.SalePrice;
+ updatePacket.ParcelData.SelectedPrims = landData.SelectedPrims;
+ updatePacket.ParcelData.SelfCount = 0; //unemplemented
+ updatePacket.ParcelData.SequenceID = sequence_id;
+ if (landData.SimwideArea > 0)
+ {
+ updatePacket.ParcelData.SimWideMaxPrims = parcelObjectCapacity;
+ }
+ else
+ {
+ updatePacket.ParcelData.SimWideMaxPrims = 0;
+ }
+ updatePacket.ParcelData.SimWideTotalPrims = landData.SimwidePrims;
+ updatePacket.ParcelData.SnapSelection = snap_selection;
+ updatePacket.ParcelData.SnapshotID = landData.SnapshotID;
+ updatePacket.ParcelData.Status = (byte)landData.Status;
+ updatePacket.ParcelData.TotalPrims = landData.OwnerPrims + landData.GroupPrims + landData.OtherPrims +
+ landData.SelectedPrims;
+ updatePacket.ParcelData.UserLocation = landData.UserLocation;
+ updatePacket.ParcelData.UserLookAt = landData.UserLookAt;
+ updatePacket.Header.Zerocoded = true;
- OutPacket(pickInfoReply, ThrottleOutPacketType.Task);
+ try
+ {
+ IEventQueue eq = Scene.RequestModuleInterface();
+ if (eq != null)
+ {
+ eq.ParcelProperties(updatePacket, this.AgentId);
+ }
+ }
+ catch (Exception ex)
+ {
+ m_log.Error("Unable to send parcel data via eventqueue - exception: " + ex.ToString());
+ m_log.Warn("sending parcel data via UDP");
+ OutPacket(updatePacket, ThrottleOutPacketType.Task);
+ }
}
- #endregion Scene/Avatar to Client
-
- // Gesture
-
- #region Appearance/ Wearables Methods
-
- public void SendWearables(AvatarWearable[] wearables, int serial)
+ public void SendLandAccessListData(List avatars, uint accessFlag, int localLandID)
{
- AgentWearablesUpdatePacket aw = (AgentWearablesUpdatePacket)PacketPool.Instance.GetPacket(PacketType.AgentWearablesUpdate);
- aw.AgentData.AgentID = AgentId;
- aw.AgentData.SerialNum = (uint)serial;
- aw.AgentData.SessionID = m_sessionId;
+ ParcelAccessListReplyPacket replyPacket = (ParcelAccessListReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelAccessListReply);
+ replyPacket.Data.AgentID = AgentId;
+ replyPacket.Data.Flags = accessFlag;
+ replyPacket.Data.LocalID = localLandID;
+ replyPacket.Data.SequenceID = 0;
- // TODO: don't create new blocks if recycling an old packet
- aw.WearableData = new AgentWearablesUpdatePacket.WearableDataBlock[13];
- AgentWearablesUpdatePacket.WearableDataBlock awb;
- for (int i = 0; i < wearables.Length; i++)
+ List list = new List();
+ foreach (UUID avatar in avatars)
{
- awb = new AgentWearablesUpdatePacket.WearableDataBlock();
- awb.WearableType = (byte)i;
- awb.AssetID = wearables[i].AssetID;
- awb.ItemID = wearables[i].ItemID;
- aw.WearableData[i] = awb;
-
-// m_log.DebugFormat(
-// "[APPEARANCE]: Sending wearable item/asset {0} {1} (index {2}) for {3}",
-// awb.ItemID, awb.AssetID, i, Name);
+ ParcelAccessListReplyPacket.ListBlock block = new ParcelAccessListReplyPacket.ListBlock();
+ block.Flags = accessFlag;
+ block.ID = avatar;
+ block.Time = 0;
+ list.Add(block);
}
- OutPacket(aw, ThrottleOutPacketType.Task);
+ replyPacket.List = list.ToArray();
+ replyPacket.Header.Zerocoded = true;
+ OutPacket(replyPacket, ThrottleOutPacketType.Task);
}
- public void SendAppearance(UUID agentID, byte[] visualParams, byte[] textureEntry)
+ public void SendForceClientSelectObjects(List ObjectIDs)
{
- AvatarAppearancePacket avp = (AvatarAppearancePacket)PacketPool.Instance.GetPacket(PacketType.AvatarAppearance);
- // TODO: don't create new blocks if recycling an old packet
- avp.VisualParam = new AvatarAppearancePacket.VisualParamBlock[218];
- avp.ObjectData.TextureEntry = textureEntry;
-
- AvatarAppearancePacket.VisualParamBlock avblock = null;
- for (int i = 0; i < visualParams.Length; i++)
+ bool firstCall = true;
+ const int MAX_OBJECTS_PER_PACKET = 251;
+ ForceObjectSelectPacket pack = (ForceObjectSelectPacket)PacketPool.Instance.GetPacket(PacketType.ForceObjectSelect);
+ ForceObjectSelectPacket.DataBlock[] data;
+ while (ObjectIDs.Count > 0)
{
- avblock = new AvatarAppearancePacket.VisualParamBlock();
- avblock.ParamValue = visualParams[i];
- avp.VisualParam[i] = avblock;
+ if (firstCall)
+ {
+ pack._Header.ResetList = true;
+ firstCall = false;
+ }
+ else
+ {
+ pack._Header.ResetList = false;
+ }
+
+ if (ObjectIDs.Count > MAX_OBJECTS_PER_PACKET)
+ {
+ data = new ForceObjectSelectPacket.DataBlock[MAX_OBJECTS_PER_PACKET];
+ }
+ else
+ {
+ data = new ForceObjectSelectPacket.DataBlock[ObjectIDs.Count];
+ }
+
+ int i;
+ for (i = 0; i < MAX_OBJECTS_PER_PACKET && ObjectIDs.Count > 0; i++)
+ {
+ data[i] = new ForceObjectSelectPacket.DataBlock();
+ data[i].LocalID = Convert.ToUInt32(ObjectIDs[0]);
+ ObjectIDs.RemoveAt(0);
+ }
+ pack.Data = data;
+ pack.Header.Zerocoded = true;
+ OutPacket(pack, ThrottleOutPacketType.Task);
}
+ }
- avp.Sender.IsTrial = false;
- avp.Sender.ID = agentID;
- OutPacket(avp, ThrottleOutPacketType.Task);
+ public void SendCameraConstraint(Vector4 ConstraintPlane)
+ {
+ CameraConstraintPacket cpack = (CameraConstraintPacket)PacketPool.Instance.GetPacket(PacketType.CameraConstraint);
+ cpack.CameraCollidePlane = new CameraConstraintPacket.CameraCollidePlaneBlock();
+ cpack.CameraCollidePlane.Plane = ConstraintPlane;
+ //m_log.DebugFormat("[CLIENTVIEW]: Constraint {0}", ConstraintPlane);
+ OutPacket(cpack, ThrottleOutPacketType.Task);
}
- public void SendAnimations(UUID[] animations, int[] seqs, UUID sourceAgentId, UUID[] objectIDs)
+ public void SendLandObjectOwners(LandData land, List groups, Dictionary ownersAndCount)
{
- //m_log.DebugFormat("[CLIENT]: Sending animations to {0}", Name);
+
- AvatarAnimationPacket ani = (AvatarAnimationPacket)PacketPool.Instance.GetPacket(PacketType.AvatarAnimation);
- // TODO: don't create new blocks if recycling an old packet
- ani.AnimationSourceList = new AvatarAnimationPacket.AnimationSourceListBlock[animations.Length];
- ani.Sender = new AvatarAnimationPacket.SenderBlock();
- ani.Sender.ID = sourceAgentId;
- ani.AnimationList = new AvatarAnimationPacket.AnimationListBlock[animations.Length];
- ani.PhysicalAvatarEventList = new AvatarAnimationPacket.PhysicalAvatarEventListBlock[0];
+ int notifyCount = ownersAndCount.Count;
+ ParcelObjectOwnersReplyPacket pack = (ParcelObjectOwnersReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelObjectOwnersReply);
- for (int i = 0; i < animations.Length; ++i)
+ if (notifyCount > 0)
{
- ani.AnimationList[i] = new AvatarAnimationPacket.AnimationListBlock();
- ani.AnimationList[i].AnimID = animations[i];
- ani.AnimationList[i].AnimSequenceID = seqs[i];
+ if (notifyCount > 32)
+ {
+ m_log.InfoFormat(
+ "[LAND]: More than {0} avatars own prims on this parcel. Only sending back details of first {0}"
+ + " - a developer might want to investigate whether this is a hard limit", 32);
- ani.AnimationSourceList[i] = new AvatarAnimationPacket.AnimationSourceListBlock();
- ani.AnimationSourceList[i].ObjectID = objectIDs[i];
- if (objectIDs[i] == UUID.Zero)
- ani.AnimationSourceList[i].ObjectID = sourceAgentId;
- }
- ani.Header.Reliable = false;
- OutPacket(ani, ThrottleOutPacketType.Task);
- }
+ notifyCount = 32;
+ }
- #endregion
+ ParcelObjectOwnersReplyPacket.DataBlock[] dataBlock
+ = new ParcelObjectOwnersReplyPacket.DataBlock[notifyCount];
- #region Avatar Packet/data sending Methods
+ int num = 0;
+ foreach (UUID owner in ownersAndCount.Keys)
+ {
+ dataBlock[num] = new ParcelObjectOwnersReplyPacket.DataBlock();
+ dataBlock[num].Count = ownersAndCount[owner];
- ///
- /// send a objectupdate packet with information about the clients avatar
- ///
- public void SendAvatarData(ulong regionHandle, string firstName, string lastName, string grouptitle, UUID avatarID,
- uint avatarLocalID, Vector3 Pos, byte[] textureEntry, uint parentID, Quaternion rotation)
- {
- ObjectUpdatePacket objupdate = (ObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ObjectUpdate);
- // TODO: don't create new blocks if recycling an old packet
- objupdate.RegionData.RegionHandle = regionHandle;
- objupdate.RegionData.TimeDilation = ushort.MaxValue;
- objupdate.ObjectData = new ObjectUpdatePacket.ObjectDataBlock[1];
- objupdate.ObjectData[0] = CreateDefaultAvatarPacket(textureEntry);
+ if (land.GroupID == owner || groups.Contains(owner))
+ dataBlock[num].IsGroupOwned = true;
- //give this avatar object a local id and assign the user a name
- objupdate.ObjectData[0].ID = avatarLocalID;
- objupdate.ObjectData[0].FullID = avatarID;
- objupdate.ObjectData[0].ParentID = parentID;
- objupdate.ObjectData[0].NameValue =
- Utils.StringToBytes("FirstName STRING RW SV " + firstName + "\nLastName STRING RW SV " + lastName + "\nTitle STRING RW SV " + grouptitle);
+ dataBlock[num].OnlineStatus = true; //TODO: fix me later
+ dataBlock[num].OwnerID = owner;
- Vector3 pos2 = new Vector3(Pos.X, Pos.Y, Pos.Z);
- byte[] pb = pos2.GetBytes();
- Array.Copy(pb, 0, objupdate.ObjectData[0].ObjectData, 16, pb.Length);
+ num++;
- byte[] rot = rotation.GetBytes();
- Array.Copy(rot, 0, objupdate.ObjectData[0].ObjectData, 52, rot.Length);
+ if (num >= notifyCount)
+ {
+ break;
+ }
+ }
- objupdate.Header.Zerocoded = true;
- OutPacket(objupdate, ThrottleOutPacketType.Task);
+ pack.Data = dataBlock;
+ }
+ pack.Header.Zerocoded = true;
+ this.OutPacket(pack, ThrottleOutPacketType.Task);
}
- ///
- /// Send a terse positional/rotation/velocity update about an avatar
- /// to the client. This avatar can be that of the client itself.
- ///
- public virtual void SendAvatarTerseUpdate(ulong regionHandle,
- ushort timeDilation, uint localID, Vector3 position,
- Vector3 velocity, Quaternion rotation, UUID agentid)
+ #endregion
+
+ #region Helper Methods
+
+ protected ImprovedTerseObjectUpdatePacket.ObjectDataBlock CreateAvatarImprovedBlock(uint localID, Vector3 pos,
+ Vector3 velocity,
+ Quaternion rotation)
{
- if (rotation.X == rotation.Y &&
- rotation.Y == rotation.Z &&
- rotation.Z == rotation.W && rotation.W == 0)
- rotation = Quaternion.Identity;
+ byte[] bytes = new byte[60];
+ int i = 0;
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat = PacketPool.GetDataBlock();
- ImprovedTerseObjectUpdatePacket.ObjectDataBlock terseBlock =
- CreateAvatarImprovedBlock(localID, position, velocity,rotation);
-
- lock (m_avatarTerseUpdates)
- {
- m_avatarTerseUpdates.Add(terseBlock);
+ dat.TextureEntry = new byte[0]; // AvatarTemplate.TextureEntry;
- // If packet is full or own movement packet, send it.
- if (m_avatarTerseUpdates.Count >= m_avatarTerseUpdatesPerPacket)
- {
- ProcessAvatarTerseUpdates(this, null);
- }
- else if (m_avatarTerseUpdates.Count == 1)
- {
- lock (m_avatarTerseUpdateTimer)
- m_avatarTerseUpdateTimer.Start();
- }
- }
- }
-
- private void ProcessAvatarTerseUpdates(object sender, ElapsedEventArgs e)
- {
- lock (m_avatarTerseUpdates)
- {
- ImprovedTerseObjectUpdatePacket terse = (ImprovedTerseObjectUpdatePacket)PacketPool.Instance.GetPacket(PacketType.ImprovedTerseObjectUpdate);
-
- terse.RegionData = new ImprovedTerseObjectUpdatePacket.RegionDataBlock();
-
- terse.RegionData.RegionHandle = Scene.RegionInfo.RegionHandle;
- terse.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
-
- int max = m_avatarTerseUpdatesPerPacket;
- if (max > m_avatarTerseUpdates.Count)
- max = m_avatarTerseUpdates.Count;
+ uint ID = localID;
- int count = 0;
- int size = 0;
+ bytes[i++] = (byte)(ID % 256);
+ bytes[i++] = (byte)((ID >> 8) % 256);
+ bytes[i++] = (byte)((ID >> 16) % 256);
+ bytes[i++] = (byte)((ID >> 24) % 256);
+ bytes[i++] = 0;
+ bytes[i++] = 1;
+ i += 14;
+ bytes[i++] = 128;
+ bytes[i++] = 63;
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
+ byte[] pb = pos.GetBytes();
+ Array.Copy(pb, 0, bytes, i, pb.Length);
+ i += 12;
- for (count = 0 ; count < max ; count++)
- {
- int length = 0;
- m_avatarTerseUpdates[count].ToBytes(blockbuffer, ref length);
- length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
- if (size + length > m_packetMTU)
- break;
- size += length;
- }
+ Vector3 internDirec = new Vector3(velocity.X, velocity.Y, velocity.Z);
- terse.ObjectData = new ImprovedTerseObjectUpdatePacket.ObjectDataBlock[count];
+ internDirec = internDirec / 128.0f;
+ internDirec.X += 1;
+ internDirec.Y += 1;
+ internDirec.Z += 1;
- for (int i = 0 ; i < count ; i++)
- {
- terse.ObjectData[i] = m_avatarTerseUpdates[0];
- m_avatarTerseUpdates.RemoveAt(0);
- }
+ ushort InternVelocityX = (ushort)(32768 * internDirec.X);
+ ushort InternVelocityY = (ushort)(32768 * internDirec.Y);
+ ushort InternVelocityZ = (ushort)(32768 * internDirec.Z);
- terse.Header.Reliable = false;
- terse.Header.Zerocoded = true;
- OutPacket(terse, ThrottleOutPacketType.Task);
+ ushort ac = 32767;
+ bytes[i++] = (byte)(InternVelocityX % 256);
+ bytes[i++] = (byte)((InternVelocityX >> 8) % 256);
+ bytes[i++] = (byte)(InternVelocityY % 256);
+ bytes[i++] = (byte)((InternVelocityY >> 8) % 256);
+ bytes[i++] = (byte)(InternVelocityZ % 256);
+ bytes[i++] = (byte)((InternVelocityZ >> 8) % 256);
- if (m_avatarTerseUpdates.Count == 0)
- {
- lock (m_avatarTerseUpdateTimer)
- m_avatarTerseUpdateTimer.Stop();
- }
- }
- }
+ //accel
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
- public void SendCoarseLocationUpdate(List users, List CoarseLocations)
- {
- if (!IsActive) return; // We don't need to update inactive clients.
+ //rotation
+ ushort rw, rx, ry, rz;
+ rw = (ushort)(32768 * (rotation.W + 1));
+ rx = (ushort)(32768 * (rotation.X + 1));
+ ry = (ushort)(32768 * (rotation.Y + 1));
+ rz = (ushort)(32768 * (rotation.Z + 1));
- CoarseLocationUpdatePacket loc = (CoarseLocationUpdatePacket)PacketPool.Instance.GetPacket(PacketType.CoarseLocationUpdate);
- // TODO: don't create new blocks if recycling an old packet
- int total = CoarseLocations.Count;
- CoarseLocationUpdatePacket.IndexBlock ib =
- new CoarseLocationUpdatePacket.IndexBlock();
- loc.Location = new CoarseLocationUpdatePacket.LocationBlock[total];
- loc.AgentData = new CoarseLocationUpdatePacket.AgentDataBlock[total];
+ //rot
+ bytes[i++] = (byte)(rx % 256);
+ bytes[i++] = (byte)((rx >> 8) % 256);
+ bytes[i++] = (byte)(ry % 256);
+ bytes[i++] = (byte)((ry >> 8) % 256);
+ bytes[i++] = (byte)(rz % 256);
+ bytes[i++] = (byte)((rz >> 8) % 256);
+ bytes[i++] = (byte)(rw % 256);
+ bytes[i++] = (byte)((rw >> 8) % 256);
- for (int i = 0; i < total; i++)
- {
- CoarseLocationUpdatePacket.LocationBlock lb =
- new CoarseLocationUpdatePacket.LocationBlock();
- lb.X = (byte)CoarseLocations[i].X;
- lb.Y = (byte)CoarseLocations[i].Y;
+ //rotation vel
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
- lb.Z = CoarseLocations[i].Z > 1024 ? (byte)0 : (byte)(CoarseLocations[i].Z * 0.25);
- loc.Location[i] = lb;
- loc.AgentData[i] = new CoarseLocationUpdatePacket.AgentDataBlock();
- loc.AgentData[i].AgentID = users[i];
- }
- ib.You = -1;
- ib.Prey = -1;
- loc.Index = ib;
- loc.Header.Reliable = false;
- loc.Header.Zerocoded = true;
+ dat.Data = bytes;
- OutPacket(loc, ThrottleOutPacketType.Task);
+ return (dat);
}
- #endregion
-
- #region Primitive Packet/data Sending Methods
-
///
///
///
///
+ ///
///
- ///
- public void AttachObject(uint localID, Quaternion rotation, byte attachPoint, UUID ownerID)
+ ///
+ protected ImprovedTerseObjectUpdatePacket.ObjectDataBlock CreatePrimImprovedBlock(uint localID,
+ Vector3 position,
+ Quaternion rotation,
+ Vector3 velocity,
+ Vector3 rotationalvelocity,
+ byte state)
{
- if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
- return;
+ uint ID = localID;
+ byte[] bytes = new byte[60];
- ObjectAttachPacket attach = (ObjectAttachPacket)PacketPool.Instance.GetPacket(PacketType.ObjectAttach);
- // TODO: don't create new blocks if recycling an old packet
- attach.AgentData.AgentID = AgentId;
- attach.AgentData.SessionID = m_sessionId;
- attach.AgentData.AttachmentPoint = attachPoint;
- attach.ObjectData = new ObjectAttachPacket.ObjectDataBlock[1];
- attach.ObjectData[0] = new ObjectAttachPacket.ObjectDataBlock();
- attach.ObjectData[0].ObjectLocalID = localID;
- attach.ObjectData[0].Rotation = rotation;
- attach.Header.Zerocoded = true;
- OutPacket(attach, ThrottleOutPacketType.Task);
- }
+ int i = 0;
+ ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat = PacketPool.GetDataBlock();
+ dat.TextureEntry = new byte[0];
+ bytes[i++] = (byte)(ID % 256);
+ bytes[i++] = (byte)((ID >> 8) % 256);
+ bytes[i++] = (byte)((ID >> 16) % 256);
+ bytes[i++] = (byte)((ID >> 24) % 256);
+ bytes[i++] = (byte)(((state & 0xf0) >> 4) | ((state & 0x0f) << 4));
+ bytes[i++] = 0;
- public void SendPrimitiveToClient(
- ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
- Vector3 pos, Vector3 vel, Vector3 acc, Quaternion rotation, Vector3 rvel,
- uint flags, UUID objectID, UUID ownerID, string text, byte[] color,
- uint parentID, byte[] particleSystem, byte clickAction, byte material)
- {
- byte[] textureanim = new byte[0];
+ byte[] pb = position.GetBytes();
+ Array.Copy(pb, 0, bytes, i, pb.Length);
+ i += 12;
+ ushort ac = 32767;
- SendPrimitiveToClient(regionHandle, timeDilation, localID, primShape, pos, vel,
- acc, rotation, rvel, flags,
- objectID, ownerID, text, color, parentID, particleSystem,
- clickAction, material, textureanim, false, 0, UUID.Zero, UUID.Zero, 0, 0, 0);
- }
+ ushort velx, vely, velz;
+ Vector3 vel = new Vector3(velocity.X, velocity.Y, velocity.Z);
- public void SendPrimitiveToClient(
- ulong regionHandle, ushort timeDilation, uint localID, PrimitiveBaseShape primShape,
- Vector3 pos, Vector3 velocity, Vector3 acceleration, Quaternion rotation, Vector3 rotational_velocity,
- uint flags,
- UUID objectID, UUID ownerID, string text, byte[] color, uint parentID, byte[] particleSystem,
- byte clickAction, byte material, byte[] textureanim, bool attachment, uint AttachPoint, UUID AssetId, UUID SoundId, double SoundGain, byte SoundFlags, double SoundRadius)
- {
+ vel = vel / 128.0f;
+ vel.X += 1;
+ vel.Y += 1;
+ vel.Z += 1;
+ //vel
+ velx = (ushort)(32768 * (vel.X));
+ vely = (ushort)(32768 * (vel.Y));
+ velz = (ushort)(32768 * (vel.Z));
- if (AttachPoint > 30 && ownerID != AgentId) // Someone else's HUD
- return;
- if (primShape.PCode == 9 && primShape.State != 0 && parentID == 0)
- return;
+ bytes[i++] = (byte)(velx % 256);
+ bytes[i++] = (byte)((velx >> 8) % 256);
+ bytes[i++] = (byte)(vely % 256);
+ bytes[i++] = (byte)((vely >> 8) % 256);
+ bytes[i++] = (byte)(velz % 256);
+ bytes[i++] = (byte)((velz >> 8) % 256);
- if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
- rotation = Quaternion.Identity;
+ //accel
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
+ bytes[i++] = (byte)(ac % 256);
+ bytes[i++] = (byte)((ac >> 8) % 256);
- ObjectUpdatePacket.ObjectDataBlock objectData = CreatePrimUpdateBlock(primShape, flags);
+ ushort rw, rx, ry, rz;
+ rw = (ushort)(32768 * (rotation.W + 1));
+ rx = (ushort)(32768 * (rotation.X + 1));
+ ry = (ushort)(32768 * (rotation.Y + 1));
+ rz = (ushort)(32768 * (rotation.Z + 1));
- objectData.ID = localID;
- objectData.FullID = objectID;
- objectData.OwnerID = ownerID;
+ //rot
+ bytes[i++] = (byte)(rx % 256);
+ bytes[i++] = (byte)((rx >> 8) % 256);
+ bytes[i++] = (byte)(ry % 256);
+ bytes[i++] = (byte)((ry >> 8) % 256);
+ bytes[i++] = (byte)(rz % 256);
+ bytes[i++] = (byte)((rz >> 8) % 256);
+ bytes[i++] = (byte)(rw % 256);
+ bytes[i++] = (byte)((rw >> 8) % 256);
- objectData.Text = Util.StringToBytes256(text);
- objectData.TextColor[0] = color[0];
- objectData.TextColor[1] = color[1];
- objectData.TextColor[2] = color[2];
- objectData.TextColor[3] = color[3];
- objectData.ParentID = parentID;
- objectData.PSBlock = particleSystem;
- objectData.ClickAction = clickAction;
- objectData.Material = material;
- objectData.Flags = 0;
+ //rotation vel
+ Vector3 rvel = new Vector3(rotationalvelocity.X, rotationalvelocity.Y, rotationalvelocity.Z);
- if (attachment)
- {
- // Necessary???
- objectData.JointAxisOrAnchor = new Vector3(0, 0, 2);
- objectData.JointPivot = new Vector3(0, 0, 0);
+ rvel = rvel / 128.0f;
+ rvel.X += 1;
+ rvel.Y += 1;
+ rvel.Z += 1;
+ //vel
+ ushort rvelx = (ushort)(32768 * (rvel.X));
+ ushort rvely = (ushort)(32768 * (rvel.Y));
+ ushort rvelz = (ushort)(32768 * (rvel.Z));
- // Item from inventory???
- objectData.NameValue =
- Utils.StringToBytes("AttachItemID STRING RW SV " + AssetId.Guid);
- objectData.State = (byte)((AttachPoint % 16) * 16 + (AttachPoint / 16));
- }
+ bytes[i++] = (byte)(rvelx % 256);
+ bytes[i++] = (byte)((rvelx >> 8) % 256);
+ bytes[i++] = (byte)(rvely % 256);
+ bytes[i++] = (byte)((rvely >> 8) % 256);
+ bytes[i++] = (byte)(rvelz % 256);
+ bytes[i++] = (byte)((rvelz >> 8) % 256);
+ dat.Data = bytes;
- // Xantor 20080528: Send sound info as well
- // Xantor 20080530: Zero out everything if there's no SoundId, so zerocompression will work again
- objectData.Sound = SoundId;
- if (SoundId == UUID.Zero)
- {
- objectData.OwnerID = UUID.Zero;
- objectData.Gain = 0.0f;
- objectData.Radius = 0.0f;
- objectData.Flags = 0;
- }
- else
+ return dat;
+ }
+
+ ///
+ /// Create the ObjectDataBlock for a ObjectUpdatePacket (for a Primitive)
+ ///
+ ///
+ ///
+ protected ObjectUpdatePacket.ObjectDataBlock CreatePrimUpdateBlock(PrimitiveBaseShape primShape, uint flags)
+ {
+ ObjectUpdatePacket.ObjectDataBlock objupdate = PacketPool.GetDataBlock();
+ SetDefaultPrimPacketValues(objupdate);
+ objupdate.UpdateFlags = flags;
+ SetPrimPacketShapeData(objupdate, primShape);
+
+ if ((primShape.PCode == (byte)PCode.NewTree) || (primShape.PCode == (byte)PCode.Tree) || (primShape.PCode == (byte)PCode.Grass))
{
- objectData.OwnerID = ownerID;
- objectData.Gain = (float)SoundGain;
- objectData.Radius = (float)SoundRadius;
- objectData.Flags = SoundFlags;
+ objupdate.Data = new byte[1];
+ objupdate.Data[0] = primShape.State;
}
+ return objupdate;
+ }
- byte[] pb = pos.GetBytes();
- Array.Copy(pb, 0, objectData.ObjectData, 0, pb.Length);
+ protected void SetPrimPacketShapeData(ObjectUpdatePacket.ObjectDataBlock objectData, PrimitiveBaseShape primData)
+ {
+ objectData.TextureEntry = primData.TextureEntry;
+ objectData.PCode = primData.PCode;
+ objectData.State = primData.State;
+ objectData.PathBegin = primData.PathBegin;
+ objectData.PathEnd = primData.PathEnd;
+ objectData.PathScaleX = primData.PathScaleX;
+ objectData.PathScaleY = primData.PathScaleY;
+ objectData.PathShearX = primData.PathShearX;
+ objectData.PathShearY = primData.PathShearY;
+ objectData.PathSkew = primData.PathSkew;
+ objectData.ProfileBegin = primData.ProfileBegin;
+ objectData.ProfileEnd = primData.ProfileEnd;
+ objectData.Scale = primData.Scale;
+ objectData.PathCurve = primData.PathCurve;
+ objectData.ProfileCurve = primData.ProfileCurve;
+ objectData.ProfileHollow = primData.ProfileHollow;
+ objectData.PathRadiusOffset = primData.PathRadiusOffset;
+ objectData.PathRevolutions = primData.PathRevolutions;
+ objectData.PathTaperX = primData.PathTaperX;
+ objectData.PathTaperY = primData.PathTaperY;
+ objectData.PathTwist = primData.PathTwist;
+ objectData.PathTwistBegin = primData.PathTwistBegin;
+ objectData.ExtraParams = primData.ExtraParams;
+ }
- byte[] vel = velocity.GetBytes();
- Array.Copy(vel, 0, objectData.ObjectData, pb.Length, vel.Length);
+ ///
+ /// Set some default values in a ObjectUpdatePacket
+ ///
+ ///
+ protected void SetDefaultPrimPacketValues(ObjectUpdatePacket.ObjectDataBlock objdata)
+ {
+ objdata.PSBlock = new byte[0];
+ objdata.ExtraParams = new byte[1];
+ objdata.MediaURL = new byte[0];
+ objdata.NameValue = new byte[0];
+ objdata.Text = new byte[0];
+ objdata.TextColor = new byte[4];
+ objdata.JointAxisOrAnchor = new Vector3(0, 0, 0);
+ objdata.JointPivot = new Vector3(0, 0, 0);
+ objdata.Material = 3;
+ objdata.TextureAnim = new byte[0];
+ objdata.Sound = UUID.Zero;
+ objdata.State = 0;
+ objdata.Data = new byte[0];
- byte[] rot = rotation.GetBytes();
- Array.Copy(rot, 0, objectData.ObjectData, 36, rot.Length);
+ objdata.ObjectData = new byte[60];
+ objdata.ObjectData[46] = 128;
+ objdata.ObjectData[47] = 63;
+ }
- byte[] rvel = rotational_velocity.GetBytes();
- Array.Copy(rvel, 0, objectData.ObjectData, 36 + rot.Length, rvel.Length);
+ ///
+ ///
+ ///
+ ///
+ public ObjectUpdatePacket.ObjectDataBlock CreateDefaultAvatarPacket(byte[] textureEntry)
+ {
+ ObjectUpdatePacket.ObjectDataBlock objdata = PacketPool.GetDataBlock();
+ // new OpenMetaverse.Packets.ObjectUpdatePacket.ObjectDataBlock(data1, ref i);
- if (textureanim.Length > 0)
+ SetDefaultAvatarPacketValues(ref objdata);
+ objdata.UpdateFlags = 61 + (9 << 8) + (130 << 16) + (16 << 24);
+ objdata.PathCurve = 16;
+ objdata.ProfileCurve = 1;
+ objdata.PathScaleX = 100;
+ objdata.PathScaleY = 100;
+ objdata.ParentID = 0;
+ objdata.OwnerID = UUID.Zero;
+ objdata.Scale = new Vector3(1, 1, 1);
+ objdata.PCode = (byte)PCode.Avatar;
+ if (textureEntry != null)
{
- objectData.TextureAnim = textureanim;
+ objdata.TextureEntry = textureEntry;
}
+ Vector3 pos = new Vector3(objdata.ObjectData, 16);
+ pos.X = 100f;
+ objdata.ID = 8880000;
+ objdata.NameValue = Utils.StringToBytes("FirstName STRING RW SV Test \nLastName STRING RW SV User ");
+ //Vector3 pos2 = new Vector3(100f, 100f, 23f);
+ //objdata.FullID=user.AgentId;
+ byte[] pb = pos.GetBytes();
+ Array.Copy(pb, 0, objdata.ObjectData, 16, pb.Length);
- lock (m_primFullUpdates)
- {
- if (m_primFullUpdates.Count == 0)
- m_primFullUpdateTimer.Start();
+ return objdata;
+ }
- m_primFullUpdates.Add(objectData);
+ ///
+ ///
+ ///
+ ///
+ protected void SetDefaultAvatarPacketValues(ref ObjectUpdatePacket.ObjectDataBlock objdata)
+ {
+ objdata.PSBlock = new byte[0];
+ objdata.ExtraParams = new byte[1];
+ objdata.MediaURL = new byte[0];
+ objdata.NameValue = new byte[0];
+ objdata.Text = new byte[0];
+ objdata.TextColor = new byte[4];
+ objdata.JointAxisOrAnchor = new Vector3(0, 0, 0);
+ objdata.JointPivot = new Vector3(0, 0, 0);
+ objdata.Material = 4;
+ objdata.TextureAnim = new byte[0];
+ objdata.Sound = UUID.Zero;
+ Primitive.TextureEntry ntex = new Primitive.TextureEntry(new UUID("00000000-0000-0000-5005-000000000005"));
+ objdata.TextureEntry = ntex.GetBytes();
- if (m_primFullUpdates.Count >= m_primFullUpdatesPerPacket)
- ProcessPrimFullUpdates(this, null);
- }
+ objdata.State = 0;
+ objdata.Data = new byte[0];
+
+ objdata.ObjectData = new byte[76];
+ objdata.ObjectData[15] = 128;
+ objdata.ObjectData[16] = 63;
+ objdata.ObjectData[56] = 128;
+ objdata.ObjectData[61] = 102;
+ objdata.ObjectData[62] = 40;
+ objdata.ObjectData[63] = 61;
+ objdata.ObjectData[64] = 189;
}
- void HandleQueueEmpty(ThrottleOutPacketType queue)
+ public void SendNameReply(UUID profileId, string firstname, string lastname)
{
- switch (queue)
- {
- case ThrottleOutPacketType.Texture:
- ProcessTextureRequests();
- break;
- }
+ UUIDNameReplyPacket packet = (UUIDNameReplyPacket)PacketPool.Instance.GetPacket(PacketType.UUIDNameReply);
+ // TODO: don't create new blocks if recycling an old packet
+ packet.UUIDNameBlock = new UUIDNameReplyPacket.UUIDNameBlockBlock[1];
+ packet.UUIDNameBlock[0] = new UUIDNameReplyPacket.UUIDNameBlockBlock();
+ packet.UUIDNameBlock[0].ID = profileId;
+ packet.UUIDNameBlock[0].FirstName = Utils.StringToBytes(firstname);
+ packet.UUIDNameBlock[0].LastName = Utils.StringToBytes(lastname);
+
+ OutPacket(packet, ThrottleOutPacketType.Task);
}
- void ProcessTextureRequests()
+ #endregion
+
+ ///
+ /// This is a different way of processing packets then ProcessInPacket
+ ///
+ protected virtual void RegisterLocalPacketHandlers()
{
- if (m_imageManager != null)
- m_imageManager.ProcessImageQueue(m_textureSendLimit, m_textureDataLimit);
+ AddLocalPacketHandler(PacketType.LogoutRequest, Logout);
+ AddLocalPacketHandler(PacketType.ViewerEffect, HandleViewerEffect);
+ AddLocalPacketHandler(PacketType.AgentCachedTexture, AgentTextureCached);
+ AddLocalPacketHandler(PacketType.MultipleObjectUpdate, MultipleObjUpdate);
+ AddLocalPacketHandler(PacketType.MoneyTransferRequest, HandleMoneyTransferRequest);
+ AddLocalPacketHandler(PacketType.ParcelBuy, HandleParcelBuyRequest);
+ AddLocalPacketHandler(PacketType.UUIDGroupNameRequest, HandleUUIDGroupNameRequest);
+ AddLocalPacketHandler(PacketType.ObjectGroup, HandleObjectGroupRequest);
+ AddLocalPacketHandler(PacketType.GenericMessage, HandleGenericMessage);
}
- void ProcessPrimFullUpdates(object sender, ElapsedEventArgs e)
+ private bool HandleMoneyTransferRequest(IClientAPI sender, Packet Pack)
{
- lock (m_primFullUpdates)
+ MoneyTransferRequestPacket money = (MoneyTransferRequestPacket) Pack;
+ // validate the agent owns the agentID and sessionID
+ if (money.MoneyData.SourceID == sender.AgentId && money.AgentData.AgentID == sender.AgentId &&
+ money.AgentData.SessionID == sender.SessionId)
{
- if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
+ handlerMoneyTransferRequest = OnMoneyTransferRequest;
+ if (handlerMoneyTransferRequest != null)
{
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
-
- return;
+ handlerMoneyTransferRequest(money.MoneyData.SourceID, money.MoneyData.DestID,
+ money.MoneyData.Amount, money.MoneyData.TransactionType,
+ Util.FieldToString(money.MoneyData.Description));
}
- ObjectUpdatePacket outPacket =
- (ObjectUpdatePacket)PacketPool.Instance.GetPacket(
- PacketType.ObjectUpdate);
-
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
+ return true;
+ }
- int max = m_primFullUpdates.Count;
- if (max > m_primFullUpdatesPerPacket)
- max = m_primFullUpdatesPerPacket;
+ return false;
+ }
- int count = 0;
- int size = 0;
-
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
-
- for (count = 0 ; count < max ; count++)
+ private bool HandleParcelBuyRequest(IClientAPI sender, Packet Pack)
+ {
+ ParcelBuyPacket parcel = (ParcelBuyPacket) Pack;
+ if (parcel.AgentData.AgentID == AgentId && parcel.AgentData.SessionID == SessionId)
+ {
+ handlerParcelBuy = OnParcelBuy;
+ if (handlerParcelBuy != null)
{
- int length = 0;
- m_primFullUpdates[count].ToBytes(blockbuffer, ref length);
- length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
- if (size + length > m_packetMTU)
- break;
- size += length;
+ handlerParcelBuy(parcel.AgentData.AgentID, parcel.Data.GroupID, parcel.Data.Final,
+ parcel.Data.IsGroupOwned,
+ parcel.Data.RemoveContribution, parcel.Data.LocalID, parcel.ParcelData.Area,
+ parcel.ParcelData.Price,
+ false);
}
+ return true;
+ }
+ return false;
+ }
- outPacket.ObjectData =
- new ObjectUpdatePacket.ObjectDataBlock[count];
+ private bool HandleUUIDGroupNameRequest(IClientAPI sender, Packet Pack)
+ {
+ UUIDGroupNameRequestPacket upack = (UUIDGroupNameRequestPacket)Pack;
+
- for (int index = 0 ; index < count ; index++)
+ for (int i = 0; i < upack.UUIDNameBlock.Length; i++)
+ {
+ handlerUUIDGroupNameRequest = OnUUIDGroupNameRequest;
+ if (handlerUUIDGroupNameRequest != null)
{
- outPacket.ObjectData[index] = m_primFullUpdates[0];
- m_primFullUpdates.RemoveAt(0);
+ handlerUUIDGroupNameRequest(upack.UUIDNameBlock[i].ID, this);
}
-
- outPacket.Header.Zerocoded = true;
- OutPacket(outPacket, ThrottleOutPacketType.Task);
-
- if (m_primFullUpdates.Count == 0 && m_primFullUpdateTimer.Enabled)
- lock (m_primFullUpdateTimer)
- m_primFullUpdateTimer.Stop();
}
+
+ return true;
}
- ///
- ///
- ///
- public void SendPrimTerseUpdate(ulong regionHandle, ushort timeDilation, uint localID, Vector3 position,
- Quaternion rotation, Vector3 velocity, Vector3 rotationalvelocity, byte state, UUID AssetId, UUID ownerID, int attachPoint)
+ public bool HandleGenericMessage(IClientAPI sender, Packet pack)
{
- if (attachPoint > 30 && ownerID != AgentId) // Someone else's HUD
- return;
+ GenericMessagePacket gmpack = (GenericMessagePacket) pack;
+ if (m_genericPacketHandlers.Count == 0) return false;
+ if (gmpack.AgentData.SessionID != SessionId) return false;
- if (rotation.X == rotation.Y && rotation.Y == rotation.Z && rotation.Z == rotation.W && rotation.W == 0)
- rotation = Quaternion.Identity;
+ handlerGenericMessage = null;
- ImprovedTerseObjectUpdatePacket.ObjectDataBlock objectData =
- CreatePrimImprovedBlock(localID, position, rotation,
- velocity, rotationalvelocity, state);
+ string method = Util.FieldToString(gmpack.MethodData.Method).ToLower().Trim();
- lock (m_primTerseUpdates)
+ if (m_genericPacketHandlers.TryGetValue(method, out handlerGenericMessage))
{
- if (m_primTerseUpdates.Count == 0)
- m_primTerseUpdateTimer.Start();
-
- m_primTerseUpdates.Add(objectData);
+ List msg = new List();
+ List msgBytes = new List();
- if (m_primTerseUpdates.Count >= m_primTerseUpdatesPerPacket)
- ProcessPrimTerseUpdates(this, null);
+ if (handlerGenericMessage != null)
+ {
+ foreach (GenericMessagePacket.ParamListBlock block in gmpack.ParamList)
+ {
+ msg.Add(Util.FieldToString(block.Parameter));
+ msgBytes.Add(block.Parameter);
+ }
+ try
+ {
+ if (OnBinaryGenericMessage != null)
+ {
+ OnBinaryGenericMessage(this, method, msgBytes.ToArray());
+ }
+ handlerGenericMessage(sender, method, msg);
+ return true;
+ }
+ catch (Exception e)
+ {
+ m_log.Error("[GENERICMESSAGE] " + e);
+ }
+ }
}
+ m_log.Error("[GENERICMESSAGE] Not handling GenericMessage with method-type of: " + method);
+ return false;
}
- void ProcessPrimTerseUpdates(object sender, ElapsedEventArgs e)
+ public bool HandleObjectGroupRequest(IClientAPI sender, Packet Pack)
{
- lock (m_primTerseUpdates)
+
+ ObjectGroupPacket ogpack = (ObjectGroupPacket)Pack;
+ if (ogpack.AgentData.SessionID != SessionId) return false;
+
+ handlerObjectGroupRequest = OnObjectGroupRequest;
+ if (handlerObjectGroupRequest != null)
{
- if (m_primTerseUpdates.Count == 0)
+ for (int i = 0; i < ogpack.ObjectData.Length; i++)
{
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
-
- return;
+ handlerObjectGroupRequest(this, ogpack.AgentData.GroupID, ogpack.ObjectData[i].ObjectLocalID, UUID.Zero);
}
+ }
+ return true;
+ }
- ImprovedTerseObjectUpdatePacket outPacket =
- (ImprovedTerseObjectUpdatePacket)
- PacketPool.Instance.GetPacket(
- PacketType.ImprovedTerseObjectUpdate);
-
- outPacket.RegionData.RegionHandle =
- Scene.RegionInfo.RegionHandle;
- outPacket.RegionData.TimeDilation =
- (ushort)(Scene.TimeDilation * ushort.MaxValue);
-
- int max = m_primTerseUpdates.Count;
- if (max > m_primTerseUpdatesPerPacket)
- max = m_primTerseUpdatesPerPacket;
-
- int count = 0;
- int size = 0;
-
- byte[] zerobuffer = new byte[1024];
- byte[] blockbuffer = new byte[1024];
-
- for (count = 0 ; count < max ; count++)
+ private bool HandleViewerEffect(IClientAPI sender, Packet Pack)
+ {
+ ViewerEffectPacket viewer = (ViewerEffectPacket)Pack;
+ if (viewer.AgentData.SessionID != SessionId) return false;
+ handlerViewerEffect = OnViewerEffect;
+ if (handlerViewerEffect != null)
+ {
+ int length = viewer.Effect.Length;
+ List args = new List(length);
+ for (int i = 0; i < length; i++)
{
- int length = 0;
- m_primTerseUpdates[count].ToBytes(blockbuffer, ref length);
- length = Helpers.ZeroEncode(blockbuffer, length, zerobuffer);
- if (size + length > m_packetMTU)
- break;
- size += length;
+ //copy the effects block arguments into the event handler arg.
+ ViewerEffectEventHandlerArg argument = new ViewerEffectEventHandlerArg();
+ argument.AgentID = viewer.Effect[i].AgentID;
+ argument.Color = viewer.Effect[i].Color;
+ argument.Duration = viewer.Effect[i].Duration;
+ argument.ID = viewer.Effect[i].ID;
+ argument.Type = viewer.Effect[i].Type;
+ argument.TypeData = viewer.Effect[i].TypeData;
+ args.Add(argument);
}
- outPacket.ObjectData =
- new ImprovedTerseObjectUpdatePacket.
- ObjectDataBlock[count];
+ handlerViewerEffect(sender, args);
+ }
- for (int index = 0 ; index < count ; index++)
- {
- outPacket.ObjectData[index] = m_primTerseUpdates[0];
- m_primTerseUpdates.RemoveAt(0);
- }
+ return true;
+ }
- outPacket.Header.Reliable = false;
- outPacket.Header.Zerocoded = true;
- OutPacket(outPacket, ThrottleOutPacketType.Task);
+ public void SendScriptQuestion(UUID taskID, string taskName, string ownerName, UUID itemID, int question)
+ {
+ ScriptQuestionPacket scriptQuestion = (ScriptQuestionPacket)PacketPool.Instance.GetPacket(PacketType.ScriptQuestion);
+ scriptQuestion.Data = new ScriptQuestionPacket.DataBlock();
+ // TODO: don't create new blocks if recycling an old packet
+ scriptQuestion.Data.TaskID = taskID;
+ scriptQuestion.Data.ItemID = itemID;
+ scriptQuestion.Data.Questions = question;
+ scriptQuestion.Data.ObjectName = Utils.StringToBytes(taskName);
+ scriptQuestion.Data.ObjectOwner = Utils.StringToBytes(ownerName);
- if (m_primTerseUpdates.Count == 0)
- lock (m_primTerseUpdateTimer)
- m_primTerseUpdateTimer.Stop();
- }
+ OutPacket(scriptQuestion, ThrottleOutPacketType.Task);
}
- public void FlushPrimUpdates()
+ private void InitDefaultAnimations()
{
- while (m_primFullUpdates.Count > 0)
- {
- ProcessPrimFullUpdates(this, null);
- }
- while (m_primTerseUpdates.Count > 0)
- {
- ProcessPrimTerseUpdates(this, null);
- }
- while (m_avatarTerseUpdates.Count > 0)
+ using (XmlTextReader reader = new XmlTextReader("data/avataranimations.xml"))
{
- ProcessAvatarTerseUpdates(this, null);
+ XmlDocument doc = new XmlDocument();
+ doc.Load(reader);
+ if (doc.DocumentElement != null)
+ foreach (XmlNode nod in doc.DocumentElement.ChildNodes)
+ {
+ if (nod.Attributes["name"] != null)
+ {
+ string name = nod.Attributes["name"].Value.ToLower();
+ string id = nod.InnerText;
+ m_defaultAnimations.Add(name, (UUID)id);
+ }
+ }
}
}
- public void SendAssetUploadCompleteMessage(sbyte AssetType, bool Success, UUID AssetFullID)
+ public UUID GetDefaultAnimation(string name)
{
- AssetUploadCompletePacket newPack = new AssetUploadCompletePacket();
- newPack.AssetBlock.Type = AssetType;
- newPack.AssetBlock.Success = Success;
- newPack.AssetBlock.UUID = AssetFullID;
- newPack.Header.Zerocoded = true;
- OutPacket(newPack, ThrottleOutPacketType.Asset);
+ if (m_defaultAnimations.ContainsKey(name))
+ return m_defaultAnimations[name];
+ return UUID.Zero;
}
- public void SendXferRequest(ulong XferID, short AssetType, UUID vFileID, byte FilePath, byte[] FileName)
+ ///
+ /// Handler called when we receive a logout packet.
+ ///
+ ///
+ ///
+ ///
+ protected virtual bool Logout(IClientAPI client, Packet packet)
{
- RequestXferPacket newPack = new RequestXferPacket();
- newPack.XferID.ID = XferID;
- newPack.XferID.VFileType = AssetType;
- newPack.XferID.VFileID = vFileID;
- newPack.XferID.FilePath = FilePath;
- newPack.XferID.Filename = FileName;
- newPack.Header.Zerocoded = true;
- OutPacket(newPack, ThrottleOutPacketType.Asset);
+ if (packet.Type == PacketType.LogoutRequest)
+ {
+ if (((LogoutRequestPacket)packet).AgentData.SessionID != SessionId) return false;
+ }
+
+ return Logout(client);
}
- public void SendConfirmXfer(ulong xferID, uint PacketID)
+ ///
+ ///
+ ///
+ ///
+ ///
+ protected virtual bool Logout(IClientAPI client)
{
- ConfirmXferPacketPacket newPack = new ConfirmXferPacketPacket();
- newPack.XferID.ID = xferID;
- newPack.XferID.Packet = PacketID;
- newPack.Header.Zerocoded = true;
- OutPacket(newPack, ThrottleOutPacketType.Asset);
- }
-
- public void SendInitiateDownload(string simFileName, string clientFileName)
- {
- InitiateDownloadPacket newPack = new InitiateDownloadPacket();
- newPack.AgentData.AgentID = AgentId;
- newPack.FileData.SimFilename = Utils.StringToBytes(simFileName);
- newPack.FileData.ViewerFilename = Utils.StringToBytes(clientFileName);
- OutPacket(newPack, ThrottleOutPacketType.Asset);
- }
-
- public void SendImageFirstPart(
- ushort numParts, UUID ImageUUID, uint ImageSize, byte[] ImageData, byte imageCodec)
- {
- ImageDataPacket im = new ImageDataPacket();
- im.Header.Reliable = false;
- im.ImageID.Packets = numParts;
- im.ImageID.ID = ImageUUID;
+ m_log.InfoFormat("[CLIENT]: Got a logout request for {0} in {1}", Name, Scene.RegionInfo.RegionName);
- if (ImageSize > 0)
- im.ImageID.Size = ImageSize;
+ handlerLogout = OnLogout;
- im.ImageData.Data = ImageData;
- im.ImageID.Codec = imageCodec;
- im.Header.Zerocoded = true;
- OutPacket(im, ThrottleOutPacketType.Texture);
+ if (handlerLogout != null)
+ {
+ handlerLogout(client);
+ }
+
+ return true;
}
- public void SendImageNextPart(ushort partNumber, UUID imageUuid, byte[] imageData)
+ ///
+ /// Send a response back to a client when it asks the asset server (via the region server) if it has
+ /// its appearance texture cached.
+ ///
+ /// At the moment, we always reply that there is no cached texture.
+ ///
+ ///
+ ///
+ ///
+ protected bool AgentTextureCached(IClientAPI simclient, Packet packet)
{
- ImagePacketPacket im = new ImagePacketPacket();
- im.Header.Reliable = false;
- im.ImageID.Packet = partNumber;
- im.ImageID.ID = imageUuid;
- im.ImageData.Data = imageData;
+ //m_log.Debug("texture cached: " + packet.ToString());
+ AgentCachedTexturePacket cachedtex = (AgentCachedTexturePacket)packet;
+ AgentCachedTextureResponsePacket cachedresp = (AgentCachedTextureResponsePacket)PacketPool.Instance.GetPacket(PacketType.AgentCachedTextureResponse);
- OutPacket(im, ThrottleOutPacketType.Texture);
- }
+ if (cachedtex.AgentData.SessionID != SessionId) return false;
- public void SendImageNotFound(UUID imageid)
- {
- ImageNotInDatabasePacket notFoundPacket
- = (ImageNotInDatabasePacket)PacketPool.Instance.GetPacket(PacketType.ImageNotInDatabase);
+ // TODO: don't create new blocks if recycling an old packet
+ cachedresp.AgentData.AgentID = AgentId;
+ cachedresp.AgentData.SessionID = m_sessionId;
+ cachedresp.AgentData.SerialNum = m_cachedTextureSerial;
+ m_cachedTextureSerial++;
+ cachedresp.WearableData =
+ new AgentCachedTextureResponsePacket.WearableDataBlock[cachedtex.WearableData.Length];
- notFoundPacket.ImageID.ID = imageid;
+ for (int i = 0; i < cachedtex.WearableData.Length; i++)
+ {
+ cachedresp.WearableData[i] = new AgentCachedTextureResponsePacket.WearableDataBlock();
+ cachedresp.WearableData[i].TextureIndex = cachedtex.WearableData[i].TextureIndex;
+ cachedresp.WearableData[i].TextureID = UUID.Zero;
+ cachedresp.WearableData[i].HostName = new byte[0];
+ }
- OutPacket(notFoundPacket, ThrottleOutPacketType.Texture);
+ cachedresp.Header.Zerocoded = true;
+ OutPacket(cachedresp, ThrottleOutPacketType.Task);
+
+ return true;
}
- public void SendShutdownConnectionNotice()
+ protected bool MultipleObjUpdate(IClientAPI simClient, Packet packet)
{
- OutPacket(PacketPool.Instance.GetPacket(PacketType.DisableSimulator), ThrottleOutPacketType.Unknown);
- }
+ MultipleObjectUpdatePacket multipleupdate = (MultipleObjectUpdatePacket)packet;
+ if (multipleupdate.AgentData.SessionID != SessionId) return false;
+ // m_log.Debug("new multi update packet " + multipleupdate.ToString());
+ Scene tScene = (Scene)m_scene;
- public void SendSimStats(SimStats stats)
- {
- SimStatsPacket pack = new SimStatsPacket();
- pack.Region = new SimStatsPacket.RegionBlock();
- pack.Region.RegionX = stats.RegionX;
- pack.Region.RegionY = stats.RegionY;
- pack.Region.RegionFlags = stats.RegionFlags;
- pack.Region.ObjectCapacity = stats.ObjectCapacity;
- //pack.Region = //stats.RegionBlock;
- pack.Stat = stats.StatsBlock;
+ for (int i = 0; i < multipleupdate.ObjectData.Length; i++)
+ {
+ MultipleObjectUpdatePacket.ObjectDataBlock block = multipleupdate.ObjectData[i];
- pack.Header.Reliable = false;
+ // Can't act on Null Data
+ if (block.Data != null)
+ {
+ uint localId = block.ObjectLocalID;
+ SceneObjectPart part = tScene.GetSceneObjectPart(localId);
- OutPacket(pack, ThrottleOutPacketType.Task);
- }
+ if (part == null)
+ {
+ // It's a ghost! tell the client to delete it from view.
+ simClient.SendKillObject(Scene.RegionInfo.RegionHandle,
+ localId);
+ }
+ else
+ {
+ // UUID partId = part.UUID;
+ UpdatePrimGroupRotation handlerUpdatePrimGroupRotation;
- public void SendObjectPropertiesFamilyData(uint RequestFlags, UUID ObjectUUID, UUID OwnerID, UUID GroupID,
- uint BaseMask, uint OwnerMask, uint GroupMask, uint EveryoneMask,
- uint NextOwnerMask, int OwnershipCost, byte SaleType, int SalePrice, uint Category,
- UUID LastOwnerID, string ObjectName, string Description)
- {
- ObjectPropertiesFamilyPacket objPropFamilyPack = (ObjectPropertiesFamilyPacket)PacketPool.Instance.GetPacket(PacketType.ObjectPropertiesFamily);
- // TODO: don't create new blocks if recycling an old packet
+ switch (block.Type)
+ {
+ case 1:
+ Vector3 pos1 = new Vector3(block.Data, 0);
- ObjectPropertiesFamilyPacket.ObjectDataBlock objPropDB = new ObjectPropertiesFamilyPacket.ObjectDataBlock();
- objPropDB.RequestFlags = RequestFlags;
- objPropDB.ObjectID = ObjectUUID;
- if (OwnerID == GroupID)
- objPropDB.OwnerID = UUID.Zero;
- else
- objPropDB.OwnerID = OwnerID;
- objPropDB.GroupID = GroupID;
- objPropDB.BaseMask = BaseMask;
- objPropDB.OwnerMask = OwnerMask;
- objPropDB.GroupMask = GroupMask;
- objPropDB.EveryoneMask = EveryoneMask;
- objPropDB.NextOwnerMask = NextOwnerMask;
+ handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ // m_log.Debug("new movement position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
+ handlerUpdatePrimSinglePosition(localId, pos1, this);
+ }
+ break;
+ case 2:
+ Quaternion rot1 = new Quaternion(block.Data, 0, true);
- // TODO: More properties are needed in SceneObjectPart!
- objPropDB.OwnershipCost = OwnershipCost;
- objPropDB.SaleType = SaleType;
- objPropDB.SalePrice = SalePrice;
- objPropDB.Category = Category;
- objPropDB.LastOwnerID = LastOwnerID;
- objPropDB.Name = Util.StringToBytes256(ObjectName);
- objPropDB.Description = Util.StringToBytes256(Description);
- objPropFamilyPack.ObjectData = objPropDB;
- objPropFamilyPack.Header.Zerocoded = true;
- OutPacket(objPropFamilyPack, ThrottleOutPacketType.Task);
- }
+ handlerUpdatePrimSingleRotation = OnUpdatePrimSingleRotation;
+ if (handlerUpdatePrimSingleRotation != null)
+ {
+ // m_log.Info("new tab rotation is " + rot1.X + " , " + rot1.Y + " , " + rot1.Z + " , " + rot1.W);
+ handlerUpdatePrimSingleRotation(localId, rot1, this);
+ }
+ break;
+ case 3:
+ Vector3 rotPos = new Vector3(block.Data, 0);
+ Quaternion rot2 = new Quaternion(block.Data, 12, true);
- public void SendObjectPropertiesReply(
- UUID ItemID, ulong CreationDate, UUID CreatorUUID, UUID FolderUUID, UUID FromTaskUUID,
- UUID GroupUUID, short InventorySerial, UUID LastOwnerUUID, UUID ObjectUUID,
- UUID OwnerUUID, string TouchTitle, byte[] TextureID, string SitTitle, string ItemName,
- string ItemDescription, uint OwnerMask, uint NextOwnerMask, uint GroupMask, uint EveryoneMask,
- uint BaseMask, byte saleType, int salePrice)
- {
- ObjectPropertiesPacket proper = (ObjectPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ObjectProperties);
- // TODO: don't create new blocks if recycling an old packet
+ handlerUpdatePrimSingleRotationPosition = OnUpdatePrimSingleRotationPosition;
+ if (handlerUpdatePrimSingleRotationPosition != null)
+ {
+ // m_log.Debug("new mouse rotation position is " + rotPos.X + " , " + rotPos.Y + " , " + rotPos.Z);
+ // m_log.Info("new mouse rotation is " + rot2.X + " , " + rot2.Y + " , " + rot2.Z + " , " + rot2.W);
+ handlerUpdatePrimSingleRotationPosition(localId, rot2, rotPos, this);
+ }
+ break;
+ case 4:
+ case 20:
+ Vector3 scale4 = new Vector3(block.Data, 0);
- proper.ObjectData = new ObjectPropertiesPacket.ObjectDataBlock[1];
- proper.ObjectData[0] = new ObjectPropertiesPacket.ObjectDataBlock();
- proper.ObjectData[0].ItemID = ItemID;
- proper.ObjectData[0].CreationDate = CreationDate;
- proper.ObjectData[0].CreatorID = CreatorUUID;
- proper.ObjectData[0].FolderID = FolderUUID;
- proper.ObjectData[0].FromTaskID = FromTaskUUID;
- proper.ObjectData[0].GroupID = GroupUUID;
- proper.ObjectData[0].InventorySerial = InventorySerial;
+ handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+// m_log.Debug("new scale is " + scale4.X + " , " + scale4.Y + " , " + scale4.Z);
+ handlerUpdatePrimScale(localId, scale4, this);
+ }
+ break;
+ case 5:
- proper.ObjectData[0].LastOwnerID = LastOwnerUUID;
- // proper.ObjectData[0].LastOwnerID = UUID.Zero;
+ Vector3 scale1 = new Vector3(block.Data, 12);
+ Vector3 pos11 = new Vector3(block.Data, 0);
- proper.ObjectData[0].ObjectID = ObjectUUID;
- if (OwnerUUID == GroupUUID)
- proper.ObjectData[0].OwnerID = UUID.Zero;
- else
- proper.ObjectData[0].OwnerID = OwnerUUID;
- proper.ObjectData[0].TouchName = Util.StringToBytes256(TouchTitle);
- proper.ObjectData[0].TextureID = TextureID;
- proper.ObjectData[0].SitName = Util.StringToBytes256(SitTitle);
- proper.ObjectData[0].Name = Util.StringToBytes256(ItemName);
- proper.ObjectData[0].Description = Util.StringToBytes256(ItemDescription);
- proper.ObjectData[0].OwnerMask = OwnerMask;
- proper.ObjectData[0].NextOwnerMask = NextOwnerMask;
- proper.ObjectData[0].GroupMask = GroupMask;
- proper.ObjectData[0].EveryoneMask = EveryoneMask;
- proper.ObjectData[0].BaseMask = BaseMask;
- // proper.ObjectData[0].AggregatePerms = 53;
- // proper.ObjectData[0].AggregatePermTextures = 0;
- // proper.ObjectData[0].AggregatePermTexturesOwner = 0;
- proper.ObjectData[0].SaleType = saleType;
- proper.ObjectData[0].SalePrice = salePrice;
- proper.Header.Zerocoded = true;
- OutPacket(proper, ThrottleOutPacketType.Task);
- }
+ handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+ // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimScale(localId, scale1, this);
- #endregion
+ handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ handlerUpdatePrimSinglePosition(localId, pos11, this);
+ }
+ }
+ break;
+ case 9:
+ Vector3 pos2 = new Vector3(block.Data, 0);
- #region Estate Data Sending Methods
+ handlerUpdateVector = OnUpdatePrimGroupPosition;
- private static bool convertParamStringToBool(byte[] field)
- {
- string s = Utils.BytesToString(field);
- if (s == "1" || s.ToLower() == "y" || s.ToLower() == "yes" || s.ToLower() == "t" || s.ToLower() == "true")
- {
- return true;
- }
- return false;
- }
+ if (handlerUpdateVector != null)
+ {
- public void SendEstateManagersList(UUID invoice, UUID[] EstateManagers, uint estateID)
- {
- EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
- packet.AgentData.TransactionID = UUID.Random();
- packet.AgentData.AgentID = AgentId;
- packet.AgentData.SessionID = SessionId;
- packet.MethodData.Invoice = invoice;
- packet.MethodData.Method = Utils.StringToBytes("setaccess");
+ handlerUpdateVector(localId, pos2, this);
+ }
+ break;
+ case 10:
+ Quaternion rot3 = new Quaternion(block.Data, 0, true);
- EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + EstateManagers.Length];
+ handlerUpdatePrimRotation = OnUpdatePrimGroupRotation;
+ if (handlerUpdatePrimRotation != null)
+ {
+ // Console.WriteLine("new rotation is " + rot3.X + " , " + rot3.Y + " , " + rot3.Z + " , " + rot3.W);
+ handlerUpdatePrimRotation(localId, rot3, this);
+ }
+ break;
+ case 11:
+ Vector3 pos3 = new Vector3(block.Data, 0);
+ Quaternion rot4 = new Quaternion(block.Data, 12, true);
- for (int i = 0; i < (6 + EstateManagers.Length); i++)
- {
- returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
- }
- int j = 0;
+ handlerUpdatePrimGroupRotation = OnUpdatePrimGroupMouseRotation;
+ if (handlerUpdatePrimGroupRotation != null)
+ {
+ // m_log.Debug("new rotation position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
+ // m_log.Debug("new group mouse rotation is " + rot4.X + " , " + rot4.Y + " , " + rot4.Z + " , " + rot4.W);
+ handlerUpdatePrimGroupRotation(localId, pos3, rot4, this);
+ }
+ break;
+ case 12:
+ case 28:
+ Vector3 scale7 = new Vector3(block.Data, 0);
- returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateManagers).ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes(EstateManagers.Length.ToString()); j++;
- for (int i = 0; i < EstateManagers.Length; i++)
- {
- returnblock[j].Parameter = EstateManagers[i].GetBytes(); j++;
- }
- packet.ParamList = returnblock;
- packet.Header.Reliable = false;
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
+ if (handlerUpdatePrimGroupScale != null)
+ {
+// m_log.Debug("new scale is " + scale7.X + " , " + scale7.Y + " , " + scale7.Z);
+ handlerUpdatePrimGroupScale(localId, scale7, this);
+ }
+ break;
+ case 13:
+ Vector3 scale2 = new Vector3(block.Data, 12);
+ Vector3 pos4 = new Vector3(block.Data, 0);
- public void SendBannedUserList(UUID invoice, EstateBan[] bl, uint estateID)
- {
- ListBannedUsers = new List();
+ handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+ //m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimScale(localId, scale2, this);
- for (int i = 0; i < bl.Length; i++)
- {
- if (bl[i] == null)
- continue;
- if (bl[i].BannedUserID == UUID.Zero)
- continue;
- BannedUsers.Add(bl[i].BannedUserID);
- }
+ // Change the position based on scale (for bug number 246)
+ handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ // m_log.Debug("new movement position is " + pos.X + " , " + pos.Y + " , " + pos.Z);
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ handlerUpdatePrimSinglePosition(localId, pos4, this);
+ }
+ }
+ break;
+ case 29:
+ Vector3 scale5 = new Vector3(block.Data, 12);
+ Vector3 pos5 = new Vector3(block.Data, 0);
- EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
- packet.AgentData.TransactionID = UUID.Random();
- packet.AgentData.AgentID = AgentId;
- packet.AgentData.SessionID = SessionId;
- packet.MethodData.Invoice = invoice;
- packet.MethodData.Method = Utils.StringToBytes("setaccess");
+ handlerUpdatePrimGroupScale = OnUpdatePrimGroupScale;
+ if (handlerUpdatePrimGroupScale != null)
+ {
+ // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimGroupScale(localId, scale5, this);
+ handlerUpdateVector = OnUpdatePrimGroupPosition;
- EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[6 + BannedUsers.Count];
+ if (handlerUpdateVector != null)
+ {
+ handlerUpdateVector(localId, pos5, this);
+ }
+ }
+ break;
+ case 21:
+ Vector3 scale6 = new Vector3(block.Data, 12);
+ Vector3 pos6 = new Vector3(block.Data, 0);
- for (int i = 0; i < (6 + BannedUsers.Count); i++)
- {
- returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
+ handlerUpdatePrimScale = OnUpdatePrimScale;
+ if (handlerUpdatePrimScale != null)
+ {
+ // m_log.Debug("new scale is " + scale.X + " , " + scale.Y + " , " + scale.Z);
+ handlerUpdatePrimScale(localId, scale6, this);
+ handlerUpdatePrimSinglePosition = OnUpdatePrimSinglePosition;
+ if (handlerUpdatePrimSinglePosition != null)
+ {
+ handlerUpdatePrimSinglePosition(localId, pos6, this);
+ }
+ }
+ break;
+ default:
+ m_log.Debug("[CLIENT] MultipleObjUpdate recieved an unknown packet type: " + (block.Type));
+ break;
+ }
+ }
+ }
}
- int j = 0;
+ return true;
+ }
- returnblock[j].Parameter = Utils.StringToBytes(estateID.ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes(((int)Constants.EstateAccessCodex.EstateBans).ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
- returnblock[j].Parameter = Utils.StringToBytes(BannedUsers.Count.ToString()); j++;
- returnblock[j].Parameter = Utils.StringToBytes("0"); j++;
+ public void RequestMapLayer()
+ {
+ //should be getting the map layer from the grid server
+ //send a layer covering the 800,800 - 1200,1200 area (should be covering the requested area)
+ MapLayerReplyPacket mapReply = (MapLayerReplyPacket)PacketPool.Instance.GetPacket(PacketType.MapLayerReply);
+ // TODO: don't create new blocks if recycling an old packet
+ mapReply.AgentData.AgentID = AgentId;
+ mapReply.AgentData.Flags = 0;
+ mapReply.LayerData = new MapLayerReplyPacket.LayerDataBlock[1];
+ mapReply.LayerData[0] = new MapLayerReplyPacket.LayerDataBlock();
+ mapReply.LayerData[0].Bottom = 0;
+ mapReply.LayerData[0].Left = 0;
+ mapReply.LayerData[0].Top = 30000;
+ mapReply.LayerData[0].Right = 30000;
+ mapReply.LayerData[0].ImageID = new UUID("00000000-0000-1111-9999-000000000006");
+ mapReply.Header.Zerocoded = true;
+ OutPacket(mapReply, ThrottleOutPacketType.Land);
+ }
- foreach (UUID banned in BannedUsers)
+ public void RequestMapBlocksX(int minX, int minY, int maxX, int maxY)
+ {
+ /*
+ IList simMapProfiles = m_gridServer.RequestMapBlocks(minX, minY, maxX, maxY);
+ MapBlockReplyPacket mbReply = new MapBlockReplyPacket();
+ mbReply.AgentData.AgentId = AgentId;
+ int len;
+ if (simMapProfiles == null)
+ len = 0;
+ else
+ len = simMapProfiles.Count;
+
+ mbReply.Data = new MapBlockReplyPacket.DataBlock[len];
+ int iii;
+ for (iii = 0; iii < len; iii++)
{
- returnblock[j].Parameter = banned.GetBytes(); j++;
+ Hashtable mp = (Hashtable)simMapProfiles[iii];
+ mbReply.Data[iii] = new MapBlockReplyPacket.DataBlock();
+ mbReply.Data[iii].Name = Util.UTF8.GetBytes((string)mp["name"]);
+ mbReply.Data[iii].Access = System.Convert.ToByte(mp["access"]);
+ mbReply.Data[iii].Agents = System.Convert.ToByte(mp["agents"]);
+ mbReply.Data[iii].MapImageID = new UUID((string)mp["map-image-id"]);
+ mbReply.Data[iii].RegionFlags = System.Convert.ToUInt32(mp["region-flags"]);
+ mbReply.Data[iii].WaterHeight = System.Convert.ToByte(mp["water-height"]);
+ mbReply.Data[iii].X = System.Convert.ToUInt16(mp["x"]);
+ mbReply.Data[iii].Y = System.Convert.ToUInt16(mp["y"]);
}
- packet.ParamList = returnblock;
- packet.Header.Reliable = false;
- OutPacket(packet, ThrottleOutPacketType.Task);
+ this.OutPacket(mbReply, ThrottleOutPacketType.Land);
+ */
}
- public void SendRegionInfoToEstateMenu(RegionInfoForEstateMenuArgs args)
+ ///
+ /// returns a byte array of the client set throttles Gets multiplied by the multiplier
+ ///
+ ///
+ /// non 1 multiplier for subdividing the throttles between individual regions
+ ///
+ public byte[] GetThrottlesPacked(float multiplier)
{
- RegionInfoPacket rinfopack = new RegionInfoPacket();
- RegionInfoPacket.RegionInfoBlock rinfoblk = new RegionInfoPacket.RegionInfoBlock();
- rinfopack.AgentData.AgentID = AgentId;
- rinfopack.AgentData.SessionID = SessionId;
- rinfoblk.BillableFactor = args.billableFactor;
- rinfoblk.EstateID = args.estateID;
- rinfoblk.MaxAgents = args.maxAgents;
- rinfoblk.ObjectBonusFactor = args.objectBonusFactor;
- rinfoblk.ParentEstateID = args.parentEstateID;
- rinfoblk.PricePerMeter = args.pricePerMeter;
- rinfoblk.RedirectGridX = args.redirectGridX;
- rinfoblk.RedirectGridY = args.redirectGridY;
- rinfoblk.RegionFlags = args.regionFlags;
- rinfoblk.SimAccess = args.simAccess;
- rinfoblk.SunHour = args.sunHour;
- rinfoblk.TerrainLowerLimit = args.terrainLowerLimit;
- rinfoblk.TerrainRaiseLimit = args.terrainRaiseLimit;
- rinfoblk.UseEstateSun = args.useEstateSun;
- rinfoblk.WaterHeight = args.waterHeight;
- rinfoblk.SimName = Utils.StringToBytes(args.simName);
-
- rinfopack.RegionInfo2 = new RegionInfoPacket.RegionInfo2Block();
- rinfopack.RegionInfo2.HardMaxAgents = uint.MaxValue;
- rinfopack.RegionInfo2.HardMaxObjects = uint.MaxValue;
- rinfopack.RegionInfo2.MaxAgents32 = uint.MaxValue;
- rinfopack.RegionInfo2.ProductName = Utils.EmptyBytes;
- rinfopack.RegionInfo2.ProductSKU = Utils.EmptyBytes;
-
- rinfopack.HasVariableBlocks = true;
- rinfopack.RegionInfo = rinfoblk;
- rinfopack.AgentData = new RegionInfoPacket.AgentDataBlock();
- rinfopack.AgentData.AgentID = AgentId;
- rinfopack.AgentData.SessionID = SessionId;
+ return m_PacketHandler.PacketQueue.GetThrottlesPacked(multiplier);
+ }
+ ///
+ /// sets the throttles from values supplied by the client
+ ///
+ ///
+ public void SetChildAgentThrottle(byte[] throttles)
+ {
+ m_PacketHandler.PacketQueue.SetThrottleFromClient(throttles);
+ }
+ ///
+ /// Method gets called when a new packet has arrived from the UDP
+ /// server. This happens after it's been decoded into a libsl object.
+ ///
+ /// object containing the packet.
+ public virtual void InPacket(object NewPack)
+ {
+ // Cast NewPack to Packet.
+ m_PacketHandler.InPacket((Packet) NewPack);
+ }
- OutPacket(rinfopack, ThrottleOutPacketType.Task);
+ ///
+ /// This is the starting point for sending a simulator packet out to the client.
+ ///
+ /// Please do not call this from outside the LindenUDP client stack.
+ ///
+ ///
+ /// Corresponds to the type of data that is going out. Enum
+ public void OutPacket(Packet NewPack, ThrottleOutPacketType throttlePacketType)
+ {
+ m_PacketHandler.OutPacket(NewPack, throttlePacketType);
}
- public void SendEstateCovenantInformation(UUID covenant)
+ public bool AddMoney(int debit)
{
- EstateCovenantReplyPacket einfopack = new EstateCovenantReplyPacket();
- EstateCovenantReplyPacket.DataBlock edata = new EstateCovenantReplyPacket.DataBlock();
- edata.CovenantID = covenant;
- edata.CovenantTimestamp = 0;
- if (m_scene.RegionInfo.EstateSettings.EstateOwner != UUID.Zero)
- edata.EstateOwnerID = m_scene.RegionInfo.EstateSettings.EstateOwner;
- else
- edata.EstateOwnerID = m_scene.RegionInfo.MasterAvatarAssignedUUID;
- edata.EstateName = Utils.StringToBytes(m_scene.RegionInfo.EstateSettings.EstateName);
- einfopack.Data = edata;
- OutPacket(einfopack, ThrottleOutPacketType.Task);
+ if (m_moneyBalance + debit >= 0)
+ {
+ m_moneyBalance += debit;
+ SendMoneyBalance(UUID.Zero, true, Utils.StringToBytes("Poof Poof!"), m_moneyBalance);
+ return true;
+ }
+ return false;
}
- public void SendDetailedEstateData(UUID invoice, string estateName, uint estateID, uint parentEstate, uint estateFlags, uint sunPosition, UUID covenant, string abuseEmail, UUID estateOwner)
+ ///
+ /// Breaks down the genericMessagePacket into specific events
+ ///
+ ///
+ ///
+ ///
+ public void DecipherGenericMessage(string gmMethod, UUID gmInvoice, GenericMessagePacket.ParamListBlock[] gmParams)
{
- EstateOwnerMessagePacket packet = new EstateOwnerMessagePacket();
- packet.MethodData.Invoice = invoice;
- packet.AgentData.TransactionID = UUID.Random();
- packet.MethodData.Method = Utils.StringToBytes("estateupdateinfo");
- EstateOwnerMessagePacket.ParamListBlock[] returnblock = new EstateOwnerMessagePacket.ParamListBlock[10];
-
- for (int i = 0; i < 10; i++)
+ switch (gmMethod)
{
- returnblock[i] = new EstateOwnerMessagePacket.ParamListBlock();
- }
-
- //Sending Estate Settings
- returnblock[0].Parameter = Utils.StringToBytes(estateName);
- // TODO: remove this cruft once MasterAvatar is fully deprecated
- //
- returnblock[1].Parameter = Utils.StringToBytes(estateOwner.ToString());
- returnblock[2].Parameter = Utils.StringToBytes(estateID.ToString());
+ case "autopilot":
+ float locx;
+ float locy;
+ float locz;
- returnblock[3].Parameter = Utils.StringToBytes(estateFlags.ToString());
- returnblock[4].Parameter = Utils.StringToBytes(sunPosition.ToString());
- returnblock[5].Parameter = Utils.StringToBytes(parentEstate.ToString());
- returnblock[6].Parameter = Utils.StringToBytes(covenant.ToString());
- returnblock[7].Parameter = Utils.StringToBytes("1160895077"); // what is this?
- returnblock[8].Parameter = Utils.StringToBytes("1"); // what is this?
- returnblock[9].Parameter = Utils.StringToBytes(abuseEmail);
+ try
+ {
+ uint regionX;
+ uint regionY;
+ Utils.LongToUInts(Scene.RegionInfo.RegionHandle, out regionX, out regionY);
+ locx = Convert.ToSingle(Utils.BytesToString(gmParams[0].Parameter)) - regionX;
+ locy = Convert.ToSingle(Utils.BytesToString(gmParams[1].Parameter)) - regionY;
+ locz = Convert.ToSingle(Utils.BytesToString(gmParams[2].Parameter));
+ }
+ catch (InvalidCastException)
+ {
+ m_log.Error("[CLIENT]: Invalid autopilot request");
+ return;
+ }
- packet.ParamList = returnblock;
- packet.Header.Reliable = false;
- //m_log.Debug("[ESTATE]: SIM--->" + packet.ToString());
- OutPacket(packet, ThrottleOutPacketType.Task);
- }
+ handlerAutoPilotGo = OnAutoPilotGo;
+ if (handlerAutoPilotGo != null)
+ {
+ handlerAutoPilotGo(0, new Vector3(locx, locy, locz), this);
+ }
+ m_log.InfoFormat("[CLIENT]: Client Requests autopilot to position <{0},{1},{2}>", locx, locy, locz);
- #endregion
- #region Land Data Sending Methods
+ break;
+ default:
+ m_log.Debug("[CLIENT]: Unknown Generic Message, Method: " + gmMethod + ". Invoice: " + gmInvoice + ". Dumping Params:");
+ for (int hi = 0; hi < gmParams.Length; hi++)
+ {
+ Console.WriteLine(gmParams[hi].ToString());
+ }
+ //gmpack.MethodData.
+ break;
- public void SendLandParcelOverlay(byte[] data, int sequence_id)
- {
- ParcelOverlayPacket packet = (ParcelOverlayPacket)PacketPool.Instance.GetPacket(PacketType.ParcelOverlay);
- packet.ParcelData.Data = data;
- packet.ParcelData.SequenceID = sequence_id;
- packet.Header.Zerocoded = true;
- OutPacket(packet, ThrottleOutPacketType.Task);
+ }
}
- public void SendLandProperties(int sequence_id, bool snap_selection, int request_result, LandData landData, float simObjectBonusFactor, int parcelObjectCapacity, int simObjectCapacity, uint regionFlags)
+ ///
+ /// Entryway from the client to the simulator. All UDP packets from the client will end up here
+ ///
+ /// OpenMetaverse.packet
+ public void ProcessInPacket(Packet Pack)
{
- ParcelPropertiesPacket updatePacket = (ParcelPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ParcelProperties);
- // TODO: don't create new blocks if recycling an old packet
-
- updatePacket.ParcelData.AABBMax = landData.AABBMax;
- updatePacket.ParcelData.AABBMin = landData.AABBMin;
- updatePacket.ParcelData.Area = landData.Area;
- updatePacket.ParcelData.AuctionID = landData.AuctionID;
- updatePacket.ParcelData.AuthBuyerID = landData.AuthBuyerID;
-
- updatePacket.ParcelData.Bitmap = landData.Bitmap;
-
- updatePacket.ParcelData.Desc = Utils.StringToBytes(landData.Description);
- updatePacket.ParcelData.Category = (byte)landData.Category;
- updatePacket.ParcelData.ClaimDate = landData.ClaimDate;
- updatePacket.ParcelData.ClaimPrice = landData.ClaimPrice;
- updatePacket.ParcelData.GroupID = landData.GroupID;
- updatePacket.ParcelData.GroupPrims = landData.GroupPrims;
- updatePacket.ParcelData.IsGroupOwned = landData.IsGroupOwned;
- updatePacket.ParcelData.LandingType = landData.LandingType;
- updatePacket.ParcelData.LocalID = landData.LocalID;
- if (landData.Area > 0)
- {
- updatePacket.ParcelData.MaxPrims = parcelObjectCapacity;
- }
- else
+ if (ProcessPacketMethod(Pack))
{
- updatePacket.ParcelData.MaxPrims = 0;
+ return;
}
- updatePacket.ParcelData.MediaAutoScale = landData.MediaAutoScale;
- updatePacket.ParcelData.MediaID = landData.MediaID;
- updatePacket.ParcelData.MediaURL = Util.StringToBytes256(landData.MediaURL);
- updatePacket.ParcelData.MusicURL = Util.StringToBytes256(landData.MusicURL);
- updatePacket.ParcelData.Name = Util.StringToBytes256(landData.Name);
- updatePacket.ParcelData.OtherCleanTime = landData.OtherCleanTime;
- updatePacket.ParcelData.OtherCount = 0; //TODO: Unimplemented
- updatePacket.ParcelData.OtherPrims = landData.OtherPrims;
- updatePacket.ParcelData.OwnerID = landData.OwnerID;
- updatePacket.ParcelData.OwnerPrims = landData.OwnerPrims;
- updatePacket.ParcelData.ParcelFlags = landData.Flags;
- updatePacket.ParcelData.ParcelPrimBonus = simObjectBonusFactor;
- updatePacket.ParcelData.PassHours = landData.PassHours;
- updatePacket.ParcelData.PassPrice = landData.PassPrice;
- updatePacket.ParcelData.PublicCount = 0; //TODO: Unimplemented
-
- updatePacket.ParcelData.RegionDenyAnonymous = (regionFlags & (uint)RegionFlags.DenyAnonymous) > 0;
- updatePacket.ParcelData.RegionDenyIdentified = (regionFlags & (uint)RegionFlags.DenyIdentified) > 0;
- updatePacket.ParcelData.RegionDenyTransacted = (regionFlags & (uint)RegionFlags.DenyTransacted) > 0;
- updatePacket.ParcelData.RegionPushOverride = (regionFlags & (uint)RegionFlags.RestrictPushObject) > 0;
+ const bool m_checkPackets = true;
- updatePacket.ParcelData.RentPrice = 0;
- updatePacket.ParcelData.RequestResult = request_result;
- updatePacket.ParcelData.SalePrice = landData.SalePrice;
- updatePacket.ParcelData.SelectedPrims = landData.SelectedPrims;
- updatePacket.ParcelData.SelfCount = 0; //TODO: Unimplemented
- updatePacket.ParcelData.SequenceID = sequence_id;
- if (landData.SimwideArea > 0)
- {
- updatePacket.ParcelData.SimWideMaxPrims = parcelObjectCapacity;
- }
- else
+ // Main packet processing conditional
+ switch (Pack.Type)
{
- updatePacket.ParcelData.SimWideMaxPrims = 0;
- }
- updatePacket.ParcelData.SimWideTotalPrims = landData.SimwidePrims;
- updatePacket.ParcelData.SnapSelection = snap_selection;
- updatePacket.ParcelData.SnapshotID = landData.SnapshotID;
- updatePacket.ParcelData.Status = (byte)landData.Status;
- updatePacket.ParcelData.TotalPrims = landData.OwnerPrims + landData.GroupPrims + landData.OtherPrims +
- landData.SelectedPrims;
- updatePacket.ParcelData.UserLocation = landData.UserLocation;
- updatePacket.ParcelData.UserLookAt = landData.UserLookAt;
- updatePacket.Header.Zerocoded = true;
+ #region Scene/Avatar
- try
- {
- IEventQueue eq = Scene.RequestModuleInterface();
- if (eq != null)
- {
- eq.ParcelProperties(updatePacket, this.AgentId);
- }
- }
- catch (Exception ex)
- {
- m_log.Error("Unable to send parcel data via eventqueue - exception: " + ex.ToString());
- m_log.Warn("sending parcel data via UDP");
- OutPacket(updatePacket, ThrottleOutPacketType.Task);
- }
- }
+ case PacketType.AvatarPropertiesRequest:
+ AvatarPropertiesRequestPacket avatarProperties = (AvatarPropertiesRequestPacket)Pack;
- public void SendLandAccessListData(List avatars, uint accessFlag, int localLandID)
- {
- ParcelAccessListReplyPacket replyPacket = (ParcelAccessListReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelAccessListReply);
- replyPacket.Data.AgentID = AgentId;
- replyPacket.Data.Flags = accessFlag;
- replyPacket.Data.LocalID = localLandID;
- replyPacket.Data.SequenceID = 0;
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (avatarProperties.AgentData.SessionID != SessionId ||
+ avatarProperties.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- List list = new List();
- foreach (UUID avatar in avatars)
- {
- ParcelAccessListReplyPacket.ListBlock block = new ParcelAccessListReplyPacket.ListBlock();
- block.Flags = accessFlag;
- block.ID = avatar;
- block.Time = 0;
- list.Add(block);
- }
+ handlerRequestAvatarProperties = OnRequestAvatarProperties;
+ if (handlerRequestAvatarProperties != null)
+ {
+ handlerRequestAvatarProperties(this, avatarProperties.AgentData.AvatarID);
+ }
- replyPacket.List = list.ToArray();
- replyPacket.Header.Zerocoded = true;
- OutPacket(replyPacket, ThrottleOutPacketType.Task);
- }
+ break;
- public void SendForceClientSelectObjects(List ObjectIDs)
- {
- bool firstCall = true;
- const int MAX_OBJECTS_PER_PACKET = 251;
- ForceObjectSelectPacket pack = (ForceObjectSelectPacket)PacketPool.Instance.GetPacket(PacketType.ForceObjectSelect);
- ForceObjectSelectPacket.DataBlock[] data;
- while (ObjectIDs.Count > 0)
- {
- if (firstCall)
- {
- pack._Header.ResetList = true;
- firstCall = false;
- }
- else
- {
- pack._Header.ResetList = false;
- }
+ case PacketType.ChatFromViewer:
+ ChatFromViewerPacket inchatpack = (ChatFromViewerPacket)Pack;
- if (ObjectIDs.Count > MAX_OBJECTS_PER_PACKET)
- {
- data = new ForceObjectSelectPacket.DataBlock[MAX_OBJECTS_PER_PACKET];
- }
- else
- {
- data = new ForceObjectSelectPacket.DataBlock[ObjectIDs.Count];
- }
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (inchatpack.AgentData.SessionID != SessionId ||
+ inchatpack.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- int i;
- for (i = 0; i < MAX_OBJECTS_PER_PACKET && ObjectIDs.Count > 0; i++)
- {
- data[i] = new ForceObjectSelectPacket.DataBlock();
- data[i].LocalID = Convert.ToUInt32(ObjectIDs[0]);
- ObjectIDs.RemoveAt(0);
- }
- pack.Data = data;
- pack.Header.Zerocoded = true;
- OutPacket(pack, ThrottleOutPacketType.Task);
- }
- }
-
- public void SendCameraConstraint(Vector4 ConstraintPlane)
- {
- CameraConstraintPacket cpack = (CameraConstraintPacket)PacketPool.Instance.GetPacket(PacketType.CameraConstraint);
- cpack.CameraCollidePlane = new CameraConstraintPacket.CameraCollidePlaneBlock();
- cpack.CameraCollidePlane.Plane = ConstraintPlane;
- //m_log.DebugFormat("[CLIENTVIEW]: Constraint {0}", ConstraintPlane);
- OutPacket(cpack, ThrottleOutPacketType.Task);
- }
+ string fromName = String.Empty; //ClientAvatar.firstname + " " + ClientAvatar.lastname;
+ byte[] message = inchatpack.ChatData.Message;
+ byte type = inchatpack.ChatData.Type;
+ Vector3 fromPos = new Vector3(); // ClientAvatar.Pos;
+ // UUID fromAgentID = AgentId;
- public void SendLandObjectOwners(LandData land, List groups, Dictionary ownersAndCount)
- {
-
+ int channel = inchatpack.ChatData.Channel;
- int notifyCount = ownersAndCount.Count;
- ParcelObjectOwnersReplyPacket pack = (ParcelObjectOwnersReplyPacket)PacketPool.Instance.GetPacket(PacketType.ParcelObjectOwnersReply);
+ if (OnChatFromClient != null)
+ {
+ OSChatMessage args = new OSChatMessage();
+ args.Channel = channel;
+ args.From = fromName;
+ args.Message = Utils.BytesToString(message);
+ args.Type = (ChatTypeEnum)type;
+ args.Position = fromPos;
- if (notifyCount > 0)
- {
- if (notifyCount > 32)
- {
- m_log.InfoFormat(
- "[LAND]: More than {0} avatars own prims on this parcel. Only sending back details of first {0}"
- + " - a developer might want to investigate whether this is a hard limit", 32);
+ args.Scene = Scene;
+ args.Sender = this;
+ args.SenderUUID = this.AgentId;
- notifyCount = 32;
- }
+ handlerChatFromClient = OnChatFromClient;
+ if (handlerChatFromClient != null)
+ handlerChatFromClient(this, args);
+ }
+ break;
- ParcelObjectOwnersReplyPacket.DataBlock[] dataBlock
- = new ParcelObjectOwnersReplyPacket.DataBlock[notifyCount];
+ case PacketType.AvatarPropertiesUpdate:
+ AvatarPropertiesUpdatePacket avatarProps = (AvatarPropertiesUpdatePacket)Pack;
- int num = 0;
- foreach (UUID owner in ownersAndCount.Keys)
- {
- dataBlock[num] = new ParcelObjectOwnersReplyPacket.DataBlock();
- dataBlock[num].Count = ownersAndCount[owner];
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (avatarProps.AgentData.SessionID != SessionId ||
+ avatarProps.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- if (land.GroupID == owner || groups.Contains(owner))
- dataBlock[num].IsGroupOwned = true;
+ handlerUpdateAvatarProperties = OnUpdateAvatarProperties;
+ if (handlerUpdateAvatarProperties != null)
+ {
+ AvatarPropertiesUpdatePacket.PropertiesDataBlock Properties = avatarProps.PropertiesData;
+ UserProfileData UserProfile = new UserProfileData();
+ UserProfile.ID = AgentId;
+ UserProfile.AboutText = Utils.BytesToString(Properties.AboutText);
+ UserProfile.FirstLifeAboutText = Utils.BytesToString(Properties.FLAboutText);
+ UserProfile.FirstLifeImage = Properties.FLImageID;
+ UserProfile.Image = Properties.ImageID;
+ UserProfile.ProfileUrl = Utils.BytesToString(Properties.ProfileURL);
- dataBlock[num].OnlineStatus = true; //TODO: fix me later
- dataBlock[num].OwnerID = owner;
+ handlerUpdateAvatarProperties(this, UserProfile);
+ }
+ break;
- num++;
+ case PacketType.ScriptDialogReply:
+ ScriptDialogReplyPacket rdialog = (ScriptDialogReplyPacket)Pack;
- if (num >= notifyCount)
+ #region Packet Session and User Check
+ if (m_checkPackets)
{
- break;
+ if (rdialog.AgentData.SessionID != SessionId ||
+ rdialog.AgentData.AgentID != AgentId)
+ break;
}
- }
+ #endregion
- pack.Data = dataBlock;
- }
- pack.Header.Zerocoded = true;
- this.OutPacket(pack, ThrottleOutPacketType.Task);
- }
+ int ch = rdialog.Data.ChatChannel;
+ byte[] msg = rdialog.Data.ButtonLabel;
+ if (OnChatFromClient != null)
+ {
+ OSChatMessage args = new OSChatMessage();
+ args.Channel = ch;
+ args.From = String.Empty;
+ args.Message = Utils.BytesToString(msg);
+ args.Type = ChatTypeEnum.Shout;
+ args.Position = new Vector3();
+ args.Scene = Scene;
+ args.Sender = this;
+ handlerChatFromClient2 = OnChatFromClient;
+ if (handlerChatFromClient2 != null)
+ handlerChatFromClient2(this, args);
+ }
- #endregion
+ break;
- #region Helper Methods
+ case PacketType.ImprovedInstantMessage:
+ ImprovedInstantMessagePacket msgpack = (ImprovedInstantMessagePacket)Pack;
- protected ImprovedTerseObjectUpdatePacket.ObjectDataBlock CreateAvatarImprovedBlock(uint localID, Vector3 pos,
- Vector3 velocity,
- Quaternion rotation)
- {
- byte[] bytes = new byte[60];
- int i = 0;
- ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat = PacketPool.GetDataBlock();
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (msgpack.AgentData.SessionID != SessionId ||
+ msgpack.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- dat.TextureEntry = new byte[0]; // AvatarTemplate.TextureEntry;
+ string IMfromName = Util.FieldToString(msgpack.MessageBlock.FromAgentName);
+ string IMmessage = Utils.BytesToString(msgpack.MessageBlock.Message);
+ handlerInstantMessage = OnInstantMessage;
- uint ID = localID;
+ if (handlerInstantMessage != null)
+ {
+ GridInstantMessage im = new GridInstantMessage(Scene,
+ msgpack.AgentData.AgentID,
+ IMfromName,
+ msgpack.MessageBlock.ToAgentID,
+ msgpack.MessageBlock.Dialog,
+ msgpack.MessageBlock.FromGroup,
+ IMmessage,
+ msgpack.MessageBlock.ID,
+ msgpack.MessageBlock.Offline != 0 ? true : false,
+ msgpack.MessageBlock.Position,
+ msgpack.MessageBlock.BinaryBucket);
- bytes[i++] = (byte)(ID % 256);
- bytes[i++] = (byte)((ID >> 8) % 256);
- bytes[i++] = (byte)((ID >> 16) % 256);
- bytes[i++] = (byte)((ID >> 24) % 256);
- bytes[i++] = 0;
- bytes[i++] = 1;
- i += 14;
- bytes[i++] = 128;
- bytes[i++] = 63;
+ handlerInstantMessage(this, im);
+ }
+ break;
- byte[] pb = pos.GetBytes();
- Array.Copy(pb, 0, bytes, i, pb.Length);
- i += 12;
+ case PacketType.AcceptFriendship:
+ AcceptFriendshipPacket afriendpack = (AcceptFriendshipPacket)Pack;
- Vector3 internDirec = new Vector3(velocity.X, velocity.Y, velocity.Z);
+ #region Packet Session and User Check
+ if (m_checkPackets)
+ {
+ if (afriendpack.AgentData.SessionID != SessionId ||
+ afriendpack.AgentData.AgentID != AgentId)
+ break;
+ }
+ #endregion
- internDirec = internDirec / 128.0f;
- internDirec.X += 1;
- internDirec.Y += 1;
- internDirec.Z += 1;
+ // My guess is this is the folder to stick the calling card into
+ List