diff --git a/OpenSim/Client/MXP/ClientStack/MXPClientView.cs b/OpenSim/Client/MXP/ClientStack/MXPClientView.cs deleted file mode 100644 index a604a2ee63..0000000000 --- a/OpenSim/Client/MXP/ClientStack/MXPClientView.cs +++ /dev/null @@ -1,1728 +0,0 @@ -/* - * Copyright (c) Contributors, http://opensimulator.org/ - * See CONTRIBUTORS.TXT for a full list of copyright holders. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * * Neither the name of the OpenSimulator Project nor the - * names of its contributors may be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -using System; -using System.Collections.Generic; -using System.Net; -using System.Reflection; -using System.Text; -using log4net; -using MXP; -using MXP.Messages; -using OpenMetaverse; -using OpenMetaverse.Packets; -using OpenSim.Framework; -using OpenSim.Framework.Client; -using Packet=OpenMetaverse.Packets.Packet; -using MXP.Extentions.OpenMetaverseFragments.Proto; -using MXP.Util; -using MXP.Fragments; -using MXP.Common.Proto; -using OpenSim.Region.Framework.Scenes; - -namespace OpenSim.Client.MXP.ClientStack -{ - public class MXPClientView : IClientAPI, IClientCore - { - internal static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); - - #region Constants - private Vector3 FORWARD = new Vector3(1, 0, 0); - private Vector3 BACKWARD = new Vector3(-1, 0, 0); - private Vector3 LEFT = new Vector3(0, 1, 0); - private Vector3 RIGHT = new Vector3(0, -1, 0); - private Vector3 UP = new Vector3(0, 0, 1); - private Vector3 DOWN = new Vector3(0, 0, -1); - #endregion - - #region Fields - private readonly Session m_session; - private readonly UUID m_sessionID; - private readonly UUID m_userID; - private readonly IScene m_scene; - private readonly string m_firstName; - private readonly string m_lastName; -// private int m_objectsToSynchronize = 0; -// private int m_objectsSynchronized = -1; - - private Vector3 m_startPosition=new Vector3(128f, 128f, 128f); - #endregion - - #region Properties - - public Session Session - { - get { return m_session; } - } - - public Vector3 StartPos - { - get { return m_startPosition; } - set { m_startPosition = value; } - } - - public UUID AgentId - { - get { return m_userID; } - } - - public UUID SessionId - { - get { return m_sessionID; } - } - - public UUID SecureSessionId - { - get { return m_sessionID; } - } - - public UUID ActiveGroupId - { - get { return UUID.Zero; } - } - - public string ActiveGroupName - { - get { return ""; } - } - - public ulong ActiveGroupPowers - { - get { return 0; } - } - - public ulong GetGroupPowers(UUID groupID) - { - return 0; - } - - public bool IsGroupMember(UUID GroupID) - { - return false; - } - - public string FirstName - { - get { return m_firstName; } - } - - public string LastName - { - get { return m_lastName; } - } - - public IScene Scene - { - get { return m_scene; } - } - - public int NextAnimationSequenceNumber - { - get { return 0; } - } - - public string Name - { - get { return FirstName; } - } - - public bool IsActive - { - get { return Session.SessionState == SessionState.Connected; } - set - { - if (!value) - Stop(); - } - } - - public bool IsLoggingOut - { - get { return false ; } - set { } - } - - #endregion - - #region Constructors - public MXPClientView(Session mxpSession, UUID mxpSessionID, UUID userID, IScene mxpHostBubble, string mxpFirstName, string mxpLastName) - { - this.m_session = mxpSession; - this.m_userID = userID; - this.m_firstName = mxpFirstName; - this.m_lastName = mxpLastName; - this.m_scene = mxpHostBubble; - this.m_sessionID = mxpSessionID; - } - #endregion - - #region MXP Incoming Message Processing - - public void MXPPRocessMessage(Message message) - { - if (message.GetType() == typeof(ModifyRequestMessage)) - { - MXPProcessModifyRequest((ModifyRequestMessage)message); - } - else - { - m_log.Warn("[MXP ClientStack] Received messaged unhandled: " + message); - } - } - - private void MXPProcessModifyRequest(ModifyRequestMessage modifyRequest) - { - ObjectFragment objectFragment=modifyRequest.ObjectFragment; - if (objectFragment.ObjectId == m_userID.Guid) - { - OmAvatarExt avatarExt = modifyRequest.GetExtension(); - - AgentUpdateArgs agentUpdate = new AgentUpdateArgs(); - agentUpdate.AgentID = new UUID(objectFragment.ObjectId); - agentUpdate.SessionID = m_sessionID; - agentUpdate.State = (byte)avatarExt.State; - - Quaternion avatarOrientation = FromOmQuaternion(objectFragment.Orientation); - if (avatarOrientation.X == 0 && avatarOrientation.Y == 0 && avatarOrientation.Z == 0 && avatarOrientation.W == 0) - { - avatarOrientation = Quaternion.Identity; - } - Vector3 avatarLocation=FromOmVector(objectFragment.Location); - - if (avatarExt.MovementDirection != null) - { - Vector3 direction = FromOmVector(avatarExt.MovementDirection); - - direction = direction * Quaternion.Inverse(avatarOrientation); - - if ((direction - FORWARD).Length() < 0.5) - { - agentUpdate.ControlFlags += (uint)AgentManager.ControlFlags.AGENT_CONTROL_AT_POS; - } - if ((direction - BACKWARD).Length() < 0.5) - { - agentUpdate.ControlFlags += (uint)AgentManager.ControlFlags.AGENT_CONTROL_AT_NEG; - } - if ((direction - LEFT).Length() < 0.5) - { - agentUpdate.ControlFlags += (uint)AgentManager.ControlFlags.AGENT_CONTROL_LEFT_POS; - } - if ((direction - RIGHT).Length() < 0.5) - { - agentUpdate.ControlFlags += (uint)AgentManager.ControlFlags.AGENT_CONTROL_LEFT_NEG; - } - if ((direction - UP).Length() < 0.5) - { - agentUpdate.ControlFlags += (uint)AgentManager.ControlFlags.AGENT_CONTROL_UP_POS; - } - if ((direction - DOWN).Length() < 0.5) - { - agentUpdate.ControlFlags += (uint)AgentManager.ControlFlags.AGENT_CONTROL_UP_NEG; - } - - } - if (avatarExt.TargetOrientation != null) - { - agentUpdate.BodyRotation = FromOmQuaternion(avatarExt.TargetOrientation); - } - else - { - agentUpdate.BodyRotation = FromOmQuaternion(objectFragment.Orientation); - } - - if (avatarExt.Body != null) - { - foreach (OmBipedBoneOrientation boneOrientation in avatarExt.Body.BipedBoneOrientations) - { - if (boneOrientation.Bone == OmBipedBones.Head) - { - agentUpdate.HeadRotation = FromOmQuaternion(boneOrientation.Orientation); - } - } - } - else - { - agentUpdate.HeadRotation = Quaternion.Identity; - } - - if (avatarExt.Camera != null) - { - Quaternion cameraOrientation = FromOmQuaternion(avatarExt.Camera.Orientation); - agentUpdate.CameraCenter = FromOmVector(avatarExt.Camera.Location); - agentUpdate.CameraAtAxis = FORWARD * cameraOrientation; - agentUpdate.CameraLeftAxis = LEFT * cameraOrientation; - agentUpdate.CameraUpAxis = UP * cameraOrientation; - } - else - { - agentUpdate.CameraCenter = avatarLocation; - agentUpdate.CameraAtAxis = FORWARD * avatarOrientation; - agentUpdate.CameraLeftAxis = LEFT * avatarOrientation; - agentUpdate.CameraUpAxis = UP * avatarOrientation; - } - - OnAgentUpdate(this, agentUpdate); - - ModifyResponseMessage modifyResponse = new ModifyResponseMessage(); - modifyResponse.FailureCode = MxpResponseCodes.SUCCESS; - modifyResponse.RequestMessageId = modifyRequest.MessageId; - m_session.Send(modifyResponse); - } - else - { - ModifyResponseMessage modifyResponse = new ModifyResponseMessage(); - modifyResponse.FailureCode = MxpResponseCodes.UNAUTHORIZED_OPERATION; - modifyResponse.RequestMessageId = modifyRequest.MessageId; - m_session.Send(modifyResponse); - } - } - - #endregion - - #region MXP Outgoing Message Processing - -// private void MXPSendPrimitive(uint localID, UUID ownerID, Vector3 acc, Vector3 rvel, PrimitiveBaseShape primShape, Vector3 pos, UUID objectID, Vector3 vel, Quaternion rotation, uint flags, string text, byte[] textColor, uint parentID, byte[] particleSystem, byte clickAction, byte material, byte[] textureanim) -// { -// String typeName = ToOmType(primShape.PCode); -// m_log.Info("[MXP ClientStack] Transmitting Primitive" + typeName); -// -// PerceptionEventMessage pe = new PerceptionEventMessage(); -// pe.ObjectFragment.ObjectId = objectID.Guid; -// -// pe.ObjectFragment.ParentObjectId = Guid.Empty; -// -// // Resolving parent UUID. -// OpenSim.Region.Framework.Scenes.Scene scene = (OpenSim.Region.Framework.Scenes.Scene)Scene; -// if (scene.Entities.ContainsKey(parentID)) -// { -// pe.ObjectFragment.ParentObjectId = scene.Entities[parentID].UUID.Guid; -// } -// -// pe.ObjectFragment.ObjectIndex = localID; -// pe.ObjectFragment.ObjectName = typeName + " Object"; -// pe.ObjectFragment.OwnerId = ownerID.Guid; -// pe.ObjectFragment.TypeId = Guid.Empty; -// pe.ObjectFragment.TypeName = typeName; -// pe.ObjectFragment.Acceleration = ToOmVector(acc); -// pe.ObjectFragment.AngularAcceleration=new MsdQuaternion4f(); -// pe.ObjectFragment.AngularVelocity = ToOmQuaternion(rvel); -// pe.ObjectFragment.BoundingSphereRadius = primShape.Scale.Length(); -// -// pe.ObjectFragment.Location = ToOmVector(pos); -// -// pe.ObjectFragment.Mass = 1.0f; -// pe.ObjectFragment.Orientation = ToOmQuaternion(rotation); -// pe.ObjectFragment.Velocity =ToOmVector(vel); -// -// OmSlPrimitiveExt ext = new OmSlPrimitiveExt(); -// -// if (!((primShape.PCode == (byte)PCode.NewTree) || (primShape.PCode == (byte)PCode.Tree) || (primShape.PCode == (byte)PCode.Grass))) -// { -// -// ext.PathBegin = primShape.PathBegin; -// ext.PathEnd = primShape.PathEnd; -// ext.PathScaleX = primShape.PathScaleX; -// ext.PathScaleY = primShape.PathScaleY; -// ext.PathShearX = primShape.PathShearX; -// ext.PathShearY = primShape.PathShearY; -// ext.PathSkew = primShape.PathSkew; -// ext.ProfileBegin = primShape.ProfileBegin; -// ext.ProfileEnd = primShape.ProfileEnd; -// ext.PathCurve = primShape.PathCurve; -// ext.ProfileCurve = primShape.ProfileCurve; -// ext.ProfileHollow = primShape.ProfileHollow; -// ext.PathRadiusOffset = primShape.PathRadiusOffset; -// ext.PathRevolutions = primShape.PathRevolutions; -// ext.PathTaperX = primShape.PathTaperX; -// ext.PathTaperY = primShape.PathTaperY; -// ext.PathTwist = primShape.PathTwist; -// ext.PathTwistBegin = primShape.PathTwistBegin; -// -// -// } -// -// ext.UpdateFlags = flags; -// ext.ExtraParams = primShape.ExtraParams; -// ext.State = primShape.State; -// ext.TextureEntry = primShape.TextureEntry; -// ext.TextureAnim = textureanim; -// ext.Scale = ToOmVector(primShape.Scale); -// ext.Text = text; -// ext.TextColor = ToOmColor(textColor); -// ext.PSBlock = particleSystem; -// ext.ClickAction = clickAction; -// ext.Material = material; -// -// pe.SetExtension(ext); -// -// Session.Send(pe); -// -// if (m_objectsSynchronized != -1) -// { -// m_objectsSynchronized++; -// -// if (m_objectsToSynchronize >= m_objectsSynchronized) -// { -// SynchronizationEndEventMessage synchronizationEndEventMessage = new SynchronizationEndEventMessage(); -// Session.Send(synchronizationEndEventMessage); -// m_objectsSynchronized = -1; -// } -// } -// } - - public void MXPSendAvatarData(string participantName, UUID ownerID, UUID parentId, UUID avatarID, uint avatarLocalID, Vector3 position, Quaternion rotation) - { - m_log.Info("[MXP ClientStack] Transmitting Avatar Data " + participantName); - - PerceptionEventMessage pe = new PerceptionEventMessage(); - - pe.ObjectFragment.ObjectId = avatarID.Guid; - pe.ObjectFragment.ParentObjectId = parentId.Guid; - pe.ObjectFragment.ObjectIndex = avatarLocalID; - pe.ObjectFragment.ObjectName = participantName; - pe.ObjectFragment.OwnerId = ownerID.Guid; - pe.ObjectFragment.TypeId = Guid.Empty; - pe.ObjectFragment.TypeName = "Avatar"; - pe.ObjectFragment.Acceleration = new MsdVector3f(); - pe.ObjectFragment.AngularAcceleration = new MsdQuaternion4f(); - pe.ObjectFragment.AngularVelocity = new MsdQuaternion4f(); - - pe.ObjectFragment.BoundingSphereRadius = 1.0f; // TODO Fill in appropriate value - - pe.ObjectFragment.Location = ToOmVector(position); - - pe.ObjectFragment.Mass = 1.0f; // TODO Fill in appropriate value - pe.ObjectFragment.Orientation = ToOmQuaternion(rotation); - pe.ObjectFragment.Velocity = new MsdVector3f(); - - Session.Send(pe); - } - - public void MXPSendTerrain(float[] map) - { - m_log.Info("[MXP ClientStack] Transmitting terrain for " + m_scene.RegionInfo.RegionName); - - PerceptionEventMessage pe = new PerceptionEventMessage(); - - // Hacking terrain object uuid to zero and index to hashcode of regionuuid - pe.ObjectFragment.ObjectId = m_scene.RegionInfo.RegionSettings.RegionUUID.Guid; - pe.ObjectFragment.ObjectIndex = (uint)(m_scene.RegionInfo.RegionSettings.RegionUUID.GetHashCode() + ((long)int.MaxValue) / 2); - pe.ObjectFragment.ParentObjectId = UUID.Zero.Guid; - pe.ObjectFragment.ObjectName = "Terrain of " + m_scene.RegionInfo.RegionName; - pe.ObjectFragment.OwnerId = m_scene.RegionInfo.EstateSettings.EstateOwner.Guid; - pe.ObjectFragment.TypeId = Guid.Empty; - pe.ObjectFragment.TypeName = "Terrain"; - pe.ObjectFragment.Acceleration = new MsdVector3f(); - pe.ObjectFragment.AngularAcceleration = new MsdQuaternion4f(); - pe.ObjectFragment.AngularVelocity = new MsdQuaternion4f(); - pe.ObjectFragment.BoundingSphereRadius = 128f; - - pe.ObjectFragment.Location = new MsdVector3f(); - - pe.ObjectFragment.Mass = 1.0f; - pe.ObjectFragment.Orientation = new MsdQuaternion4f(); - pe.ObjectFragment.Velocity = new MsdVector3f(); - - OmBitmapTerrainExt terrainExt = new OmBitmapTerrainExt(); - terrainExt.Width = 256; - terrainExt.Height = 256; - terrainExt.WaterLevel = (float) m_scene.RegionInfo.RegionSettings.WaterHeight; - terrainExt.Offset = 0; - terrainExt.Scale = 10; - terrainExt.HeightMap = CompressUtil.CompressHeightMap(map, 0, 10); - - pe.SetExtension(terrainExt); - - Session.Send(pe); - } - - public void MXPSendSynchronizationBegin(int objectCount) - { -// m_objectsToSynchronize = objectCount; -// m_objectsSynchronized = 0; - SynchronizationBeginEventMessage synchronizationBeginEventMessage = new SynchronizationBeginEventMessage(); - synchronizationBeginEventMessage.ObjectCount = (uint)objectCount; - Session.Send(synchronizationBeginEventMessage); - } - - #endregion - - #region MXP Conversions - - private MsdVector3f ToOmVector(Vector3 value) - { - MsdVector3f encodedValue = new MsdVector3f(); - encodedValue.X = value.X; - encodedValue.Y = value.Y; - encodedValue.Z = value.Z; - return encodedValue; - } - - private MsdQuaternion4f ToOmQuaternion(Vector3 value) - { - Quaternion quaternion=Quaternion.CreateFromEulers(value); - MsdQuaternion4f encodedValue = new MsdQuaternion4f(); - encodedValue.X = quaternion.X; - encodedValue.Y = quaternion.Y; - encodedValue.Z = quaternion.Z; - encodedValue.W = quaternion.W; - return encodedValue; - } - - private MsdQuaternion4f ToOmQuaternion(Quaternion value) - { - MsdQuaternion4f encodedValue = new MsdQuaternion4f(); - encodedValue.X = value.X; - encodedValue.Y = value.Y; - encodedValue.Z = value.Z; - encodedValue.W = value.W; - return encodedValue; - } - - private Vector3 FromOmVector(MsdVector3f vector) - { - return new Vector3(vector.X, vector.Y, vector.Z); - } - -// private Vector3 FromOmVector(float[] vector) -// { -// return new Vector3(vector[0], vector[1], vector[2]); -// } - - private Quaternion FromOmQuaternion(MsdQuaternion4f quaternion) - { - return new Quaternion(quaternion.X, quaternion.Y, quaternion.Z, quaternion.W); - } - -// private Quaternion FromOmQuaternion(float[] quaternion) -// { -// return new Quaternion(quaternion[0], quaternion[1], quaternion[2], quaternion[3]); -// } - - private MsdColor4f ToOmColor(byte[] value) - { - MsdColor4f encodedValue = new MsdColor4f(); - encodedValue.R = value[0]; - encodedValue.G = value[1]; - encodedValue.B = value[2]; - encodedValue.A = value[3]; - return encodedValue; - } - - private string ToOmType(byte value) - { - if (value == (byte)PCodeEnum.Avatar) - { - return "Avatar"; - } - if (value == (byte)PCodeEnum.Grass) - { - return "Grass"; - } - if (value == (byte)PCodeEnum.NewTree) - { - return "NewTree"; - } - if (value == (byte)PCodeEnum.ParticleSystem) - { - return "ParticleSystem"; - } - if (value == (byte)PCodeEnum.Primitive) - { - return "Primitive"; - } - if (value == (byte)PCodeEnum.Tree) - { - return "Tree"; - } - throw new Exception("Unsupported PCode value: " + value); - } - - #endregion - - #region OpenSim Event Handlers - - #pragma warning disable 67 - public event GenericMessage OnGenericMessage; - public event ImprovedInstantMessage OnInstantMessage; - public event ChatMessage OnChatFromClient; - public event TextureRequest OnRequestTexture; - public event RezObject OnRezObject; - public event ModifyTerrain OnModifyTerrain; - public event BakeTerrain OnBakeTerrain; - public event EstateChangeInfo OnEstateChangeInfo; - public event SetAppearance OnSetAppearance; - public event AvatarNowWearing OnAvatarNowWearing; - public event RezSingleAttachmentFromInv OnRezSingleAttachmentFromInv; - public event RezMultipleAttachmentsFromInv OnRezMultipleAttachmentsFromInv; - public event UUIDNameRequest OnDetachAttachmentIntoInv; - public event ObjectAttach OnObjectAttach; - public event ObjectDeselect OnObjectDetach; - public event ObjectDrop OnObjectDrop; - public event StartAnim OnStartAnim; - public event StopAnim OnStopAnim; - public event LinkObjects OnLinkObjects; - public event DelinkObjects OnDelinkObjects; - public event RequestMapBlocks OnRequestMapBlocks; - public event RequestMapName OnMapNameRequest; - public event TeleportLocationRequest OnTeleportLocationRequest; - public event DisconnectUser OnDisconnectUser; - public event RequestAvatarProperties OnRequestAvatarProperties; - public event SetAlwaysRun OnSetAlwaysRun; - public event TeleportLandmarkRequest OnTeleportLandmarkRequest; - public event DeRezObject OnDeRezObject; - public event Action OnRegionHandShakeReply; - public event GenericCall1 OnRequestWearables; - public event GenericCall1 OnCompleteMovementToRegion; - public event UpdateAgent OnPreAgentUpdate; - public event UpdateAgent OnAgentUpdate; - public event AgentRequestSit OnAgentRequestSit; - public event AgentSit OnAgentSit; - public event AvatarPickerRequest OnAvatarPickerRequest; - public event Action OnRequestAvatarsData; - public event AddNewPrim OnAddPrim; - public event FetchInventory OnAgentDataUpdateRequest; - public event TeleportLocationRequest OnSetStartLocationRequest; - public event RequestGodlikePowers OnRequestGodlikePowers; - public event GodKickUser OnGodKickUser; - public event ObjectDuplicate OnObjectDuplicate; - public event ObjectDuplicateOnRay OnObjectDuplicateOnRay; - public event GrabObject OnGrabObject; - public event DeGrabObject OnDeGrabObject; - public event MoveObject OnGrabUpdate; - public event SpinStart OnSpinStart; - public event SpinObject OnSpinUpdate; - public event SpinStop OnSpinStop; - public event UpdateShape OnUpdatePrimShape; - public event ObjectExtraParams OnUpdateExtraParams; - public event ObjectRequest OnObjectRequest; - public event ObjectSelect OnObjectSelect; - public event ObjectDeselect OnObjectDeselect; - public event GenericCall7 OnObjectDescription; - public event GenericCall7 OnObjectName; - public event GenericCall7 OnObjectClickAction; - public event GenericCall7 OnObjectMaterial; - public event RequestObjectPropertiesFamily OnRequestObjectPropertiesFamily; - public event UpdatePrimFlags OnUpdatePrimFlags; - public event UpdatePrimTexture OnUpdatePrimTexture; - public event UpdateVector OnUpdatePrimGroupPosition; - public event UpdateVector OnUpdatePrimSinglePosition; - public event UpdatePrimRotation OnUpdatePrimGroupRotation; - public event UpdatePrimSingleRotationPosition OnUpdatePrimSingleRotationPosition; - public event UpdatePrimSingleRotation OnUpdatePrimSingleRotation; - public event UpdatePrimGroupRotation OnUpdatePrimGroupMouseRotation; - public event UpdateVector OnUpdatePrimScale; - public event UpdateVector OnUpdatePrimGroupScale; - public event StatusChange OnChildAgentStatus; - public event GenericCall2 OnStopMovement; - public event Action OnRemoveAvatar; - public event ObjectPermissions OnObjectPermissions; - public event CreateNewInventoryItem OnCreateNewInventoryItem; - public event LinkInventoryItem OnLinkInventoryItem; - public event CreateInventoryFolder OnCreateNewInventoryFolder; - public event UpdateInventoryFolder OnUpdateInventoryFolder; - public event MoveInventoryFolder OnMoveInventoryFolder; - public event FetchInventoryDescendents OnFetchInventoryDescendents; - public event PurgeInventoryDescendents OnPurgeInventoryDescendents; - public event FetchInventory OnFetchInventory; - public event RequestTaskInventory OnRequestTaskInventory; - public event UpdateInventoryItem OnUpdateInventoryItem; - public event CopyInventoryItem OnCopyInventoryItem; - public event MoveInventoryItem OnMoveInventoryItem; - public event RemoveInventoryFolder OnRemoveInventoryFolder; - public event RemoveInventoryItem OnRemoveInventoryItem; - public event UDPAssetUploadRequest OnAssetUploadRequest; - public event XferReceive OnXferReceive; - public event RequestXfer OnRequestXfer; - public event ConfirmXfer OnConfirmXfer; - public event AbortXfer OnAbortXfer; - public event RezScript OnRezScript; - public event UpdateTaskInventory OnUpdateTaskInventory; - public event MoveTaskInventory OnMoveTaskItem; - public event RemoveTaskInventory OnRemoveTaskItem; - public event RequestAsset OnRequestAsset; - public event UUIDNameRequest OnNameFromUUIDRequest; - public event ParcelAccessListRequest OnParcelAccessListRequest; - public event ParcelAccessListUpdateRequest OnParcelAccessListUpdateRequest; - public event ParcelPropertiesRequest OnParcelPropertiesRequest; - public event ParcelDivideRequest OnParcelDivideRequest; - public event ParcelJoinRequest OnParcelJoinRequest; - public event ParcelPropertiesUpdateRequest OnParcelPropertiesUpdateRequest; - public event ParcelSelectObjects OnParcelSelectObjects; - public event ParcelObjectOwnerRequest OnParcelObjectOwnerRequest; - public event ParcelAbandonRequest OnParcelAbandonRequest; - public event ParcelGodForceOwner OnParcelGodForceOwner; - public event ParcelReclaim OnParcelReclaim; - public event ParcelReturnObjectsRequest OnParcelReturnObjectsRequest; - public event ParcelDeedToGroup OnParcelDeedToGroup; - public event RegionInfoRequest OnRegionInfoRequest; - public event EstateCovenantRequest OnEstateCovenantRequest; - public event FriendActionDelegate OnApproveFriendRequest; - public event FriendActionDelegate OnDenyFriendRequest; - public event FriendshipTermination OnTerminateFriendship; - public event GrantUserFriendRights OnGrantUserRights; - public event MoneyTransferRequest OnMoneyTransferRequest; - public event EconomyDataRequest OnEconomyDataRequest; - public event MoneyBalanceRequest OnMoneyBalanceRequest; - public event UpdateAvatarProperties OnUpdateAvatarProperties; - public event ParcelBuy OnParcelBuy; - public event RequestPayPrice OnRequestPayPrice; - public event ObjectSaleInfo OnObjectSaleInfo; - public event ObjectBuy OnObjectBuy; - public event BuyObjectInventory OnBuyObjectInventory; - public event RequestTerrain OnRequestTerrain; - public event RequestTerrain OnUploadTerrain; - public event ObjectIncludeInSearch OnObjectIncludeInSearch; - public event UUIDNameRequest OnTeleportHomeRequest; - public event ScriptAnswer OnScriptAnswer; - public event AgentSit OnUndo; - public event AgentSit OnRedo; - public event LandUndo OnLandUndo; - public event ForceReleaseControls OnForceReleaseControls; - public event GodLandStatRequest OnLandStatRequest; - public event DetailedEstateDataRequest OnDetailedEstateDataRequest; - public event SetEstateFlagsRequest OnSetEstateFlagsRequest; - public event SetEstateTerrainBaseTexture OnSetEstateTerrainBaseTexture; - public event SetEstateTerrainDetailTexture OnSetEstateTerrainDetailTexture; - public event SetEstateTerrainTextureHeights OnSetEstateTerrainTextureHeights; - public event CommitEstateTerrainTextureRequest OnCommitEstateTerrainTextureRequest; - public event SetRegionTerrainSettings OnSetRegionTerrainSettings; - public event EstateRestartSimRequest OnEstateRestartSimRequest; - public event EstateChangeCovenantRequest OnEstateChangeCovenantRequest; - public event UpdateEstateAccessDeltaRequest OnUpdateEstateAccessDeltaRequest; - public event SimulatorBlueBoxMessageRequest OnSimulatorBlueBoxMessageRequest; - public event EstateBlueBoxMessageRequest OnEstateBlueBoxMessageRequest; - public event EstateDebugRegionRequest OnEstateDebugRegionRequest; - public event EstateTeleportOneUserHomeRequest OnEstateTeleportOneUserHomeRequest; - public event EstateTeleportAllUsersHomeRequest OnEstateTeleportAllUsersHomeRequest; - public event UUIDNameRequest OnUUIDGroupNameRequest; - public event RegionHandleRequest OnRegionHandleRequest; - public event ParcelInfoRequest OnParcelInfoRequest; - public event RequestObjectPropertiesFamily OnObjectGroupRequest; - public event ScriptReset OnScriptReset; - 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; - public event DirPopularQuery OnDirPopularQuery; - 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 ViewerEffectEventHandler OnViewerEffect; - public event Action OnLogout; - public event Action OnConnectionClosed; - 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 FindAgentUpdate OnFindAgent; - public event TrackAgentUpdate OnTrackAgent; - public event NewUserReport OnUserReport; - public event SaveStateHandler OnSaveState; - public event GroupAccountSummaryRequest OnGroupAccountSummaryRequest; - public event GroupAccountDetailsRequest OnGroupAccountDetailsRequest; - public event GroupAccountTransactionsRequest OnGroupAccountTransactionsRequest; - public event FreezeUserUpdate OnParcelFreezeUser; - public event EjectUserUpdate OnParcelEjectUser; - public event ParcelBuyPass OnParcelBuyPass; - public event ParcelGodMark OnParcelGodMark; - public event GroupActiveProposalsRequest OnGroupActiveProposalsRequest; - public event GroupVoteHistoryRequest OnGroupVoteHistoryRequest; - public event SimWideDeletesDelegate OnSimWideDeletes; - public event SendPostcard OnSendPostcard; - public event MuteListEntryUpdate OnUpdateMuteListEntry; - public event MuteListEntryRemove OnRemoveMuteListEntry; - public event GodlikeMessage onGodlikeMessage; - public event GodUpdateRegionInfoUpdate OnGodUpdateRegionInfoUpdate; - - public event PlacesQuery OnPlacesQuery; - - #pragma warning restore 67 - - #endregion - - #region OpenSim ClientView Public Methods - // Do we need this? - public bool SendLogoutPacketWhenClosing - { - set { } - } - - public uint CircuitCode - { - get { return m_sessionID.CRC(); } - } - - public IPEndPoint RemoteEndPoint - { - get { return Session.RemoteEndPoint; } - } - - public void SetDebugPacketLevel(int newDebug) - { - //m_debugLevel = newDebug; - } - - public void InPacket(object NewPack) - { - //throw new System.NotImplementedException(); - } - - public void ProcessInPacket(Packet NewPack) - { - //throw new System.NotImplementedException(); - } - - public void OnClean() - { - if (OnLogout != null) - OnLogout(this); - - if (OnConnectionClosed != null) - OnConnectionClosed(this); - } - - public void Close() - { - m_log.Info("[MXP ClientStack] Close Called"); - - // Tell the client to go - SendLogoutPacket(); - - // Let MXPPacketServer clean it up - if (Session.SessionState != SessionState.Disconnected) - { - Session.SetStateDisconnected(); - } - - } - - public void Kick(string message) - { - Close(); - } - - public void Start() - { - Scene.AddNewClient(this); - - // Mimicking LLClientView which gets always set appearance from client. - OpenSim.Region.Framework.Scenes.Scene scene=(OpenSim.Region.Framework.Scenes.Scene)Scene; - AvatarAppearance appearance; - scene.GetAvatarAppearance(this,out appearance); - OnSetAppearance(this, appearance.Texture, (byte[])appearance.VisualParams.Clone()); - } - - public void Stop() - { - // Nor this - } - - public void SendWearables(AvatarWearable[] wearables, int serial) - { - // Need to translate to MXP somehow - } - - public void SendAppearance(UUID agentID, byte[] visualParams, byte[] textureEntry) - { - // Need to translate to MXP somehow - } - - public void SendStartPingCheck(byte seq) - { - // Need to translate to MXP somehow - } - - public void SendKillObject(ulong regionHandle, uint localID) - { - DisappearanceEventMessage de = new DisappearanceEventMessage(); - de.ObjectIndex = localID; - - Session.Send(de); - } - - public void SendAnimations(UUID[] animID, int[] seqs, UUID sourceAgentId, UUID[] objectIDs) - { - // Need to translate to MXP somehow - } - - public void SendRegionHandshake(RegionInfo regionInfo, RegionHandshakeArgs args) - { - m_log.Info("[MXP ClientStack] Completing Handshake to Region"); - - if (OnRegionHandShakeReply != null) - { - OnRegionHandShakeReply(this); - } - - if (OnCompleteMovementToRegion != null) - { - OnCompleteMovementToRegion(this); - } - - // Need to translate to MXP somehow - } - - public void SendChatMessage(string message, byte type, Vector3 fromPos, string fromName, UUID fromAgentID, byte source, byte audible) - { - ActionEventMessage chatActionEvent = new ActionEventMessage(); - chatActionEvent.ActionFragment.ActionName = "Chat"; - chatActionEvent.ActionFragment.SourceObjectId = fromAgentID.Guid; - chatActionEvent.ActionFragment.ObservationRadius = 180.0f; - chatActionEvent.ActionFragment.ExtensionDialect = "TEXT"; - chatActionEvent.SetPayloadData(Util.UTF8.GetBytes(message)); - - Session.Send(chatActionEvent); - } - - public void SendInstantMessage(GridInstantMessage im) - { - // Need to translate to MXP somehow - } - - public void SendGenericMessage(string method, List message) - { - } - - public void SendGenericMessage(string method, List message) - { - // Need to translate to MXP somehow - } - - public void SendLayerData(float[] map) - { - MXPSendTerrain(map); - } - - public void SendLayerData(int px, int py, float[] map) - { - } - - public void SendWindData(Vector2[] windSpeeds) - { - // Need to translate to MXP somehow - } - - public void SendCloudData(float[] cloudCover) - { - // Need to translate to MXP somehow - } - - public void MoveAgentIntoRegion(RegionInfo regInfo, Vector3 pos, Vector3 look) - { - //throw new System.NotImplementedException(); - } - - public void InformClientOfNeighbour(ulong neighbourHandle, IPEndPoint neighbourExternalEndPoint) - { - //throw new System.NotImplementedException(); - } - - public AgentCircuitData RequestClientInfo() - { - AgentCircuitData clientinfo = new AgentCircuitData(); - clientinfo.AgentID = AgentId; - clientinfo.Appearance = new AvatarAppearance(); - clientinfo.BaseFolder = UUID.Zero; - clientinfo.CapsPath = ""; - clientinfo.child = false; - clientinfo.ChildrenCapSeeds = new Dictionary(); - clientinfo.circuitcode = CircuitCode; - clientinfo.firstname = FirstName; - clientinfo.InventoryFolder = UUID.Zero; - clientinfo.lastname = LastName; - clientinfo.SecureSessionID = SecureSessionId; - clientinfo.SessionID = SessionId; - clientinfo.startpos = StartPos; - - return clientinfo; - } - - public void CrossRegion(ulong newRegionHandle, Vector3 pos, Vector3 lookAt, IPEndPoint newRegionExternalEndPoint, string capsURL) - { - // TODO: We'll want to get this one working. - // Need to translate to MXP somehow - } - - public void SendMapBlock(List mapBlocks, uint flag) - { - // Need to translate to MXP somehow - } - - public void SendLocalTeleport(Vector3 position, Vector3 lookAt, uint flags) - { - //throw new System.NotImplementedException(); - } - - public void SendRegionTeleport(ulong regionHandle, byte simAccess, IPEndPoint regionExternalEndPoint, uint locationID, uint flags, string capsURL) - { - // Need to translate to MXP somehow - } - - public void SendTeleportFailed(string reason) - { - // Need to translate to MXP somehow - } - - public void SendTeleportStart(uint flags) - { - // Need to translate to MXP somehow - } - - public void SendTeleportProgress(uint flags, string message) - { - } - - public void SendMoneyBalance(UUID transaction, bool success, byte[] description, int balance) - { - // Need to translate to MXP somehow - } - - public void SendPayPrice(UUID objectID, int[] payPrice) - { - // Need to translate to MXP somehow - } - - public void SendCoarseLocationUpdate(List users, List CoarseLocations) - { - // Minimap function, not used. - } - - public void SetChildAgentThrottle(byte[] throttle) - { - // Need to translate to MXP somehow - } - - public void SendAvatarDataImmediate(ISceneEntity avatar) - { - //ScenePresence presence=((Scene)this.Scene).GetScenePresence(avatarID); - ScenePresence presence = (ScenePresence)avatar; - UUID ownerID = presence.UUID; - MXPSendAvatarData(presence.Firstname + " " + presence.Lastname, ownerID, UUID.Zero, presence.UUID, presence.LocalId, presence.AbsolutePosition, presence.Rotation); - } - - public void SendPrimUpdate(ISceneEntity entity, PrimUpdateFlags updateFlags) - { - //MovementEventMessage me = new MovementEventMessage(); - //me.ObjectIndex = data.LocalID; - //me.Location = ToOmVector(data.Position); - //me.Orientation = ToOmQuaternion(data.Rotation); - - //MXPSendPrimitive(data.localID, data.ownerID, data.acc, data.rvel, data.primShape, data.pos, data.objectID, data.vel, - // data.rotation, (uint)data.flags, data.text, data.color, data.parentID, data.particleSystem, data.clickAction, - // data.material, data.textureanim); - - //Session.Send(me); - - throw new System.NotImplementedException(); - } - - public void ReprioritizeUpdates() - { - } - - public void FlushPrimUpdates() - { - } - - public void SendInventoryFolderDetails(UUID ownerID, UUID folderID, List items, List folders, int version, bool fetchFolders, bool fetchItems) - { - // Need to translate to MXP somehow - } - - public void SendInventoryItemDetails(UUID ownerID, InventoryItemBase item) - { - // Need to translate to MXP somehow - } - - public void SendInventoryItemCreateUpdate(InventoryItemBase Item, uint callbackId) - { - // Need to translate to MXP somehow - } - - public void SendRemoveInventoryItem(UUID itemID) - { - // Need to translate to MXP somehow - } - - public void SendTakeControls(int controls, bool passToAgent, bool TakeControls) - { - // Need to translate to MXP somehow - } - - public void SendTaskInventory(UUID taskID, short serial, byte[] fileName) - { - // Need to translate to MXP somehow - } - - public void SendBulkUpdateInventory(InventoryNodeBase node) - { - // Need to translate to MXP somehow - } - - public void SendXferPacket(ulong xferID, uint packet, byte[] data) - { - // SL Specific, Ignore. (Remove from IClient) - } - - public void SendAbortXferPacket(ulong xferID) - { - - } - - - public void SendEconomyData(float EnergyEfficiency, int ObjectCapacity, int ObjectCount, int PriceEnergyUnit, int PriceGroupCreate, int PriceObjectClaim, float PriceObjectRent, float PriceObjectScaleFactor, int PriceParcelClaim, float PriceParcelClaimFactor, int PriceParcelRent, int PricePublicObjectDecay, int PricePublicObjectDelete, int PriceRentLight, int PriceUpload, int TeleportMinPrice, float TeleportPriceExponent) - { - // SL Specific, Ignore. (Remove from IClient) - } - - public void SendAvatarPickerReply(AvatarPickerReplyAgentDataArgs AgentData, List Data) - { - // Need to translate to MXP somehow - } - - public void SendAgentDataUpdate(UUID agentid, UUID activegroupid, string firstname, string lastname, ulong grouppowers, string groupname, string grouptitle) - { - // Need to translate to MXP somehow - // TODO: This may need doing - involves displaying the users avatar name - } - - public void SendPreLoadSound(UUID objectID, UUID ownerID, UUID soundID) - { - // Need to translate to MXP somehow - } - - public void SendPlayAttachedSound(UUID soundID, UUID objectID, UUID ownerID, float gain, byte flags) - { - // Need to translate to MXP somehow - } - - public void SendTriggeredSound(UUID soundID, UUID ownerID, UUID objectID, UUID parentID, ulong handle, Vector3 position, float gain) - { - // Need to translate to MXP somehow - } - - public void SendAttachedSoundGainChange(UUID objectID, float gain) - { - // Need to translate to MXP somehow - } - - public void SendNameReply(UUID profileId, string firstname, string lastname) - { - // SL Specific - } - - public void SendAlertMessage(string message) - { - SendChatMessage(message, 0, Vector3.Zero, "System", UUID.Zero, 0, 0); - } - - public void SendAgentAlertMessage(string message, bool modal) - { - SendChatMessage(message, 0, Vector3.Zero, "System" + (modal ? " Notice" : ""), UUID.Zero, 0, 0); - } - - public void SendLoadURL(string objectname, UUID objectID, UUID ownerID, bool groupOwned, string message, string url) - { - // TODO: Probably can do this better - SendChatMessage("Please visit: " + url, 0, Vector3.Zero, objectname, UUID.Zero, 0, 0); - } - - public void SendDialog(string objectname, UUID objectID, string ownerFirstName, string ownerLastName, string msg, UUID textureID, int ch, string[] buttonlabels) - { - // TODO: Probably can do this better - SendChatMessage("Dialog: " + msg, 0, Vector3.Zero, objectname, UUID.Zero, 0, 0); - } - - public bool AddMoney(int debit) - { - SendChatMessage("You were paid: " + debit, 0, Vector3.Zero, "System", UUID.Zero, 0, 0); - return true; - } - - public void SendSunPos(Vector3 sunPos, Vector3 sunVel, ulong CurrentTime, uint SecondsPerSunCycle, uint SecondsPerYear, float OrbitalPosition) - { - // Need to translate to MXP somehow - // Send a light object? - } - - public void SendViewerEffect(ViewerEffectPacket.EffectBlock[] effectBlocks) - { - // Need to translate to MXP somehow - } - - public void SendViewerTime(int phase) - { - // Need to translate to MXP somehow - } - - public UUID GetDefaultAnimation(string name) - { - return UUID.Zero; - } - - public void SendAvatarProperties(UUID avatarID, string aboutText, string bornOn, byte[] charterMember, string flAbout, uint flags, UUID flImageID, UUID imageID, string profileURL, UUID partnerID) - { - // Need to translate to MXP somehow - } - - public void SendScriptQuestion(UUID taskID, string taskName, string ownerName, UUID itemID, int question) - { - // Need to translate to MXP somehow - } - - public void SendHealth(float health) - { - // Need to translate to MXP somehow - } - - public void SendEstateList(UUID invoice, int code, UUID[] Data, uint estateID) - { - // Need to translate to MXP somehow - } - - public void SendBannedUserList(UUID invoice, EstateBan[] banlist, uint estateID) - { - // Need to translate to MXP somehow - } - - public void SendRegionInfoToEstateMenu(RegionInfoForEstateMenuArgs args) - { - // Need to translate to MXP somehow - } - - public void SendEstateCovenantInformation(UUID covenant) - { - // Need to translate to MXP somehow - } - - public void SendDetailedEstateData(UUID invoice, string estateName, uint estateID, uint parentEstate, uint estateFlags, uint sunPosition, UUID covenant, string abuseEmail, UUID estateOwner) - { - // Need to translate to MXP somehow - } - - public void SendLandProperties(int sequence_id, bool snap_selection, int request_result, ILandObject lo, float simObjectBonusFactor, int parcelObjectCapacity, int simObjectCapacity, uint regionFlags) - { - // Need to translate to MXP somehow - } - - public void SendLandAccessListData(List avatars, uint accessFlag, int localLandID) - { - // Need to translate to MXP somehow - } - - public void SendForceClientSelectObjects(List objectIDs) - { - // Need to translate to MXP somehow - } - - public void SendLandObjectOwners(LandData land, List groups, Dictionary ownersAndCount) - { - // Need to translate to MXP somehow - } - - public void SendCameraConstraint(Vector4 ConstraintPlane) - { - - } - - public void SendLandParcelOverlay(byte[] data, int sequence_id) - { - // Need to translate to MXP somehow - } - - public void SendParcelMediaCommand(uint flags, ParcelMediaCommandEnum command, float time) - { - // Need to translate to MXP somehow - } - - public void SendParcelMediaUpdate(string mediaUrl, UUID mediaTextureID, byte autoScale, string mediaType, string mediaDesc, int mediaWidth, int mediaHeight, byte mediaLoop) - { - // Need to translate to MXP somehow - } - - public void SendAssetUploadCompleteMessage(sbyte AssetType, bool Success, UUID AssetFullID) - { - // Need to translate to MXP somehow - } - - public void SendConfirmXfer(ulong xferID, uint PacketID) - { - // Need to translate to MXP somehow - } - - public void SendXferRequest(ulong XferID, short AssetType, UUID vFileID, byte FilePath, byte[] FileName) - { - // Need to translate to MXP somehow - } - - public void SendInitiateDownload(string simFileName, string clientFileName) - { - // Need to translate to MXP somehow - } - - public void SendImageFirstPart(ushort numParts, UUID ImageUUID, uint ImageSize, byte[] ImageData, byte imageCodec) - { - // Need to translate to MXP somehow - } - - public void SendImageNextPart(ushort partNumber, UUID imageUuid, byte[] imageData) - { - // Need to translate to MXP somehow - } - - public void SendImageNotFound(UUID imageid) - { - // Need to translate to MXP somehow - } - - public void SendShutdownConnectionNotice() - { - // Need to translate to MXP somehow - } - - public void SendSimStats(SimStats stats) - { - // Need to translate to MXP somehow - } - - public void SendObjectPropertiesFamilyData(ISceneEntity Entity, uint RequestFlags) - { - //throw new System.NotImplementedException(); - } - - public void SendObjectPropertiesReply(ISceneEntity entity) - { - //throw new System.NotImplementedException(); - } - - public void SendAgentOffline(UUID[] agentIDs) - { - // Need to translate to MXP somehow (Friends List) - } - - public void SendAgentOnline(UUID[] agentIDs) - { - // Need to translate to MXP somehow (Friends List) - } - - public void SendSitResponse(UUID TargetID, Vector3 OffsetPos, Quaternion SitOrientation, bool autopilot, Vector3 CameraAtOffset, Vector3 CameraEyeOffset, bool ForceMouseLook) - { - // Need to translate to MXP somehow - } - - public void SendAdminResponse(UUID Token, uint AdminLevel) - { - // Need to translate to MXP somehow - } - - public void SendGroupMembership(GroupMembershipData[] GroupMembership) - { - // Need to translate to MXP somehow - } - - public void SendGroupNameReply(UUID groupLLUID, string GroupName) - { - // Need to translate to MXP somehow - } - - public void SendJoinGroupReply(UUID groupID, bool success) - { - // Need to translate to MXP somehow - } - - public void SendEjectGroupMemberReply(UUID agentID, UUID groupID, bool success) - { - // Need to translate to MXP somehow - } - - public void SendLeaveGroupReply(UUID groupID, bool success) - { - // Need to translate to MXP somehow - } - - public void SendLandStatReply(uint reportType, uint requestFlags, uint resultCount, LandStatReportItem[] lsrpia) - { - // Need to translate to MXP somehow - } - - public void SendScriptRunningReply(UUID objectID, UUID itemID, bool running) - { - // Need to translate to MXP somehow - } - - public void SendAsset(AssetRequestToClient req) - { - // Need to translate to MXP somehow - } - - public void SendTexture(AssetBase TextureAsset) - { - // Need to translate to MXP somehow - } - - public byte[] GetThrottlesPacked(float multiplier) - { - // LL Specific, get out of IClientAPI - - const int singlefloat = 4; - float tResend = multiplier; - float tLand = multiplier; - float tWind = multiplier; - float tCloud = multiplier; - float tTask = multiplier; - float tTexture = multiplier; - float tAsset = multiplier; - - byte[] throttles = new byte[singlefloat * 7]; - int i = 0; - Buffer.BlockCopy(BitConverter.GetBytes(tResend), 0, throttles, singlefloat * i, singlefloat); - i++; - Buffer.BlockCopy(BitConverter.GetBytes(tLand), 0, throttles, singlefloat * i, singlefloat); - i++; - Buffer.BlockCopy(BitConverter.GetBytes(tWind), 0, throttles, singlefloat * i, singlefloat); - i++; - Buffer.BlockCopy(BitConverter.GetBytes(tCloud), 0, throttles, singlefloat * i, singlefloat); - i++; - Buffer.BlockCopy(BitConverter.GetBytes(tTask), 0, throttles, singlefloat * i, singlefloat); - i++; - Buffer.BlockCopy(BitConverter.GetBytes(tTexture), 0, throttles, singlefloat * i, singlefloat); - i++; - Buffer.BlockCopy(BitConverter.GetBytes(tAsset), 0, throttles, singlefloat * i, singlefloat); - - return throttles; - } - - public void SendBlueBoxMessage(UUID FromAvatarID, string FromAvatarName, string Message) - { - SendChatMessage(Message, 0, Vector3.Zero, FromAvatarName, UUID.Zero, 0, 0); - } - - public void SendLogoutPacket() - { - LeaveRequestMessage lrm = new LeaveRequestMessage(); - Session.Send(lrm); - } - - public EndPoint GetClientEP() - { - return null; - } - - public ClientInfo GetClientInfo() - { - return null; - //throw new System.NotImplementedException(); - } - - public void SetClientInfo(ClientInfo info) - { - //throw new System.NotImplementedException(); - } - - public void SetClientOption(string option, string value) - { - // Need to translate to MXP somehow - } - - public string GetClientOption(string option) - { - // Need to translate to MXP somehow - return ""; - } - - public void Terminate() - { - Close(); - } - - public void SendSetFollowCamProperties(UUID objectID, SortedDictionary parameters) - { - // Need to translate to MXP somehow - } - - public void SendClearFollowCamProperties(UUID objectID) - { - // Need to translate to MXP somehow - } - - public void SendRegionHandle(UUID regoinID, ulong handle) - { - // Need to translate to MXP somehow - } - - public void SendParcelInfo(RegionInfo info, LandData land, UUID parcelID, uint x, uint y) - { - // Need to translate to MXP somehow - } - - public void SendScriptTeleportRequest(string objName, string simName, Vector3 pos, Vector3 lookAt) - { - // Need to translate to MXP somehow - } - - public void SendDirPlacesReply(UUID queryID, DirPlacesReplyData[] data) - { - // Need to translate to MXP somehow - } - - public void SendDirPeopleReply(UUID queryID, DirPeopleReplyData[] data) - { - // Need to translate to MXP somehow - } - - public void SendDirEventsReply(UUID queryID, DirEventsReplyData[] data) - { - // Need to translate to MXP somehow - } - - public void SendDirGroupsReply(UUID queryID, DirGroupsReplyData[] data) - { - // Need to translate to MXP somehow - } - - public void SendDirClassifiedReply(UUID queryID, DirClassifiedReplyData[] data) - { - // Need to translate to MXP somehow - } - - public void SendDirLandReply(UUID queryID, DirLandReplyData[] data) - { - // Need to translate to MXP somehow - } - - public void SendDirPopularReply(UUID queryID, DirPopularReplyData[] data) - { - // Need to translate to MXP somehow - } - - public void SendEventInfoReply(EventData info) - { - // Need to translate to MXP somehow - } - - public void SendMapItemReply(mapItemReply[] replies, uint mapitemtype, uint flags) - { - // Need to translate to MXP somehow - } - - public void SendAvatarGroupsReply(UUID avatarID, GroupMembershipData[] data) - { - // Need to translate to MXP somehow - } - - public void SendOfferCallingCard(UUID srcID, UUID transactionID) - { - // Need to translate to MXP somehow - } - - public void SendAcceptCallingCard(UUID transactionID) - { - // Need to translate to MXP somehow - } - - public void SendDeclineCallingCard(UUID transactionID) - { - // Need to translate to MXP somehow - } - - public void SendTerminateFriend(UUID exFriendID) - { - // Need to translate to MXP somehow - } - - public void SendAvatarClassifiedReply(UUID targetID, UUID[] classifiedID, string[] name) - { - // Need to translate to MXP somehow - } - - 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) - { - // Need to translate to MXP somehow - } - - public void SendAgentDropGroup(UUID groupID) - { - // Need to translate to MXP somehow - } - - public void SendAvatarNotesReply(UUID targetID, string text) - { - // Need to translate to MXP somehow - } - - public void SendAvatarPicksReply(UUID targetID, Dictionary picks) - { - // Need to translate to MXP somehow - } - - public void SendAvatarClassifiedReply(UUID targetID, Dictionary classifieds) - { - // Need to translate to MXP somehow - } - - public void SendParcelDwellReply(int localID, UUID parcelID, float dwell) - { - // Need to translate to MXP somehow - } - - public void SendUserInfoReply(bool imViaEmail, bool visible, string email) - { - // Need to translate to MXP somehow - } - - public void KillEndDone() - { - Stop(); - } - - public bool AddGenericPacketHandler(string MethodName, GenericMessage handler) - { - // Need to translate to MXP somehow - return true; - } - - #endregion - - #region IClientCore - - public bool TryGet(out T iface) - { - iface = default(T); - return false; - } - - public T Get() - { - return default(T); - } - - public void Disconnect(string reason) - { - Kick(reason); - Close(); - } - - public void Disconnect() - { - Close(); - } - - #endregion - - public void SendCreateGroupReply(UUID groupID, bool success, string message) - { - } - - public void RefreshGroupMembership() - { - } - - public void SendUseCachedMuteList() - { - } - - public void SendMuteListUpdate(string filename) - { - } - - 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) - { - } - - public void SendRebakeAvatarTextures(UUID textureID) - { - } - - public void SendAvatarInterestsReply(UUID avatarID, uint wantMask, string wantText, uint skillsMask, string skillsText, string languages) - { - } - - public void SendGroupAccountingDetails(IClientAPI sender,UUID groupID, UUID transactionID, UUID sessionID, int amt) - { - } - - public void SendGroupAccountingSummary(IClientAPI sender,UUID groupID, uint moneyAmt, int totalTier, int usedTier) - { - } - - public void SendGroupTransactionsSummaryDetails(IClientAPI sender,UUID groupID, UUID transactionID, UUID sessionID,int amt) - { - } - - public void SendGroupVoteHistory(UUID groupID, UUID transactionID, GroupVoteHistory[] Votes) - { - } - - public void SendGroupActiveProposals(UUID groupID, UUID transactionID, GroupActiveProposals[] Proposals) - { - } - - public void SendChangeUserRights(UUID agentID, UUID friendID, int rights) - { - } - - public void SendTextBoxRequest(string message, int chatChannel, string objectname, string ownerFirstName, string ownerLastName, UUID objectId) - { - } - - public void StopFlying(ISceneEntity presence) - { - } - - public void SendPlacesReply(UUID queryID, UUID transactionID, PlacesReplyData[] data) - { - } - } -} diff --git a/OpenSim/Client/MXP/MXPModule.cs b/OpenSim/Client/MXP/MXPModule.cs deleted file mode 100644 index 0b442cca15..0000000000 --- a/OpenSim/Client/MXP/MXPModule.cs +++ /dev/null @@ -1,131 +0,0 @@ -/* - * Copyright (c) Contributors, http://opensimulator.org/ - * See CONTRIBUTORS.TXT for a full list of copyright holders. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * * Neither the name of the OpenSimulator Project nor the - * names of its contributors may be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -using System; -using System.Collections.Generic; -using System.Reflection; -using System.Text; -using System.Timers; -using log4net; -using MXP; -using Nini.Config; -using OpenMetaverse; -using OpenSim.Client.MXP.PacketHandler; -using OpenSim.Region.Framework.Interfaces; -using OpenSim.Region.Framework.Scenes; - -namespace OpenSim.Client.MXP -{ - - /** - * MXP Client Module which adds MXP support to client / region communication. - */ - public class MXPModule : IRegionModule - { - private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); - - private MXPPacketServer m_server; - - private IConfigSource m_config; - private int m_port = 1253; - private Timer m_ticker; - - private readonly Dictionary m_scenes = new Dictionary(); - private bool m_shutdown; - - public void Initialise(Scene scene, IConfigSource source) - { - if (!m_scenes.ContainsKey(scene.RegionInfo.RegionID)) - m_scenes.Add(scene.RegionInfo.RegionID, scene); - - m_config = source; - } - - public void PostInitialise() - { - if (m_config.Configs["MXP"] != null) - { - IConfig con = m_config.Configs["MXP"]; - - if (!con.GetBoolean("Enabled", false)) - return; - - m_port = con.GetInt("Port", m_port); - - m_server = new MXPPacketServer(m_port, m_scenes,m_config.Configs["StandAlone"].GetBoolean("accounts_authenticate",true)); - - m_ticker = new Timer(100); - m_ticker.AutoReset = false; - m_ticker.Elapsed += ticker_Elapsed; - - lock (m_ticker) - m_ticker.Start(); - - m_log.Info("[MXP ClientStack] MXP Enabled and Listening"); - } - } - - void ticker_Elapsed(object sender, ElapsedEventArgs e) - { - try - { - m_server.Process(); - } - catch (Exception ex) - { - m_log.Error("[MXP ClientStack]: Unhandled exception in process loop: " + ex.ToString() + " :" + ex.StackTrace.ToString()); - } - - if (!m_shutdown) - { - lock (m_ticker) - m_ticker.Start(); - } - } - - public void Close() - { - m_shutdown = true; - if (m_ticker != null) - { - lock (m_ticker) - m_ticker.Stop(); - } - } - - public string Name - { - get { return "MXP ClientStack Module"; } - } - - public bool IsSharedModule - { - get { return true; } - } - - } -} diff --git a/OpenSim/Client/MXP/MXPUtil.cs b/OpenSim/Client/MXP/MXPUtil.cs deleted file mode 100644 index 3387145c22..0000000000 --- a/OpenSim/Client/MXP/MXPUtil.cs +++ /dev/null @@ -1,42 +0,0 @@ -/* - * Copyright (c) Contributors, http://opensimulator.org/ - * See CONTRIBUTORS.TXT for a full list of copyright holders. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * * Neither the name of the OpenSimulator Project nor the - * names of its contributors may be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -using System; -using System.Collections.Generic; -using System.Text; -using OpenMetaverse; - -namespace OpenSim.Client.MXP -{ - public static class MXPUtil - { - public static string GenerateMXPURL(string server, int port, UUID bubbleID, Vector3 location) - { - return string.Format("mxp://{0}:{1}/{2}/{3}", server, port, bubbleID.Guid, location); - } - } -} diff --git a/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs b/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs deleted file mode 100644 index dcecb8b384..0000000000 --- a/OpenSim/Client/MXP/PacketHandler/MXPPacketServer.cs +++ /dev/null @@ -1,561 +0,0 @@ -/* - * Copyright (c) Contributors, http://opensimulator.org/ - * See CONTRIBUTORS.TXT for a full list of copyright holders. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * * Neither the name of the OpenSimulator Project nor the - * names of its contributors may be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -/* This file borrows heavily from MXPServer.cs - the reference MXPServer - * See http://www.bubblecloud.org for a copy of the original file and - * implementation details. */ - -using System; -using System.Collections.Generic; -using System.Reflection; -using System.Threading; -using log4net; -using MXP; -using MXP.Messages; -using OpenMetaverse; -using OpenSim.Client.MXP.ClientStack; -using OpenSim.Framework; -using OpenSim.Region.Framework.Scenes; -using OpenSim.Framework.Communications; -using OpenSim.Services.Interfaces; -using System.Security.Cryptography; - -namespace OpenSim.Client.MXP.PacketHandler -{ - public class MXPPacketServer - { - internal static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); - - #region Fields - - private readonly List m_clients = new List(); - private readonly Dictionary m_scenes; - private readonly Transmitter m_transmitter; - -// private readonly Thread m_clientThread; - - private readonly IList m_sessions = new List(); - private readonly IList m_sessionsToClient = new List(); - private readonly IList m_sessionsToRemove = new List(); - - private readonly int m_port; -// private readonly bool m_accountsAuthenticate; - - private readonly String m_programName; - private readonly byte m_programMajorVersion; - private readonly byte m_programMinorVersion; - - #endregion - - #region Constructors - - public MXPPacketServer(int port, Dictionary scenes, bool accountsAuthenticate) - { - m_port = port; -// m_accountsAuthenticate = accountsAuthenticate; - - m_scenes = scenes; - - m_programMinorVersion = 63; - m_programMajorVersion = 0; - m_programName = "OpenSimulator"; - - m_transmitter = new Transmitter(port); - - StartListener(); - } - - public void StartListener() - { - m_log.Info("[MXP ClientStack] Transmitter starting on UDP server port: " + m_port); - m_transmitter.Startup(); - m_log.Info("[MXP ClientStack] Transmitter started. MXP version: "+MxpConstants.ProtocolMajorVersion+"."+MxpConstants.ProtocolMinorVersion+" Source Revision: "+MxpConstants.ProtocolSourceRevision); - } - - #endregion - - #region Properties - - /// - /// Number of sessions pending. (Process() accepts pending sessions). - /// - public int PendingSessionCount - { - get - { - return m_transmitter.PendingSessionCount; - } - } - /// - /// Number of connected sessions. - /// - public int SessionCount - { - get - { - return m_sessions.Count; - } - } - /// - /// Property reflecting whether client transmitter threads are alive. - /// - public bool IsTransmitterAlive - { - get - { - return m_transmitter != null && m_transmitter.IsAlive; - } - } - /// - /// Number of packets sent. - /// - public ulong PacketsSent - { - get - { - return m_transmitter != null ? m_transmitter.PacketsSent : 0; - } - } - /// - /// Number of packets received. - /// - public ulong PacketsReceived - { - get - { - return m_transmitter != null ? m_transmitter.PacketsReceived : 0; - } - } - /// - /// Bytes client has received so far. - /// - public ulong BytesReceived - { - get - { - return m_transmitter != null ? m_transmitter.BytesReceived : 0; - } - } - /// - /// Bytes client has sent so far. - /// - public ulong BytesSent - { - get - { - return m_transmitter != null ? m_transmitter.BytesSent : 0; - } - } - /// - /// Number of bytes received (bytes per second) during past second. - /// - public double ReceiveRate - { - get - { - return m_transmitter != null ? m_transmitter.ReceiveRate : 0; - } - } - /// - /// Number of bytes sent (bytes per second) during past second. - /// - public double SendRate - { - get - { - return m_transmitter != null ? m_transmitter.SendRate : 0; - } - } - - #endregion - - #region Session Management - - public void Disconnect(Session session) - { - if (session.IsConnected) - { - Message message = MessageFactory.Current.ReserveMessage(typeof(LeaveRequestMessage)); - session.Send(message); - MessageFactory.Current.ReleaseMessage(message); - } - else - { - throw new Exception("Not connected."); - } - } - - #endregion - - #region Processing - - public void Process() - { - ProcessMessages(); - Clean(); - } - - public void Clean() - { - foreach (MXPClientView clientView in m_clients) - { - if (clientView.Session.SessionState == SessionState.Disconnected) - { - m_sessionsToRemove.Add(clientView); - } - } - - foreach (MXPClientView clientView in m_sessionsToRemove) - { - clientView.Scene.RemoveClient(clientView.AgentId); - clientView.OnClean(); - m_clients.Remove(clientView); - m_sessions.Remove(clientView.Session); - } - - m_sessionsToRemove.Clear(); - } - - public void ProcessMessages() - { - if (m_transmitter.PendingSessionCount > 0) - { - Session tmp = m_transmitter.AcceptPendingSession(); - m_sessions.Add(tmp); - m_sessionsToClient.Add(tmp); - - } - - List tmpRemove = new List(); - - foreach (Session session in m_sessionsToClient) - { - while (session.AvailableMessages > 0) - { - Message message = session.Receive(); - - if (message.GetType() == typeof (JoinRequestMessage)) - { - - JoinRequestMessage joinRequestMessage = (JoinRequestMessage) message; - - m_log.Info("[MXP ClientStack]: Session join request: " + session.SessionId + " (" + - (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + - session.RemoteEndPoint.Port + ")"); - - try - { - - if (joinRequestMessage.BubbleId == Guid.Empty) - { - foreach (Scene scene in m_scenes.Values) - { - if (scene.RegionInfo.RegionName == joinRequestMessage.BubbleName) - { - m_log.Info("[MXP ClientStack]: Resolved region by name: " + joinRequestMessage.BubbleName + " (" + scene.RegionInfo.RegionID + ")"); - joinRequestMessage.BubbleId = scene.RegionInfo.RegionID.Guid; - } - } - } - - if (joinRequestMessage.BubbleId == Guid.Empty) - { - m_log.Warn("[MXP ClientStack]: Failed to resolve region by name: " + joinRequestMessage.BubbleName); - } - - UUID sceneId = new UUID(joinRequestMessage.BubbleId); - - bool regionExists = true; - if (!m_scenes.ContainsKey(sceneId)) - { - m_log.Info("[MXP ClientStack]: No such region: " + sceneId); - regionExists = false; - } - - UUID userId = UUID.Zero; - UserAccount account = null; - bool authorized = regionExists ? AuthoriseUser(joinRequestMessage.ParticipantName, - joinRequestMessage.ParticipantPassphrase, - new UUID(joinRequestMessage.BubbleId), out account) - : false; - - if (authorized) - { - Scene scene = m_scenes[sceneId]; - UUID mxpSessionID = UUID.Random(); - - string reason; - - m_log.Debug("[MXP ClientStack]: Session join request success: " + session.SessionId + " (" + - (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + - session.RemoteEndPoint.Port + ")"); - - m_log.Debug("[MXP ClientStack]: Attaching UserAgent to UserProfile..."); - UUID secureSession = UUID.Zero; - AttachUserAgentToUserProfile(account, session, mxpSessionID, sceneId, out secureSession); - m_log.Debug("[MXP ClientStack]: Attached UserAgent to UserProfile."); - m_log.Debug("[MXP ClientStack]: Preparing Scene to Connection..."); - if (!PrepareSceneForConnection(mxpSessionID, secureSession, sceneId, account, out reason)) - { - m_log.DebugFormat("[MXP ClientStack]: Scene refused connection: {0}", reason); - DeclineConnection(session, joinRequestMessage); - tmpRemove.Add(session); - continue; - } - m_log.Debug("[MXP ClientStack]: Prepared Scene to Connection."); - m_log.Debug("[MXP ClientStack]: Accepting connection..."); - AcceptConnection(session, joinRequestMessage, mxpSessionID, userId); - m_log.Info("[MXP ClientStack]: Accepted connection."); - - m_log.Debug("[MXP ClientStack]: Creating ClientView...."); - MXPClientView client = new MXPClientView(session, mxpSessionID, userId, scene, account.FirstName, account.LastName); - m_clients.Add(client); - m_log.Debug("[MXP ClientStack]: Created ClientView."); - - client.MXPSendSynchronizationBegin(m_scenes[new UUID(joinRequestMessage.BubbleId)].SceneContents.GetTotalObjectsCount()); - - m_log.Debug("[MXP ClientStack]: Starting ClientView..."); - try - { - client.Start(); - m_log.Debug("[MXP ClientStack]: Started ClientView."); - } - catch (Exception e) - { - m_log.Error(e); - } - - m_log.Debug("[MXP ClientStack]: Connected"); - } - else - { - m_log.Info("[MXP ClientStack]: Session join request failure: " + session.SessionId + " (" + - (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + - session.RemoteEndPoint.Port + ")"); - - DeclineConnection(session, joinRequestMessage); - } - } - catch (Exception e) - { - m_log.Error("[MXP ClientStack]: Session join request failure: " + session.SessionId + " (" + - (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + - session.RemoteEndPoint.Port + "): "+e.ToString()+" :"+e.StackTrace.ToString()); - } - tmpRemove.Add(session); - } - } - } - - foreach (Session session in tmpRemove) - { - m_sessionsToClient.Remove(session); - } - - foreach (MXPClientView clientView in m_clients) - { - int messagesProcessedCount = 0; - Session session = clientView.Session; - - while (session.AvailableMessages > 0) - { - Message message = session.Receive(); - - if (message.GetType() == typeof(LeaveRequestMessage)) - { - LeaveResponseMessage leaveResponseMessage = (LeaveResponseMessage)MessageFactory.Current.ReserveMessage( - typeof(LeaveResponseMessage)); - - m_log.Debug("[MXP ClientStack]: Session leave request: " + session.SessionId + " (" + (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + session.RemoteEndPoint.Port + ")"); - - leaveResponseMessage.RequestMessageId = message.MessageId; - leaveResponseMessage.FailureCode = 0; - session.Send(leaveResponseMessage); - - if (session.SessionState != SessionState.Disconnected) - { - session.SetStateDisconnected(); - } - - m_log.Debug("[MXP ClientStack]: Removing Client from Scene"); - //clientView.Scene.RemoveClient(clientView.AgentId); - } - if (message.GetType() == typeof(LeaveResponseMessage)) - { - LeaveResponseMessage leaveResponseMessage = (LeaveResponseMessage)message; - - m_log.Debug("[MXP ClientStack]: Session leave response: " + session.SessionId + " (" + (session.IsIncoming ? "from" : "to") + " " + session.RemoteEndPoint.Address + ":" + session.RemoteEndPoint.Port + ")"); - - if (leaveResponseMessage.FailureCode == 0) - { - session.SetStateDisconnected(); - } - - m_log.Debug("[MXP ClientStack]: Removing Client from Scene"); - //clientView.Scene.RemoveClient(clientView.AgentId); - } - else - { - clientView.MXPPRocessMessage(message); - } - - MessageFactory.Current.ReleaseMessage(message); - messagesProcessedCount++; - if (messagesProcessedCount > 1000) - { - break; - } - } - } - } - - private void AcceptConnection(Session session, JoinRequestMessage joinRequestMessage, UUID mxpSessionID, UUID userId) - { - JoinResponseMessage joinResponseMessage = (JoinResponseMessage)MessageFactory.Current.ReserveMessage( - typeof(JoinResponseMessage)); - - joinResponseMessage.RequestMessageId = joinRequestMessage.MessageId; - joinResponseMessage.FailureCode = MxpResponseCodes.SUCCESS; - - joinResponseMessage.BubbleId = joinRequestMessage.BubbleId; - joinResponseMessage.ParticipantId = userId.Guid; - joinResponseMessage.AvatarId = userId.Guid; - joinResponseMessage.BubbleAssetCacheUrl = "http://" + - NetworkUtil.GetHostFor(session.RemoteEndPoint.Address, - m_scenes[ - new UUID(joinRequestMessage.BubbleId)]. - RegionInfo. - ExternalHostName) + ":" + - m_scenes[new UUID(joinRequestMessage.BubbleId)].RegionInfo. - HttpPort + "/assets/"; - - joinResponseMessage.BubbleName = m_scenes[new UUID(joinRequestMessage.BubbleId)].RegionInfo.RegionName; - - joinResponseMessage.BubbleRange = 128; - joinResponseMessage.BubblePerceptionRange = 128 + 256; - joinResponseMessage.BubbleRealTime = 0; - joinResponseMessage.ProgramName = m_programName; - joinResponseMessage.ProgramMajorVersion = m_programMajorVersion; - joinResponseMessage.ProgramMinorVersion = m_programMinorVersion; - joinResponseMessage.ProtocolMajorVersion = MxpConstants.ProtocolMajorVersion; - joinResponseMessage.ProtocolMinorVersion = MxpConstants.ProtocolMinorVersion; - joinResponseMessage.ProtocolSourceRevision = MxpConstants.ProtocolSourceRevision; - - session.Send(joinResponseMessage); - - session.SetStateConnected(); - } - - private void DeclineConnection(Session session, Message joinRequestMessage) - { - JoinResponseMessage joinResponseMessage = (JoinResponseMessage)MessageFactory.Current.ReserveMessage(typeof(JoinResponseMessage)); - - joinResponseMessage.RequestMessageId = joinRequestMessage.MessageId; - joinResponseMessage.FailureCode = MxpResponseCodes.UNAUTHORIZED_OPERATION; - - joinResponseMessage.ProgramName = m_programName; - joinResponseMessage.ProgramMajorVersion = m_programMajorVersion; - joinResponseMessage.ProgramMinorVersion = m_programMinorVersion; - joinResponseMessage.ProtocolMajorVersion = MxpConstants.ProtocolMajorVersion; - joinResponseMessage.ProtocolMinorVersion = MxpConstants.ProtocolMinorVersion; - joinResponseMessage.ProtocolSourceRevision = MxpConstants.ProtocolSourceRevision; - - session.Send(joinResponseMessage); - - session.SetStateDisconnected(); - } - - public bool AuthoriseUser(string participantName, string password, UUID sceneId, out UserAccount account) - { - string firstName = ""; - string lastName = ""; - account = null; - - string[] nameParts = participantName.Split(' '); - if (nameParts.Length != 2) - { - m_log.Error("[MXP ClientStack]: Login failed as user name is not formed of first and last name separated by space: " + participantName); - return false; - } - firstName = nameParts[0]; - lastName = nameParts[1]; - - account = m_scenes[sceneId].UserAccountService.GetUserAccount(m_scenes[sceneId].RegionInfo.ScopeID, firstName, lastName); - if (account != null) - return (m_scenes[sceneId].AuthenticationService.Authenticate(account.PrincipalID, password, 1) != string.Empty); - - return false; - } - - private void AttachUserAgentToUserProfile(UserAccount account, Session session, UUID sessionId, UUID sceneId, out UUID secureSessionId) - { - secureSessionId = UUID.Random(); - Scene scene = m_scenes[sceneId]; - scene.PresenceService.LoginAgent(account.PrincipalID.ToString(), sessionId, secureSessionId); - } - - private bool PrepareSceneForConnection(UUID sessionId, UUID secureSessionId, UUID sceneId, UserAccount account, out string reason) - { - Scene scene = m_scenes[sceneId]; - - AgentCircuitData agent = new AgentCircuitData(); - agent.AgentID = account.PrincipalID; - agent.firstname = account.FirstName; - agent.lastname = account.LastName; - agent.SessionID = sessionId; - agent.SecureSessionID = secureSessionId; - agent.circuitcode = sessionId.CRC(); - agent.BaseFolder = UUID.Zero; - agent.InventoryFolder = UUID.Zero; - agent.startpos = new Vector3(0, 0, 0); // TODO Fill in region start position - agent.CapsPath = "http://localhost/"; - agent.Appearance = scene.AvatarService.GetAppearance(account.PrincipalID); - - if (agent.Appearance == null) - { - m_log.WarnFormat("[INTER]: Appearance not found for {0} {1}. Creating default.", agent.firstname, agent.lastname); - agent.Appearance = new AvatarAppearance(); - } - - return scene.NewUserConnection(agent, 0, out reason); - } - - public void PrintDebugInformation() - { - m_log.Info("[MXP ClientStack]: Statistics report"); - m_log.Info("Pending Sessions: " + PendingSessionCount); - m_log.Info("Sessions: " + SessionCount + " (Clients: " + m_clients.Count + " )"); - m_log.Info("Transmitter Alive?: " + IsTransmitterAlive); - m_log.Info("Packets Sent/Received: " + PacketsSent + " / " + PacketsReceived); - m_log.Info("Bytes Sent/Received: " + BytesSent + " / " + BytesReceived); - m_log.Info("Send/Receive Rate (bps): " + SendRate + " / " + ReceiveRate); - } - - #endregion - - } -} diff --git a/OpenSim/Client/VWoHTTP/ClientStack/VWHClientView.cs b/OpenSim/Client/VWoHTTP/ClientStack/VWHClientView.cs deleted file mode 100644 index d8cd0acbd9..0000000000 --- a/OpenSim/Client/VWoHTTP/ClientStack/VWHClientView.cs +++ /dev/null @@ -1,1231 +0,0 @@ -/* - * Copyright (c) Contributors, http://opensimulator.org/ - * See CONTRIBUTORS.TXT for a full list of copyright holders. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * * Neither the name of the OpenSimulator Project nor the - * names of its contributors may be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -using System; -using System.Collections.Generic; -using System.Drawing; -using System.Drawing.Imaging; -using System.IO; -using System.Net; -using System.Text; -using OpenMetaverse; -using OpenMetaverse.Imaging; -using OpenMetaverse.Packets; -using OpenSim.Framework; -using OpenSim.Framework.Servers; -using OpenSim.Framework.Servers.HttpServer; -using OpenSim.Region.Framework.Scenes; - -namespace OpenSim.Client.VWoHTTP.ClientStack -{ - class VWHClientView : IClientAPI - { - private Scene m_scene; - - - public bool ProcessInMsg(OSHttpRequest req, OSHttpResponse resp) - { - // 0 1 2 3 - // http://simulator.com:9000/vwohttp/sessionid/methodname/param - string[] urlparts = req.Url.AbsolutePath.Split(new char[] {'/'}, StringSplitOptions.RemoveEmptyEntries); - - UUID sessionID; - // Check for session - if (!UUID.TryParse(urlparts[1], out sessionID)) - return false; - // Check we match session - if (sessionID != SessionId) - return false; - - string method = urlparts[2]; - - string param = String.Empty; - if (urlparts.Length > 3) - param = urlparts[3]; - - bool found; - - switch (method.ToLower()) - { - case "textures": - found = ProcessTextureRequest(param, resp); - break; - default: - found = false; - break; - } - - return found; - } - - private bool ProcessTextureRequest(string param, OSHttpResponse resp) - { - UUID assetID; - if (!UUID.TryParse(param, out assetID)) - return false; - - AssetBase asset = m_scene.AssetService.Get(assetID.ToString()); - - if (asset == null) - return false; - - ManagedImage tmp; - Image imgData; - byte[] jpegdata; - - OpenJPEG.DecodeToImage(asset.Data, out tmp, out imgData); - - using (MemoryStream ms = new MemoryStream()) - { - imgData.Save(ms, ImageFormat.Jpeg); - jpegdata = ms.GetBuffer(); - } - - resp.ContentType = "image/jpeg"; - resp.ContentLength = jpegdata.Length; - resp.StatusCode = 200; - resp.Body.Write(jpegdata, 0, jpegdata.Length); - - return true; - } - - public VWHClientView(UUID sessionID, UUID agentID, string agentName, Scene scene) - { - m_scene = scene; - } - - #region Implementation of IClientAPI - - public Vector3 StartPos - { - get { throw new System.NotImplementedException(); } - set { throw new System.NotImplementedException(); } - } - - public UUID AgentId - { - get { throw new System.NotImplementedException(); } - } - - public UUID SessionId - { - get { throw new System.NotImplementedException(); } - } - - public UUID SecureSessionId - { - get { throw new System.NotImplementedException(); } - } - - public UUID ActiveGroupId - { - get { throw new System.NotImplementedException(); } - } - - public string ActiveGroupName - { - get { throw new System.NotImplementedException(); } - } - - public ulong ActiveGroupPowers - { - get { throw new System.NotImplementedException(); } - } - - public ulong GetGroupPowers(UUID groupID) - { - throw new System.NotImplementedException(); - } - - public bool IsGroupMember(UUID GroupID) - { - throw new System.NotImplementedException(); - } - - public string FirstName - { - get { throw new System.NotImplementedException(); } - } - - public string LastName - { - get { throw new System.NotImplementedException(); } - } - - public IScene Scene - { - get { throw new System.NotImplementedException(); } - } - - public int NextAnimationSequenceNumber - { - get { throw new System.NotImplementedException(); } - } - - public string Name - { - get { throw new System.NotImplementedException(); } - } - - public bool IsActive - { - get { throw new System.NotImplementedException(); } - set { throw new System.NotImplementedException(); } - } - public bool IsLoggingOut - { - get { throw new System.NotImplementedException(); } - set { throw new System.NotImplementedException(); } - } - public bool SendLogoutPacketWhenClosing - { - set { throw new System.NotImplementedException(); } - } - - public uint CircuitCode - { - get { throw new System.NotImplementedException(); } - } - - public IPEndPoint RemoteEndPoint - { - get { throw new System.NotImplementedException(); } - } - - public event GenericMessage OnGenericMessage = delegate { }; - public event ImprovedInstantMessage OnInstantMessage = delegate { }; - public event ChatMessage OnChatFromClient = delegate { }; - public event TextureRequest OnRequestTexture = delegate { }; - public event RezObject OnRezObject = delegate { }; - public event ModifyTerrain OnModifyTerrain = delegate { }; - public event BakeTerrain OnBakeTerrain = delegate { }; - public event EstateChangeInfo OnEstateChangeInfo = delegate { }; - public event SetAppearance OnSetAppearance = delegate { }; - public event AvatarNowWearing OnAvatarNowWearing = delegate { }; - public event RezSingleAttachmentFromInv OnRezSingleAttachmentFromInv = delegate { return new UUID(); }; - public event RezMultipleAttachmentsFromInv OnRezMultipleAttachmentsFromInv = delegate { }; - public event UUIDNameRequest OnDetachAttachmentIntoInv = delegate { }; - public event ObjectAttach OnObjectAttach = delegate { }; - public event ObjectDeselect OnObjectDetach = delegate { }; - public event ObjectDrop OnObjectDrop = delegate { }; - public event StartAnim OnStartAnim = delegate { }; - public event StopAnim OnStopAnim = delegate { }; - public event LinkObjects OnLinkObjects = delegate { }; - public event DelinkObjects OnDelinkObjects = delegate { }; - public event RequestMapBlocks OnRequestMapBlocks = delegate { }; - public event RequestMapName OnMapNameRequest = delegate { }; - public event TeleportLocationRequest OnTeleportLocationRequest = delegate { }; - public event DisconnectUser OnDisconnectUser = delegate { }; - public event RequestAvatarProperties OnRequestAvatarProperties = delegate { }; - public event SetAlwaysRun OnSetAlwaysRun = delegate { }; - public event TeleportLandmarkRequest OnTeleportLandmarkRequest = delegate { }; - public event DeRezObject OnDeRezObject = delegate { }; - public event Action OnRegionHandShakeReply = delegate { }; - public event GenericCall1 OnRequestWearables = delegate { }; - public event GenericCall1 OnCompleteMovementToRegion = delegate { }; - public event UpdateAgent OnPreAgentUpdate; - public event UpdateAgent OnAgentUpdate = delegate { }; - public event AgentRequestSit OnAgentRequestSit = delegate { }; - public event AgentSit OnAgentSit = delegate { }; - public event AvatarPickerRequest OnAvatarPickerRequest = delegate { }; - public event Action OnRequestAvatarsData = delegate { }; - public event AddNewPrim OnAddPrim = delegate { }; - public event FetchInventory OnAgentDataUpdateRequest = delegate { }; - public event TeleportLocationRequest OnSetStartLocationRequest = delegate { }; - public event RequestGodlikePowers OnRequestGodlikePowers = delegate { }; - public event GodKickUser OnGodKickUser = delegate { }; - public event ObjectDuplicate OnObjectDuplicate = delegate { }; - public event ObjectDuplicateOnRay OnObjectDuplicateOnRay = delegate { }; - public event GrabObject OnGrabObject = delegate { }; - public event DeGrabObject OnDeGrabObject = delegate { }; - public event MoveObject OnGrabUpdate = delegate { }; - public event SpinStart OnSpinStart = delegate { }; - public event SpinObject OnSpinUpdate = delegate { }; - public event SpinStop OnSpinStop = delegate { }; - public event UpdateShape OnUpdatePrimShape = delegate { }; - public event ObjectExtraParams OnUpdateExtraParams = delegate { }; - public event ObjectRequest OnObjectRequest = delegate { }; - public event ObjectSelect OnObjectSelect = delegate { }; - public event ObjectDeselect OnObjectDeselect = delegate { }; - public event GenericCall7 OnObjectDescription = delegate { }; - public event GenericCall7 OnObjectName = delegate { }; - public event GenericCall7 OnObjectClickAction = delegate { }; - public event GenericCall7 OnObjectMaterial = delegate { }; - public event RequestObjectPropertiesFamily OnRequestObjectPropertiesFamily = delegate { }; - public event UpdatePrimFlags OnUpdatePrimFlags = delegate { }; - public event UpdatePrimTexture OnUpdatePrimTexture = delegate { }; - public event UpdateVector OnUpdatePrimGroupPosition = delegate { }; - public event UpdateVector OnUpdatePrimSinglePosition = delegate { }; - public event UpdatePrimRotation OnUpdatePrimGroupRotation = delegate { }; - public event UpdatePrimSingleRotation OnUpdatePrimSingleRotation = delegate { }; - public event UpdatePrimSingleRotationPosition OnUpdatePrimSingleRotationPosition = delegate { }; - public event UpdatePrimGroupRotation OnUpdatePrimGroupMouseRotation = delegate { }; - public event UpdateVector OnUpdatePrimScale = delegate { }; - public event UpdateVector OnUpdatePrimGroupScale = delegate { }; - public event StatusChange OnChildAgentStatus = delegate { }; - public event GenericCall2 OnStopMovement = delegate { }; - public event Action OnRemoveAvatar = delegate { }; - public event ObjectPermissions OnObjectPermissions = delegate { }; - public event CreateNewInventoryItem OnCreateNewInventoryItem = delegate { }; - public event LinkInventoryItem OnLinkInventoryItem = delegate { }; - public event CreateInventoryFolder OnCreateNewInventoryFolder = delegate { }; - public event UpdateInventoryFolder OnUpdateInventoryFolder = delegate { }; - public event MoveInventoryFolder OnMoveInventoryFolder = delegate { }; - public event FetchInventoryDescendents OnFetchInventoryDescendents = delegate { }; - public event PurgeInventoryDescendents OnPurgeInventoryDescendents = delegate { }; - public event FetchInventory OnFetchInventory = delegate { }; - public event RequestTaskInventory OnRequestTaskInventory = delegate { }; - public event UpdateInventoryItem OnUpdateInventoryItem = delegate { }; - public event CopyInventoryItem OnCopyInventoryItem = delegate { }; - public event MoveInventoryItem OnMoveInventoryItem = delegate { }; - public event RemoveInventoryFolder OnRemoveInventoryFolder = delegate { }; - public event RemoveInventoryItem OnRemoveInventoryItem = delegate { }; - public event UDPAssetUploadRequest OnAssetUploadRequest = delegate { }; - public event XferReceive OnXferReceive = delegate { }; - public event RequestXfer OnRequestXfer = delegate { }; - public event ConfirmXfer OnConfirmXfer = delegate { }; - public event AbortXfer OnAbortXfer = delegate { }; - public event RezScript OnRezScript = delegate { }; - public event UpdateTaskInventory OnUpdateTaskInventory = delegate { }; - public event MoveTaskInventory OnMoveTaskItem = delegate { }; - public event RemoveTaskInventory OnRemoveTaskItem = delegate { }; - public event RequestAsset OnRequestAsset = delegate { }; - public event UUIDNameRequest OnNameFromUUIDRequest = delegate { }; - public event ParcelAccessListRequest OnParcelAccessListRequest = delegate { }; - public event ParcelAccessListUpdateRequest OnParcelAccessListUpdateRequest = delegate { }; - public event ParcelPropertiesRequest OnParcelPropertiesRequest = delegate { }; - public event ParcelDivideRequest OnParcelDivideRequest = delegate { }; - public event ParcelJoinRequest OnParcelJoinRequest = delegate { }; - public event ParcelPropertiesUpdateRequest OnParcelPropertiesUpdateRequest = delegate { }; - public event ParcelSelectObjects OnParcelSelectObjects = delegate { }; - public event ParcelObjectOwnerRequest OnParcelObjectOwnerRequest = delegate { }; - public event ParcelAbandonRequest OnParcelAbandonRequest = delegate { }; - public event ParcelGodForceOwner OnParcelGodForceOwner = delegate { }; - public event ParcelReclaim OnParcelReclaim = delegate { }; - public event ParcelReturnObjectsRequest OnParcelReturnObjectsRequest = delegate { }; - public event ParcelDeedToGroup OnParcelDeedToGroup = delegate { }; - public event RegionInfoRequest OnRegionInfoRequest = delegate { }; - public event EstateCovenantRequest OnEstateCovenantRequest = delegate { }; - public event FriendActionDelegate OnApproveFriendRequest = delegate { }; - public event FriendActionDelegate OnDenyFriendRequest = delegate { }; - public event FriendshipTermination OnTerminateFriendship = delegate { }; - public event GrantUserFriendRights OnGrantUserRights = delegate { }; - public event MoneyTransferRequest OnMoneyTransferRequest = delegate { }; - public event EconomyDataRequest OnEconomyDataRequest = delegate { }; - public event MoneyBalanceRequest OnMoneyBalanceRequest = delegate { }; - public event UpdateAvatarProperties OnUpdateAvatarProperties = delegate { }; - public event ParcelBuy OnParcelBuy = delegate { }; - public event RequestPayPrice OnRequestPayPrice = delegate { }; - public event ObjectSaleInfo OnObjectSaleInfo = delegate { }; - public event ObjectBuy OnObjectBuy = delegate { }; - public event BuyObjectInventory OnBuyObjectInventory = delegate { }; - public event RequestTerrain OnRequestTerrain = delegate { }; - public event RequestTerrain OnUploadTerrain = delegate { }; - public event ObjectIncludeInSearch OnObjectIncludeInSearch = delegate { }; - public event UUIDNameRequest OnTeleportHomeRequest = delegate { }; - public event ScriptAnswer OnScriptAnswer = delegate { }; - public event AgentSit OnUndo = delegate { }; - public event AgentSit OnRedo = delegate { }; - public event LandUndo OnLandUndo = delegate { }; - public event ForceReleaseControls OnForceReleaseControls = delegate { }; - public event GodLandStatRequest OnLandStatRequest = delegate { }; - public event DetailedEstateDataRequest OnDetailedEstateDataRequest = delegate { }; - public event SetEstateFlagsRequest OnSetEstateFlagsRequest = delegate { }; - public event SetEstateTerrainBaseTexture OnSetEstateTerrainBaseTexture = delegate { }; - public event SetEstateTerrainDetailTexture OnSetEstateTerrainDetailTexture = delegate { }; - public event SetEstateTerrainTextureHeights OnSetEstateTerrainTextureHeights = delegate { }; - public event CommitEstateTerrainTextureRequest OnCommitEstateTerrainTextureRequest = delegate { }; - public event SetRegionTerrainSettings OnSetRegionTerrainSettings = delegate { }; - public event EstateRestartSimRequest OnEstateRestartSimRequest = delegate { }; - public event EstateChangeCovenantRequest OnEstateChangeCovenantRequest = delegate { }; - public event UpdateEstateAccessDeltaRequest OnUpdateEstateAccessDeltaRequest = delegate { }; - public event SimulatorBlueBoxMessageRequest OnSimulatorBlueBoxMessageRequest = delegate { }; - public event EstateBlueBoxMessageRequest OnEstateBlueBoxMessageRequest = delegate { }; - public event EstateDebugRegionRequest OnEstateDebugRegionRequest = delegate { }; - public event EstateTeleportOneUserHomeRequest OnEstateTeleportOneUserHomeRequest = delegate { }; - public event EstateTeleportAllUsersHomeRequest OnEstateTeleportAllUsersHomeRequest = delegate { }; - public event UUIDNameRequest OnUUIDGroupNameRequest = delegate { }; - public event RegionHandleRequest OnRegionHandleRequest = delegate { }; - public event ParcelInfoRequest OnParcelInfoRequest = delegate { }; - public event RequestObjectPropertiesFamily OnObjectGroupRequest = delegate { }; - public event ScriptReset OnScriptReset = delegate { }; - public event GetScriptRunning OnGetScriptRunning = delegate { }; - public event SetScriptRunning OnSetScriptRunning = delegate { }; - public event UpdateVector OnAutoPilotGo = delegate { }; - public event TerrainUnacked OnUnackedTerrain = delegate { }; - public event ActivateGesture OnActivateGesture = delegate { }; - public event DeactivateGesture OnDeactivateGesture = delegate { }; - public event ObjectOwner OnObjectOwner = delegate { }; - public event DirPlacesQuery OnDirPlacesQuery = delegate { }; - public event DirFindQuery OnDirFindQuery = delegate { }; - public event DirLandQuery OnDirLandQuery = delegate { }; - public event DirPopularQuery OnDirPopularQuery = delegate { }; - public event DirClassifiedQuery OnDirClassifiedQuery = delegate { }; - public event EventInfoRequest OnEventInfoRequest = delegate { }; - public event ParcelSetOtherCleanTime OnParcelSetOtherCleanTime = delegate { }; - public event MapItemRequest OnMapItemRequest = delegate { }; - public event OfferCallingCard OnOfferCallingCard = delegate { }; - public event AcceptCallingCard OnAcceptCallingCard = delegate { }; - public event DeclineCallingCard OnDeclineCallingCard = delegate { }; - public event SoundTrigger OnSoundTrigger = delegate { }; - public event StartLure OnStartLure = delegate { }; - public event TeleportLureRequest OnTeleportLureRequest = delegate { }; - public event NetworkStats OnNetworkStatsUpdate = delegate { }; - public event ClassifiedInfoRequest OnClassifiedInfoRequest = delegate { }; - public event ClassifiedInfoUpdate OnClassifiedInfoUpdate = delegate { }; - public event ClassifiedDelete OnClassifiedDelete = delegate { }; - public event ClassifiedDelete OnClassifiedGodDelete = delegate { }; - public event EventNotificationAddRequest OnEventNotificationAddRequest = delegate { }; - public event EventNotificationRemoveRequest OnEventNotificationRemoveRequest = delegate { }; - public event EventGodDelete OnEventGodDelete = delegate { }; - public event ParcelDwellRequest OnParcelDwellRequest = delegate { }; - public event UserInfoRequest OnUserInfoRequest = delegate { }; - public event UpdateUserInfo OnUpdateUserInfo = delegate { }; - public event RetrieveInstantMessages OnRetrieveInstantMessages = delegate { }; - public event PickDelete OnPickDelete = delegate { }; - public event PickGodDelete OnPickGodDelete = delegate { }; - public event PickInfoUpdate OnPickInfoUpdate = delegate { }; - public event AvatarNotesUpdate OnAvatarNotesUpdate = delegate { }; - public event MuteListRequest OnMuteListRequest = delegate { }; - public event AvatarInterestUpdate OnAvatarInterestUpdate = delegate { }; - public event PlacesQuery OnPlacesQuery = delegate { }; - public event FindAgentUpdate OnFindAgent = delegate { }; - public event TrackAgentUpdate OnTrackAgent = delegate { }; - public event NewUserReport OnUserReport = delegate { }; - public event SaveStateHandler OnSaveState = delegate { }; - public event GroupAccountSummaryRequest OnGroupAccountSummaryRequest = delegate { }; - public event GroupAccountDetailsRequest OnGroupAccountDetailsRequest = delegate { }; - public event GroupAccountTransactionsRequest OnGroupAccountTransactionsRequest = delegate { }; - public event FreezeUserUpdate OnParcelFreezeUser = delegate { }; - public event EjectUserUpdate OnParcelEjectUser = delegate { }; - public event ParcelBuyPass OnParcelBuyPass = delegate { }; - public event ParcelGodMark OnParcelGodMark = delegate { }; - public event GroupActiveProposalsRequest OnGroupActiveProposalsRequest = delegate { }; - public event GroupVoteHistoryRequest OnGroupVoteHistoryRequest = delegate { }; - public event SimWideDeletesDelegate OnSimWideDeletes = delegate { }; - public event SendPostcard OnSendPostcard = delegate { }; - public event MuteListEntryUpdate OnUpdateMuteListEntry = delegate { }; - public event MuteListEntryRemove OnRemoveMuteListEntry = delegate { }; - public event GodlikeMessage onGodlikeMessage = delegate { }; - public event GodUpdateRegionInfoUpdate OnGodUpdateRegionInfoUpdate = delegate { }; - - - - public void SetDebugPacketLevel(int newDebug) - { - throw new System.NotImplementedException(); - } - - public void InPacket(object NewPack) - { - throw new System.NotImplementedException(); - } - - public void ProcessInPacket(Packet NewPack) - { - throw new System.NotImplementedException(); - } - - public void Close() - { - throw new System.NotImplementedException(); - } - - public void Kick(string message) - { - throw new System.NotImplementedException(); - } - - public void Start() - { - throw new System.NotImplementedException(); - } - - public void Stop() - { - throw new System.NotImplementedException(); - } - - public void SendWearables(AvatarWearable[] wearables, int serial) - { - throw new System.NotImplementedException(); - } - - public void SendAppearance(UUID agentID, byte[] visualParams, byte[] textureEntry) - { - throw new System.NotImplementedException(); - } - - public void SendStartPingCheck(byte seq) - { - throw new System.NotImplementedException(); - } - - public void SendKillObject(ulong regionHandle, uint localID) - { - throw new System.NotImplementedException(); - } - - public void SendAnimations(UUID[] animID, int[] seqs, UUID sourceAgentId, UUID[] objectIDs) - { - throw new System.NotImplementedException(); - } - - public void SendRegionHandshake(RegionInfo regionInfo, RegionHandshakeArgs args) - { - throw new System.NotImplementedException(); - } - - public void SendChatMessage(string message, byte type, Vector3 fromPos, string fromName, UUID fromAgentID, byte source, byte audible) - { - throw new System.NotImplementedException(); - } - - public void SendInstantMessage(GridInstantMessage im) - { - throw new System.NotImplementedException(); - } - - public void SendGenericMessage(string method, List message) - { - } - - public void SendGenericMessage(string method, List message) - { - throw new System.NotImplementedException(); - } - - public void SendLayerData(float[] map) - { - throw new System.NotImplementedException(); - } - - public void SendLayerData(int px, int py, float[] map) - { - throw new System.NotImplementedException(); - } - - public void SendWindData(Vector2[] windSpeeds) - { - throw new System.NotImplementedException(); - } - - public void SendCloudData(float[] cloudCover) - { - throw new System.NotImplementedException(); - } - - public void MoveAgentIntoRegion(RegionInfo regInfo, Vector3 pos, Vector3 look) - { - throw new System.NotImplementedException(); - } - - public void InformClientOfNeighbour(ulong neighbourHandle, IPEndPoint neighbourExternalEndPoint) - { - throw new System.NotImplementedException(); - } - - public AgentCircuitData RequestClientInfo() - { - throw new System.NotImplementedException(); - } - - public void CrossRegion(ulong newRegionHandle, Vector3 pos, Vector3 lookAt, IPEndPoint newRegionExternalEndPoint, string capsURL) - { - throw new System.NotImplementedException(); - } - - public void SendMapBlock(List mapBlocks, uint flag) - { - throw new System.NotImplementedException(); - } - - public void SendLocalTeleport(Vector3 position, Vector3 lookAt, uint flags) - { - throw new System.NotImplementedException(); - } - - public void SendRegionTeleport(ulong regionHandle, byte simAccess, IPEndPoint regionExternalEndPoint, uint locationID, uint flags, string capsURL) - { - throw new System.NotImplementedException(); - } - - public void SendTeleportFailed(string reason) - { - throw new System.NotImplementedException(); - } - - public void SendTeleportStart(uint flags) - { - throw new System.NotImplementedException(); - } - - public void SendTeleportProgress(uint flags, string message) - { - throw new System.NotImplementedException(); - } - - public void SendMoneyBalance(UUID transaction, bool success, byte[] description, int balance) - { - throw new System.NotImplementedException(); - } - - public void SendPayPrice(UUID objectID, int[] payPrice) - { - throw new System.NotImplementedException(); - } - - public void SendCoarseLocationUpdate(List users, List CoarseLocations) - { - throw new System.NotImplementedException(); - } - - public void SetChildAgentThrottle(byte[] throttle) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarDataImmediate(ISceneEntity avatar) - { - throw new System.NotImplementedException(); - } - - public void SendPrimUpdate(ISceneEntity entity, PrimUpdateFlags updateFlags) - { - throw new System.NotImplementedException(); - } - - public void ReprioritizeUpdates() - { - throw new System.NotImplementedException(); - } - - public void FlushPrimUpdates() - { - throw new System.NotImplementedException(); - } - - public void SendInventoryFolderDetails(UUID ownerID, UUID folderID, List items, List folders, int version, bool fetchFolders, bool fetchItems) - { - throw new System.NotImplementedException(); - } - - public void SendInventoryItemDetails(UUID ownerID, InventoryItemBase item) - { - throw new System.NotImplementedException(); - } - - public void SendInventoryItemCreateUpdate(InventoryItemBase Item, uint callbackId) - { - throw new System.NotImplementedException(); - } - - public void SendRemoveInventoryItem(UUID itemID) - { - throw new System.NotImplementedException(); - } - - public void SendTakeControls(int controls, bool passToAgent, bool TakeControls) - { - throw new System.NotImplementedException(); - } - - public void SendTaskInventory(UUID taskID, short serial, byte[] fileName) - { - throw new System.NotImplementedException(); - } - - public void SendBulkUpdateInventory(InventoryNodeBase node) - { - throw new System.NotImplementedException(); - } - - public void SendXferPacket(ulong xferID, uint packet, byte[] data) - { - throw new System.NotImplementedException(); - } - - public virtual void SendAbortXferPacket(ulong xferID) - { - throw new System.NotImplementedException(); - } - - public void SendEconomyData(float EnergyEfficiency, int ObjectCapacity, int ObjectCount, int PriceEnergyUnit, int PriceGroupCreate, int PriceObjectClaim, float PriceObjectRent, float PriceObjectScaleFactor, int PriceParcelClaim, float PriceParcelClaimFactor, int PriceParcelRent, int PricePublicObjectDecay, int PricePublicObjectDelete, int PriceRentLight, int PriceUpload, int TeleportMinPrice, float TeleportPriceExponent) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarPickerReply(AvatarPickerReplyAgentDataArgs AgentData, List Data) - { - throw new System.NotImplementedException(); - } - - public void SendAgentDataUpdate(UUID agentid, UUID activegroupid, string firstname, string lastname, ulong grouppowers, string groupname, string grouptitle) - { - throw new System.NotImplementedException(); - } - - public void SendPreLoadSound(UUID objectID, UUID ownerID, UUID soundID) - { - throw new System.NotImplementedException(); - } - - public void SendPlayAttachedSound(UUID soundID, UUID objectID, UUID ownerID, float gain, byte flags) - { - throw new System.NotImplementedException(); - } - - public void SendTriggeredSound(UUID soundID, UUID ownerID, UUID objectID, UUID parentID, ulong handle, Vector3 position, float gain) - { - throw new System.NotImplementedException(); - } - - public void SendAttachedSoundGainChange(UUID objectID, float gain) - { - throw new System.NotImplementedException(); - } - - public void SendNameReply(UUID profileId, string firstname, string lastname) - { - throw new System.NotImplementedException(); - } - - public void SendAlertMessage(string message) - { - throw new System.NotImplementedException(); - } - - public void SendAgentAlertMessage(string message, bool modal) - { - throw new System.NotImplementedException(); - } - - public void SendLoadURL(string objectname, UUID objectID, UUID ownerID, bool groupOwned, string message, string url) - { - throw new System.NotImplementedException(); - } - - public void SendDialog(string objectname, UUID objectID, string ownerFirstName, string ownerLastName, string msg, UUID textureID, int ch, string[] buttonlabels) - { - throw new System.NotImplementedException(); - } - - public bool AddMoney(int debit) - { - throw new System.NotImplementedException(); - } - - public void SendSunPos(Vector3 sunPos, Vector3 sunVel, ulong CurrentTime, uint SecondsPerSunCycle, uint SecondsPerYear, float OrbitalPosition) - { - throw new System.NotImplementedException(); - } - - public void SendViewerEffect(ViewerEffectPacket.EffectBlock[] effectBlocks) - { - throw new System.NotImplementedException(); - } - - public void SendViewerTime(int phase) - { - throw new System.NotImplementedException(); - } - - public UUID GetDefaultAnimation(string name) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarProperties(UUID avatarID, string aboutText, string bornOn, byte[] charterMember, string flAbout, uint flags, UUID flImageID, UUID imageID, string profileURL, UUID partnerID) - { - throw new System.NotImplementedException(); - } - - public void SendScriptQuestion(UUID taskID, string taskName, string ownerName, UUID itemID, int question) - { - throw new System.NotImplementedException(); - } - - public void SendHealth(float health) - { - throw new System.NotImplementedException(); - } - - public void SendEstateList(UUID invoice, int code, UUID[] Data, uint estateID) - { - throw new System.NotImplementedException(); - } - - public void SendBannedUserList(UUID invoice, EstateBan[] banlist, uint estateID) - { - throw new System.NotImplementedException(); - } - - public void SendRegionInfoToEstateMenu(RegionInfoForEstateMenuArgs args) - { - throw new System.NotImplementedException(); - } - - public void SendEstateCovenantInformation(UUID covenant) - { - throw new System.NotImplementedException(); - } - - public void SendDetailedEstateData(UUID invoice, string estateName, uint estateID, uint parentEstate, uint estateFlags, uint sunPosition, UUID covenant, string abuseEmail, UUID estateOwner) - { - throw new System.NotImplementedException(); - } - - public void SendLandProperties(int sequence_id, bool snap_selection, int request_result, ILandObject lo, float simObjectBonusFactor, int parcelObjectCapacity, int simObjectCapacity, uint regionFlags) - { - throw new System.NotImplementedException(); - } - - public void SendLandAccessListData(List avatars, uint accessFlag, int localLandID) - { - throw new System.NotImplementedException(); - } - - public void SendForceClientSelectObjects(List objectIDs) - { - throw new System.NotImplementedException(); - } - - public void SendCameraConstraint(Vector4 ConstraintPlane) - { - - } - - public void SendLandObjectOwners(LandData land, List groups, Dictionary ownersAndCount) - { - throw new System.NotImplementedException(); - } - - public void SendLandParcelOverlay(byte[] data, int sequence_id) - { - throw new System.NotImplementedException(); - } - - public void SendParcelMediaCommand(uint flags, ParcelMediaCommandEnum command, float time) - { - throw new System.NotImplementedException(); - } - - public void SendParcelMediaUpdate(string mediaUrl, UUID mediaTextureID, byte autoScale, string mediaType, string mediaDesc, int mediaWidth, int mediaHeight, byte mediaLoop) - { - throw new System.NotImplementedException(); - } - - public void SendAssetUploadCompleteMessage(sbyte AssetType, bool Success, UUID AssetFullID) - { - throw new System.NotImplementedException(); - } - - public void SendConfirmXfer(ulong xferID, uint PacketID) - { - throw new System.NotImplementedException(); - } - - public void SendXferRequest(ulong XferID, short AssetType, UUID vFileID, byte FilePath, byte[] FileName) - { - throw new System.NotImplementedException(); - } - - public void SendInitiateDownload(string simFileName, string clientFileName) - { - throw new System.NotImplementedException(); - } - - public void SendImageFirstPart(ushort numParts, UUID ImageUUID, uint ImageSize, byte[] ImageData, byte imageCodec) - { - throw new System.NotImplementedException(); - } - - public void SendImageNextPart(ushort partNumber, UUID imageUuid, byte[] imageData) - { - throw new System.NotImplementedException(); - } - - public void SendImageNotFound(UUID imageid) - { - throw new System.NotImplementedException(); - } - - public void SendShutdownConnectionNotice() - { - throw new System.NotImplementedException(); - } - - public void SendSimStats(SimStats stats) - { - throw new System.NotImplementedException(); - } - - public void SendObjectPropertiesFamilyData(ISceneEntity Entity, uint RequestFlags) - { - throw new System.NotImplementedException(); - } - - public void SendObjectPropertiesReply(ISceneEntity entity) - { - throw new System.NotImplementedException(); - } - - public void SendAgentOffline(UUID[] agentIDs) - { - throw new System.NotImplementedException(); - } - - public void SendAgentOnline(UUID[] agentIDs) - { - throw new System.NotImplementedException(); - } - - public void SendSitResponse(UUID TargetID, Vector3 OffsetPos, Quaternion SitOrientation, bool autopilot, Vector3 CameraAtOffset, Vector3 CameraEyeOffset, bool ForceMouseLook) - { - throw new System.NotImplementedException(); - } - - public void SendAdminResponse(UUID Token, uint AdminLevel) - { - throw new System.NotImplementedException(); - } - - public void SendGroupMembership(GroupMembershipData[] GroupMembership) - { - throw new System.NotImplementedException(); - } - - public void SendGroupNameReply(UUID groupLLUID, string GroupName) - { - throw new System.NotImplementedException(); - } - - public void SendJoinGroupReply(UUID groupID, bool success) - { - throw new System.NotImplementedException(); - } - - public void SendEjectGroupMemberReply(UUID agentID, UUID groupID, bool success) - { - throw new System.NotImplementedException(); - } - - public void SendLeaveGroupReply(UUID groupID, bool success) - { - throw new System.NotImplementedException(); - } - - public void SendCreateGroupReply(UUID groupID, bool success, string message) - { - throw new System.NotImplementedException(); - } - - public void SendLandStatReply(uint reportType, uint requestFlags, uint resultCount, LandStatReportItem[] lsrpia) - { - throw new System.NotImplementedException(); - } - - public void SendScriptRunningReply(UUID objectID, UUID itemID, bool running) - { - throw new System.NotImplementedException(); - } - - public void SendAsset(AssetRequestToClient req) - { - throw new System.NotImplementedException(); - } - - public void SendTexture(AssetBase TextureAsset) - { - throw new System.NotImplementedException(); - } - - public byte[] GetThrottlesPacked(float multiplier) - { - throw new System.NotImplementedException(); - } - - public event ViewerEffectEventHandler OnViewerEffect; - public event Action OnLogout; - public event Action OnConnectionClosed; - public void SendBlueBoxMessage(UUID FromAvatarID, string FromAvatarName, string Message) - { - throw new System.NotImplementedException(); - } - - public void SendLogoutPacket() - { - throw new System.NotImplementedException(); - } - - public EndPoint GetClientEP() - { - return null; - } - - public ClientInfo GetClientInfo() - { - throw new System.NotImplementedException(); - } - - public void SetClientInfo(ClientInfo info) - { - throw new System.NotImplementedException(); - } - - public void SetClientOption(string option, string value) - { - throw new System.NotImplementedException(); - } - - public string GetClientOption(string option) - { - throw new System.NotImplementedException(); - } - - public void Terminate() - { - throw new System.NotImplementedException(); - } - - public void SendSetFollowCamProperties(UUID objectID, SortedDictionary parameters) - { - throw new System.NotImplementedException(); - } - - public void SendClearFollowCamProperties(UUID objectID) - { - throw new System.NotImplementedException(); - } - - public void SendRegionHandle(UUID regoinID, ulong handle) - { - throw new System.NotImplementedException(); - } - - public void SendParcelInfo(RegionInfo info, LandData land, UUID parcelID, uint x, uint y) - { - throw new System.NotImplementedException(); - } - - public void SendScriptTeleportRequest(string objName, string simName, Vector3 pos, Vector3 lookAt) - { - throw new System.NotImplementedException(); - } - - public void SendDirPlacesReply(UUID queryID, DirPlacesReplyData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendDirPeopleReply(UUID queryID, DirPeopleReplyData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendDirEventsReply(UUID queryID, DirEventsReplyData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendDirGroupsReply(UUID queryID, DirGroupsReplyData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendDirClassifiedReply(UUID queryID, DirClassifiedReplyData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendDirLandReply(UUID queryID, DirLandReplyData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendDirPopularReply(UUID queryID, DirPopularReplyData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendEventInfoReply(EventData info) - { - throw new System.NotImplementedException(); - } - - public void SendMapItemReply(mapItemReply[] replies, uint mapitemtype, uint flags) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarGroupsReply(UUID avatarID, GroupMembershipData[] data) - { - throw new System.NotImplementedException(); - } - - public void SendOfferCallingCard(UUID srcID, UUID transactionID) - { - throw new System.NotImplementedException(); - } - - public void SendAcceptCallingCard(UUID transactionID) - { - throw new System.NotImplementedException(); - } - - public void SendDeclineCallingCard(UUID transactionID) - { - throw new System.NotImplementedException(); - } - - public void SendTerminateFriend(UUID exFriendID) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarClassifiedReply(UUID targetID, UUID[] classifiedID, string[] name) - { - throw new System.NotImplementedException(); - } - - 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) - { - throw new System.NotImplementedException(); - } - - public void SendAgentDropGroup(UUID groupID) - { - throw new System.NotImplementedException(); - } - - public void RefreshGroupMembership() - { - throw new System.NotImplementedException(); - } - - public void SendAvatarNotesReply(UUID targetID, string text) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarPicksReply(UUID targetID, Dictionary picks) - { - throw new System.NotImplementedException(); - } - - 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) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarClassifiedReply(UUID targetID, Dictionary classifieds) - { - throw new System.NotImplementedException(); - } - - public void SendAvatarInterestUpdate(IClientAPI client, uint wantmask, string wanttext, uint skillsmask, string skillstext, string languages) - { - throw new System.NotImplementedException(); - } - - public void SendParcelDwellReply(int localID, UUID parcelID, float dwell) - { - throw new System.NotImplementedException(); - } - - public void SendUserInfoReply(bool imViaEmail, bool visible, string email) - { - throw new System.NotImplementedException(); - } - - public void SendUseCachedMuteList() - { - throw new System.NotImplementedException(); - } - - public void SendMuteListUpdate(string filename) - { - throw new System.NotImplementedException(); - } - - public void KillEndDone() - { - throw new System.NotImplementedException(); - } - - public bool AddGenericPacketHandler(string MethodName, GenericMessage handler) - { - throw new System.NotImplementedException(); - } - - #endregion - - public void SendRebakeAvatarTextures(UUID textureID) - { - } - - public void SendAvatarInterestsReply(UUID avatarID, uint wantMask, string wantText, uint skillsMask, string skillsText, string languages) - { - } - - public void SendGroupAccountingDetails(IClientAPI sender,UUID groupID, UUID transactionID, UUID sessionID, int amt) - { - } - - public void SendGroupAccountingSummary(IClientAPI sender,UUID groupID, uint moneyAmt, int totalTier, int usedTier) - { - } - - public void SendGroupTransactionsSummaryDetails(IClientAPI sender,UUID groupID, UUID transactionID, UUID sessionID,int amt) - { - } - - public void SendGroupVoteHistory(UUID groupID, UUID transactionID, GroupVoteHistory[] Votes) - { - } - - public void SendGroupActiveProposals(UUID groupID, UUID transactionID, GroupActiveProposals[] Proposals) - { - } - - public void SendChangeUserRights(UUID agentID, UUID friendID, int rights) - { - } - - public void SendTextBoxRequest(string message, int chatChannel, string objectname, string ownerFirstName, string ownerLastName, UUID objectId) - { - } - - public void StopFlying(ISceneEntity presence) - { - } - - public void SendPlacesReply(UUID queryID, UUID transactionID, PlacesReplyData[] data) - { - } - } -} diff --git a/OpenSim/Client/VWoHTTP/VWoHTTPModule.cs b/OpenSim/Client/VWoHTTP/VWoHTTPModule.cs deleted file mode 100644 index 31385ba0b2..0000000000 --- a/OpenSim/Client/VWoHTTP/VWoHTTPModule.cs +++ /dev/null @@ -1,133 +0,0 @@ -/* - * Copyright (c) Contributors, http://opensimulator.org/ - * See CONTRIBUTORS.TXT for a full list of copyright holders. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * * Neither the name of the OpenSimulator Project nor the - * names of its contributors may be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY - * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY - * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -using System; -using System.Collections.Generic; -using System.Text; -using Nini.Config; -using OpenMetaverse; -using OpenSim.Client.VWoHTTP.ClientStack; -using OpenSim.Framework; -using OpenSim.Framework.Servers; -using OpenSim.Framework.Servers.HttpServer; -using OpenSim.Region.Framework.Interfaces; -using OpenSim.Region.Framework.Scenes; - -namespace OpenSim.Client.VWoHTTP -{ - class VWoHTTPModule : IRegionModule, IHttpAgentHandler - { - private bool m_disabled = true; - - private IHttpServer m_httpd; - - private readonly List m_scenes = new List(); - - private Dictionary m_clients = new Dictionary(); - - #region Implementation of IRegionModule - - public void Initialise(Scene scene, IConfigSource source) - { - if (m_disabled) - return; - - m_scenes.Add(scene); - - m_httpd = MainServer.Instance; - } - - public void PostInitialise() - { - if (m_disabled) - return; - - m_httpd.AddAgentHandler("vwohttp", this); - } - - public void Close() - { - if (m_disabled) - return; - - m_httpd.RemoveAgentHandler("vwohttp", this); - } - - public string Name - { - get { return "VWoHTTP ClientStack"; } - } - - public bool IsSharedModule - { - get { return true; } - } - - #endregion - - #region Implementation of IHttpAgentHandler - - public bool Handle(OSHttpRequest req, OSHttpResponse resp) - { - string[] urlparts = req.Url.AbsolutePath.Split(new char[] {'/'}, StringSplitOptions.RemoveEmptyEntries); - - if (urlparts.Length < 2) - return false; - - if (urlparts[1] == "connect") - { - UUID sessID = UUID.Random(); - - VWHClientView client = new VWHClientView(sessID, UUID.Random(), "VWoHTTPClient", m_scenes[0]); - - m_clients.Add(sessID, client); - - return true; - } - else - { - if (urlparts.Length < 3) - return false; - - UUID sessionID; - if (!UUID.TryParse(urlparts[1], out sessionID)) - return false; - - if (!m_clients.ContainsKey(sessionID)) - return false; - - return m_clients[sessionID].ProcessInMsg(req, resp); - } - } - - public bool Match(OSHttpRequest req, OSHttpResponse resp) - { - return req.Url.ToString().Contains("vwohttp"); - } - - #endregion - } -} diff --git a/OpenSim/Framework/Servers/VersionInfo.cs b/OpenSim/Framework/Servers/VersionInfo.cs index c9d4c93d49..53a3f17b86 100644 --- a/OpenSim/Framework/Servers/VersionInfo.cs +++ b/OpenSim/Framework/Servers/VersionInfo.cs @@ -29,7 +29,7 @@ namespace OpenSim { public class VersionInfo { - private const string VERSION_NUMBER = "0.7.1"; + private const string VERSION_NUMBER = "0.7.2"; private const Flavour VERSION_FLAVOUR = Flavour.Dev; public enum Flavour diff --git a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs index 1f7e66dabb..0f7f666c60 100644 --- a/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs +++ b/OpenSim/Region/ClientStack/LindenUDP/LLClientView.cs @@ -4764,7 +4764,15 @@ namespace OpenSim.Region.ClientStack.LindenUDP data.RelativePosition.ToBytes(objectData, 0); data.Velocity.ToBytes(objectData, 12); data.Acceleration.ToBytes(objectData, 24); - data.RotationOffset.ToBytes(objectData, 36); + try + { + data.RotationOffset.ToBytes(objectData, 36); + } + catch (Exception e) + { + m_log.Warn("[LLClientView]: exception converting quaternion to bytes, using Quaternion.Identity. Exception: " + e.ToString()); + OpenMetaverse.Quaternion.Identity.ToBytes(objectData, 36); + } data.AngularVelocity.ToBytes(objectData, 48); ObjectUpdatePacket.ObjectDataBlock update = new ObjectUpdatePacket.ObjectDataBlock(); diff --git a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/LocalInventoryServiceConnector.cs b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/LocalInventoryServiceConnector.cs index c7244c88ef..6dd871faa3 100644 --- a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/LocalInventoryServiceConnector.cs +++ b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/LocalInventoryServiceConnector.cs @@ -182,9 +182,12 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Inventory public InventoryCollection GetFolderContent(UUID userID, UUID folderID) { InventoryCollection invCol = m_InventoryService.GetFolderContent(userID, folderID); - if (UserManager != null) - foreach (InventoryItemBase item in invCol.Items) - UserManager.AddUser(item.CreatorIdAsUuid, item.CreatorData); + Util.FireAndForget(delegate + { + if (UserManager != null) + foreach (InventoryItemBase item in invCol.Items) + UserManager.AddUser(item.CreatorIdAsUuid, item.CreatorData); + }); return invCol; } diff --git a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/RemoteXInventoryServiceConnector.cs b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/RemoteXInventoryServiceConnector.cs index bd01bb944f..8f1f25774a 100644 --- a/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/RemoteXInventoryServiceConnector.cs +++ b/OpenSim/Region/CoreModules/ServiceConnectorsOut/Inventory/RemoteXInventoryServiceConnector.cs @@ -46,10 +46,22 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Inventory LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); private bool m_Enabled = false; - private bool m_Initialized = false; -// private Scene m_Scene; + private Scene m_Scene; private XInventoryServicesConnector m_RemoteConnector; + private IUserManagement m_UserManager; + private IUserManagement UserManager + { + get + { + if (m_UserManager == null) + { + m_UserManager = m_Scene.RequestModuleInterface(); + } + return m_UserManager; + } + } + public Type ReplaceableInterface { get { return null; } @@ -114,12 +126,10 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Inventory if (!m_Enabled) return; - if (!m_Initialized) - { - m_Initialized = true; - } - scene.RegisterModuleInterface(this); + + if (m_Scene == null) + m_Scene = scene; } public void RemoveRegion(Scene scene) @@ -173,7 +183,15 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.Inventory public InventoryCollection GetFolderContent(UUID userID, UUID folderID) { - return m_RemoteConnector.GetFolderContent(userID, folderID); + InventoryCollection invCol = m_RemoteConnector.GetFolderContent(userID, folderID); + Util.FireAndForget(delegate + { + if (UserManager != null) + foreach (InventoryItemBase item in invCol.Items) + UserManager.AddUser(item.CreatorIdAsUuid, item.CreatorData); + }); + + return invCol; } public List GetFolderItems(UUID userID, UUID folderID) diff --git a/OpenSim/Services/Connectors/Inventory/XInventoryConnector.cs b/OpenSim/Services/Connectors/Inventory/XInventoryConnector.cs index cd9f2bfcff..a662abb867 100644 --- a/OpenSim/Services/Connectors/Inventory/XInventoryConnector.cs +++ b/OpenSim/Services/Connectors/Inventory/XInventoryConnector.cs @@ -158,7 +158,10 @@ namespace OpenSim.Services.Connectors public InventoryCollection GetFolderContent(UUID principalID, UUID folderID) { InventoryCollection inventory = new InventoryCollection(); - + inventory.Folders = new List(); + inventory.Items = new List(); + inventory.UserID = principalID; + try { Dictionary ret = MakeRequest("GETFOLDERCONTENT", @@ -172,11 +175,6 @@ namespace OpenSim.Services.Connectors if (ret.Count == 0) return null; - - inventory.Folders = new List(); - inventory.Items = new List(); - inventory.UserID = principalID; - Dictionary folders = (Dictionary)ret["FOLDERS"]; Dictionary items = diff --git a/OpenSim/Services/InventoryService/XInventoryService.cs b/OpenSim/Services/InventoryService/XInventoryService.cs index e602412be1..0af35c84ac 100644 --- a/OpenSim/Services/InventoryService/XInventoryService.cs +++ b/OpenSim/Services/InventoryService/XInventoryService.cs @@ -244,7 +244,7 @@ namespace OpenSim.Services.InventoryService // connector. So we disregard the principal and look // by ID. // - m_log.DebugFormat("[XINVENTORY SERVICE]: Fetch contents for folder {0}", folderID.ToString()); + //m_log.DebugFormat("[XINVENTORY SERVICE]: Fetch contents for folder {0}", folderID.ToString()); InventoryCollection inventory = new InventoryCollection(); inventory.UserID = principalID; inventory.Folders = new List(); diff --git a/bin/Castle.Core.dll b/bin/Castle.Core.dll deleted file mode 100644 index 2464e66160..0000000000 Binary files a/bin/Castle.Core.dll and /dev/null differ diff --git a/bin/Castle.DynamicProxy.dll b/bin/Castle.DynamicProxy.dll deleted file mode 100644 index 8540495107..0000000000 Binary files a/bin/Castle.DynamicProxy.dll and /dev/null differ diff --git a/bin/Castle.DynamicProxy2.dll b/bin/Castle.DynamicProxy2.dll deleted file mode 100644 index 83e192e901..0000000000 Binary files a/bin/Castle.DynamicProxy2.dll and /dev/null differ diff --git a/bin/DotSets.dll b/bin/DotSets.dll deleted file mode 100644 index 5225651409..0000000000 Binary files a/bin/DotSets.dll and /dev/null differ diff --git a/bin/MXP.dll b/bin/MXP.dll deleted file mode 100644 index 99e90c879c..0000000000 Binary files a/bin/MXP.dll and /dev/null differ diff --git a/bin/Mono.PEToolkit.dll b/bin/Mono.PEToolkit.dll deleted file mode 100644 index b4c3e70e67..0000000000 Binary files a/bin/Mono.PEToolkit.dll and /dev/null differ diff --git a/bin/RAIL.dll b/bin/RAIL.dll deleted file mode 100644 index f2632d71b6..0000000000 Binary files a/bin/RAIL.dll and /dev/null differ diff --git a/bin/protobuf-net.dll b/bin/protobuf-net.dll deleted file mode 100644 index 057a411094..0000000000 Binary files a/bin/protobuf-net.dll and /dev/null differ diff --git a/prebuild.xml b/prebuild.xml index 49063daa57..1102c11c09 100644 --- a/prebuild.xml +++ b/prebuild.xml @@ -1959,69 +1959,6 @@ - - - - - - ../../../bin/ - - - - - ../../../bin/ - - - - ../../../bin/ - - - - - - - - - - - - - - - - - - - - - - ../../../bin/ - - - - - ../../../bin/ - - - - ../../../bin/ - - - - - - - - - - - - - - - - - @@ -2163,7 +2100,6 @@ - @@ -2201,8 +2137,6 @@ - - @@ -2235,8 +2169,6 @@ - - @@ -2274,8 +2206,6 @@ - - @@ -2304,7 +2234,6 @@ - @@ -2346,7 +2275,6 @@ - @@ -2385,7 +2313,6 @@ -