diff options
author | MW | 2007-05-19 18:32:01 +0000 |
---|---|---|
committer | MW | 2007-05-19 18:32:01 +0000 |
commit | 274ce6987e0b017800ddb62fe65143e0d5e1cae5 (patch) | |
tree | 4842cdbb9e209451136b1ab9149da5d5dd84db70 | |
parent | (no commit message) (diff) | |
download | opensim-SC-274ce6987e0b017800ddb62fe65143e0d5e1cae5.zip opensim-SC-274ce6987e0b017800ddb62fe65143e0d5e1cae5.tar.gz opensim-SC-274ce6987e0b017800ddb62fe65143e0d5e1cae5.tar.bz2 opensim-SC-274ce6987e0b017800ddb62fe65143e0d5e1cae5.tar.xz |
Border crossing back to mostly working, still seems a problem in that you need to stop walking just after you cross the border for it to work properly (else you will continue moving into a negative position in the first sim)
-rw-r--r-- | OpenSim.RegionServer/AuthenticateSessionsBase.cs | 23 | ||||
-rw-r--r-- | OpenSim.RegionServer/AuthenticateSessionsRemote.cs | 2 | ||||
-rw-r--r-- | OpenSim.RegionServer/SimClient.cs | 8 | ||||
-rw-r--r-- | OpenSim.RegionServer/world/World.cs | 2 | ||||
-rw-r--r-- | OpenSim.Servers/CheckSumServer.cs | 34 | ||||
-rw-r--r-- | OpenSim.Servers/UDPServerBase.cs | 9 | ||||
-rw-r--r-- | OpenSim/OpenSimMain.cs | 2 |
7 files changed, 47 insertions, 33 deletions
diff --git a/OpenSim.RegionServer/AuthenticateSessionsBase.cs b/OpenSim.RegionServer/AuthenticateSessionsBase.cs index f784f54..91bc54d 100644 --- a/OpenSim.RegionServer/AuthenticateSessionsBase.cs +++ b/OpenSim.RegionServer/AuthenticateSessionsBase.cs | |||
@@ -81,8 +81,29 @@ namespace OpenSim | |||
81 | this.AgentCircuits[(uint)agentData.circuitcode].firstname = agentData.firstname; | 81 | this.AgentCircuits[(uint)agentData.circuitcode].firstname = agentData.firstname; |
82 | this.AgentCircuits[(uint)agentData.circuitcode].lastname = agentData.lastname; | 82 | this.AgentCircuits[(uint)agentData.circuitcode].lastname = agentData.lastname; |
83 | this.AgentCircuits[(uint)agentData.circuitcode].startpos = agentData.startpos; | 83 | this.AgentCircuits[(uint)agentData.circuitcode].startpos = agentData.startpos; |
84 | // Console.WriteLine("update user start pos is " + agentData.startpos.X + " , " + agentData.startpos.Y + " , " + agentData.startpos.Z); | ||
85 | |||
86 | } | ||
87 | |||
88 | } | ||
89 | |||
90 | public void UpdateAgentChildStatus(uint circuitcode, bool childstatus) | ||
91 | { | ||
92 | if (this.AgentCircuits.ContainsKey(circuitcode)) | ||
93 | { | ||
94 | this.AgentCircuits[circuitcode].child = childstatus; | ||
95 | |||
96 | } | ||
97 | } | ||
98 | |||
99 | public bool GetAgentChildStatus(uint circuitcode) | ||
100 | { | ||
101 | if (this.AgentCircuits.ContainsKey(circuitcode)) | ||
102 | { | ||
103 | return this.AgentCircuits[circuitcode].child; | ||
104 | |||
84 | } | 105 | } |
85 | 106 | return false; | |
86 | } | 107 | } |
87 | } | 108 | } |
88 | } | 109 | } |
diff --git a/OpenSim.RegionServer/AuthenticateSessionsRemote.cs b/OpenSim.RegionServer/AuthenticateSessionsRemote.cs index 57c98e4..0802d75 100644 --- a/OpenSim.RegionServer/AuthenticateSessionsRemote.cs +++ b/OpenSim.RegionServer/AuthenticateSessionsRemote.cs | |||
@@ -34,6 +34,8 @@ namespace OpenSim | |||
34 | { | 34 | { |
35 | agentData.startpos = new LLVector3(Convert.ToUInt32(requestData["startpos_x"]), Convert.ToUInt32(requestData["startpos_y"]), Convert.ToUInt32(requestData["startpos_z"])); | 35 | agentData.startpos = new LLVector3(Convert.ToUInt32(requestData["startpos_x"]), Convert.ToUInt32(requestData["startpos_y"]), Convert.ToUInt32(requestData["startpos_z"])); |
36 | agentData.child = false; | 36 | agentData.child = false; |
37 | // Console.WriteLine("expect user start pos is " + agentData.startpos.X + " , " + agentData.startpos.Y + " , " + agentData.startpos.Z); | ||
38 | |||
37 | } | 39 | } |
38 | 40 | ||
39 | this.AddNewCircuit(agentData.circuitcode, agentData); | 41 | this.AddNewCircuit(agentData.circuitcode, agentData); |
diff --git a/OpenSim.RegionServer/SimClient.cs b/OpenSim.RegionServer/SimClient.cs index daaa6dd..9ae08f4 100644 --- a/OpenSim.RegionServer/SimClient.cs +++ b/OpenSim.RegionServer/SimClient.cs | |||
@@ -118,7 +118,9 @@ namespace OpenSim | |||
118 | 118 | ||
119 | if (m_gridServer.GetName() == "Remote") | 119 | if (m_gridServer.GetName() == "Remote") |
120 | { | 120 | { |
121 | this.m_child = m_authenticateSessionsHandler.GetAgentChildStatus(initialcirpack.CircuitCode.Code); | ||
121 | this.startpos = m_authenticateSessionsHandler.GetPosition(initialcirpack.CircuitCode.Code); | 122 | this.startpos = m_authenticateSessionsHandler.GetPosition(initialcirpack.CircuitCode.Code); |
123 | //Console.WriteLine("start pos is " + this.startpos.X + " , " + this.startpos.Y + " , " + this.startpos.Z); | ||
122 | } | 124 | } |
123 | else | 125 | else |
124 | { | 126 | { |
@@ -142,13 +144,15 @@ namespace OpenSim | |||
142 | # region Client Methods | 144 | # region Client Methods |
143 | public void UpgradeClient() | 145 | public void UpgradeClient() |
144 | { | 146 | { |
147 | Console.WriteLine("updateclient being called"); | ||
145 | OpenSim.Framework.Console.MainConsole.Instance.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "SimClient.cs:UpgradeClient() - upgrading child to full agent"); | 148 | OpenSim.Framework.Console.MainConsole.Instance.WriteLine(OpenSim.Framework.Console.LogPriority.LOW, "SimClient.cs:UpgradeClient() - upgrading child to full agent"); |
146 | this.m_child = false; | 149 | this.m_child = false; |
147 | this.m_world.RemoveViewerAgent(this); | 150 | this.m_world.RemoveViewerAgent(this); |
148 | if (!this.m_sandboxMode) | 151 | if (!this.m_sandboxMode) |
149 | { | 152 | { |
150 | this.startpos = ((RemoteGridBase)m_gridServer).agentcircuits[CircuitCode].startpos; | 153 | this.startpos = m_authenticateSessionsHandler.GetPosition(CircuitCode); |
151 | ((RemoteGridBase)m_gridServer).agentcircuits[CircuitCode].child = false; | 154 | m_authenticateSessionsHandler.UpdateAgentChildStatus(CircuitCode, false); |
155 | //Console.WriteLine("upgrade start pos is " + this.startpos.X + " , " + this.startpos.Y + " , " + this.startpos.Z); | ||
152 | } | 156 | } |
153 | this.InitNewClient(); | 157 | this.InitNewClient(); |
154 | } | 158 | } |
diff --git a/OpenSim.RegionServer/world/World.cs b/OpenSim.RegionServer/world/World.cs index 72214d4..ecf9c69 100644 --- a/OpenSim.RegionServer/world/World.cs +++ b/OpenSim.RegionServer/world/World.cs | |||
@@ -585,7 +585,7 @@ namespace OpenSim.world | |||
585 | } | 585 | } |
586 | if (agentClient.ClientAvatar.PhysActor != null) | 586 | if (agentClient.ClientAvatar.PhysActor != null) |
587 | { | 587 | { |
588 | this.phyScene.RemoveAvatar(agentClient.ClientAvatar.PhysActor); | 588 | //this.phyScene.RemoveAvatar(agentClient.ClientAvatar.PhysActor); |
589 | } | 589 | } |
590 | } | 590 | } |
591 | catch (Exception e) | 591 | catch (Exception e) |
diff --git a/OpenSim.Servers/CheckSumServer.cs b/OpenSim.Servers/CheckSumServer.cs index f0b4124..ae1724f 100644 --- a/OpenSim.Servers/CheckSumServer.cs +++ b/OpenSim.Servers/CheckSumServer.cs | |||
@@ -17,12 +17,11 @@ namespace OpenSim.Servers | |||
17 | { | 17 | { |
18 | public class CheckSumServer : UDPServerBase | 18 | public class CheckSumServer : UDPServerBase |
19 | { | 19 | { |
20 | protected ConsoleBase m_console; | 20 | //protected ConsoleBase m_console; |
21 | 21 | ||
22 | public CheckSumServer(int port, ConsoleBase console) | 22 | public CheckSumServer(int port) |
23 | : base(port) | ||
23 | { | 24 | { |
24 | listenPort = port; | ||
25 | this.m_console = console; | ||
26 | } | 25 | } |
27 | 26 | ||
28 | protected override void OnReceivedData(IAsyncResult result) | 27 | protected override void OnReceivedData(IAsyncResult result) |
@@ -35,10 +34,8 @@ namespace OpenSim.Servers | |||
35 | 34 | ||
36 | packet = Packet.BuildPacket(RecvBuffer, ref packetEnd, ZeroBuffer); | 35 | packet = Packet.BuildPacket(RecvBuffer, ref packetEnd, ZeroBuffer); |
37 | 36 | ||
38 | // do we already have a circuit for this endpoint | ||
39 | if (packet.Type == PacketType.SecuredTemplateChecksumRequest) | 37 | if (packet.Type == PacketType.SecuredTemplateChecksumRequest) |
40 | { | 38 | { |
41 | |||
42 | SecuredTemplateChecksumRequestPacket checksum = (SecuredTemplateChecksumRequestPacket)packet; | 39 | SecuredTemplateChecksumRequestPacket checksum = (SecuredTemplateChecksumRequestPacket)packet; |
43 | TemplateChecksumReplyPacket checkreply = new TemplateChecksumReplyPacket(); | 40 | TemplateChecksumReplyPacket checkreply = new TemplateChecksumReplyPacket(); |
44 | checkreply.DataBlock.Checksum = 180572585; | 41 | checkreply.DataBlock.Checksum = 180572585; |
@@ -55,23 +52,21 @@ namespace OpenSim.Servers | |||
55 | SecuredTemplateChecksumRequestPacket checkrequest = new SecuredTemplateChecksumRequestPacket(); | 52 | SecuredTemplateChecksumRequestPacket checkrequest = new SecuredTemplateChecksumRequestPacket(); |
56 | checkrequest.TokenBlock.Token = checksum.TokenBlock.Token; | 53 | checkrequest.TokenBlock.Token = checksum.TokenBlock.Token; |
57 | this.SendPacket(checkrequest, epSender); | 54 | this.SendPacket(checkrequest, epSender); |
58 | */ | 55 | */ |
59 | |||
60 | } | 56 | } |
61 | else if (packet.Type == PacketType.TemplateChecksumReply) | 57 | else if (packet.Type == PacketType.TemplateChecksumReply) |
62 | { | 58 | { |
63 | //echo back the client checksum reply (Hegemon's method) | 59 | //echo back the client checksum reply (Hegemon's method) |
64 | TemplateChecksumReplyPacket checksum = (TemplateChecksumReplyPacket)packet; | 60 | TemplateChecksumReplyPacket checksum2 = (TemplateChecksumReplyPacket)packet; |
65 | TemplateChecksumReplyPacket checkreply2 = new TemplateChecksumReplyPacket(); | 61 | TemplateChecksumReplyPacket checkreply2 = new TemplateChecksumReplyPacket(); |
66 | checkreply2.DataBlock.Checksum = checksum.DataBlock.Checksum; | 62 | checkreply2.DataBlock.Checksum = checksum2.DataBlock.Checksum; |
67 | checkreply2.DataBlock.Flags = checksum.DataBlock.Flags; | 63 | checkreply2.DataBlock.Flags = checksum2.DataBlock.Flags; |
68 | checkreply2.DataBlock.MajorVersion = checksum.DataBlock.MajorVersion; | 64 | checkreply2.DataBlock.MajorVersion = checksum2.DataBlock.MajorVersion; |
69 | checkreply2.DataBlock.MinorVersion = checksum.DataBlock.MinorVersion; | 65 | checkreply2.DataBlock.MinorVersion = checksum2.DataBlock.MinorVersion; |
70 | checkreply2.DataBlock.PatchVersion = checksum.DataBlock.PatchVersion; | 66 | checkreply2.DataBlock.PatchVersion = checksum2.DataBlock.PatchVersion; |
71 | checkreply2.DataBlock.ServerVersion = checksum.DataBlock.ServerVersion; | 67 | checkreply2.DataBlock.ServerVersion = checksum2.DataBlock.ServerVersion; |
72 | checkreply2.TokenBlock.Token = checksum.TokenBlock.Token; | 68 | checkreply2.TokenBlock.Token = checksum2.TokenBlock.Token; |
73 | this.SendPacket(checkreply2, epSender); | 69 | this.SendPacket(checkreply2, epSender); |
74 | |||
75 | } | 70 | } |
76 | else | 71 | else |
77 | { | 72 | { |
@@ -80,16 +75,13 @@ namespace OpenSim.Servers | |||
80 | Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); | 75 | Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); |
81 | } | 76 | } |
82 | 77 | ||
83 | |||
84 | private void SendPacket(Packet Pack, EndPoint endp) | 78 | private void SendPacket(Packet Pack, EndPoint endp) |
85 | { | 79 | { |
86 | if (!Pack.Header.Resent) | 80 | if (!Pack.Header.Resent) |
87 | { | 81 | { |
88 | // Set the sequence number | ||
89 | |||
90 | Pack.Header.Sequence = 1; | 82 | Pack.Header.Sequence = 1; |
91 | |||
92 | } | 83 | } |
84 | |||
93 | byte[] ZeroOutBuffer = new byte[4096]; | 85 | byte[] ZeroOutBuffer = new byte[4096]; |
94 | byte[] sendbuffer; | 86 | byte[] sendbuffer; |
95 | sendbuffer = Pack.ToBytes(); | 87 | sendbuffer = Pack.ToBytes(); |
diff --git a/OpenSim.Servers/UDPServerBase.cs b/OpenSim.Servers/UDPServerBase.cs index e7feb01..a308052 100644 --- a/OpenSim.Servers/UDPServerBase.cs +++ b/OpenSim.Servers/UDPServerBase.cs | |||
@@ -24,8 +24,9 @@ namespace OpenSim.Servers | |||
24 | protected AsyncCallback ReceivedData; | 24 | protected AsyncCallback ReceivedData; |
25 | protected int listenPort; | 25 | protected int listenPort; |
26 | 26 | ||
27 | public UDPServerBase() | 27 | public UDPServerBase(int port) |
28 | { | 28 | { |
29 | listenPort = port; | ||
29 | } | 30 | } |
30 | 31 | ||
31 | protected virtual void OnReceivedData(IAsyncResult result) | 32 | protected virtual void OnReceivedData(IAsyncResult result) |
@@ -38,8 +39,6 @@ namespace OpenSim.Servers | |||
38 | 39 | ||
39 | packet = Packet.BuildPacket(RecvBuffer, ref packetEnd, ZeroBuffer); | 40 | packet = Packet.BuildPacket(RecvBuffer, ref packetEnd, ZeroBuffer); |
40 | 41 | ||
41 | |||
42 | |||
43 | Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); | 42 | Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); |
44 | } | 43 | } |
45 | 44 | ||
@@ -60,14 +59,10 @@ namespace OpenSim.Servers | |||
60 | Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); | 59 | Server.BeginReceiveFrom(RecvBuffer, 0, RecvBuffer.Length, SocketFlags.None, ref epSender, ReceivedData, null); |
61 | } | 60 | } |
62 | 61 | ||
63 | |||
64 | public virtual void SendPacketTo(byte[] buffer, int size, SocketFlags flags, uint circuitcode) | 62 | public virtual void SendPacketTo(byte[] buffer, int size, SocketFlags flags, uint circuitcode) |
65 | { | 63 | { |
66 | // find the endpoint for this circuit | ||
67 | 64 | ||
68 | } | 65 | } |
69 | |||
70 | |||
71 | } | 66 | } |
72 | } | 67 | } |
73 | 68 | ||
diff --git a/OpenSim/OpenSimMain.cs b/OpenSim/OpenSimMain.cs index 30fed30..9025316 100644 --- a/OpenSim/OpenSimMain.cs +++ b/OpenSim/OpenSimMain.cs | |||
@@ -100,7 +100,7 @@ namespace OpenSim | |||
100 | //Authenticate Session Handler | 100 | //Authenticate Session Handler |
101 | AuthenticateSessionsLocal authen = new AuthenticateSessionsLocal(); | 101 | AuthenticateSessionsLocal authen = new AuthenticateSessionsLocal(); |
102 | this.AuthenticateSessionsHandler = authen; | 102 | this.AuthenticateSessionsHandler = authen; |
103 | this.checkServer = new CheckSumServer(12036, m_console); | 103 | this.checkServer = new CheckSumServer(12036); |
104 | this.checkServer.ServerListener(); | 104 | this.checkServer.ServerListener(); |
105 | } | 105 | } |
106 | else | 106 | else |