aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Environment/Modules/InterGrid
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Environment/Modules/InterGrid')
-rw-r--r--OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs1762
1 files changed, 881 insertions, 881 deletions
diff --git a/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs b/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs
index ffde9f2..746828a 100644
--- a/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs
+++ b/OpenSim/Region/Environment/Modules/InterGrid/OpenGridProtocolModule.cs
@@ -1,881 +1,881 @@
1/* 1/*
2 * Copyright (c) Contributors, http://opensimulator.org/ 2 * Copyright (c) Contributors, http://opensimulator.org/
3 * See CONTRIBUTORS.TXT for a full list of copyright holders. 3 * See CONTRIBUTORS.TXT for a full list of copyright holders.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met: 6 * modification, are permitted provided that the following conditions are met:
7 * * Redistributions of source code must retain the above copyright 7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright 9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution. 11 * documentation and/or other materials provided with the distribution.
12 * * Neither the name of the OpenSim Project nor the 12 * * Neither the name of the OpenSim Project nor the
13 * names of its contributors may be used to endorse or promote products 13 * names of its contributors may be used to endorse or promote products
14 * derived from this software without specific prior written permission. 14 * derived from this software without specific prior written permission.
15 * 15 *
16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY 16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY 19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */ 26 */
27using System; 27using System;
28using System.Collections; 28using System.Collections;
29using System.Collections.Generic; 29using System.Collections.Generic;
30using System.IO; 30using System.IO;
31using System.Net; 31using System.Net;
32using System.Net.Security; 32using System.Net.Security;
33using System.Net.Sockets; 33using System.Net.Sockets;
34using System.Reflection; 34using System.Reflection;
35using System.Text.RegularExpressions; 35using System.Text.RegularExpressions;
36using System.Threading; 36using System.Threading;
37 37
38using libsecondlife; 38using libsecondlife;
39using libsecondlife.StructuredData; 39using libsecondlife.StructuredData;
40 40
41using log4net; 41using log4net;
42using Nini.Config; 42using Nini.Config;
43using Nwc.XmlRpc; 43using Nwc.XmlRpc;
44 44
45using OpenSim.Framework; 45using OpenSim.Framework;
46using OpenSim.Region.Environment.Interfaces; 46using OpenSim.Region.Environment.Interfaces;
47using OpenSim.Region.Environment.Scenes; 47using OpenSim.Region.Environment.Scenes;
48using OpenSim.Framework.Communications.Cache; 48using OpenSim.Framework.Communications.Cache;
49using OpenSim.Framework.Communications.Capabilities; 49using OpenSim.Framework.Communications.Capabilities;
50using OpenSim.Framework.Statistics; 50using OpenSim.Framework.Statistics;
51using LLSD = libsecondlife.StructuredData.LLSD; 51using LLSD = libsecondlife.StructuredData.LLSD;
52using LLSDMap = libsecondlife.StructuredData.LLSDMap; 52using LLSDMap = libsecondlife.StructuredData.LLSDMap;
53using LLSDArray = libsecondlife.StructuredData.LLSDArray; 53using LLSDArray = libsecondlife.StructuredData.LLSDArray;
54 54
55namespace OpenSim.Region.Environment.Modules.InterGrid 55namespace OpenSim.Region.Environment.Modules.InterGrid
56{ 56{
57 public struct OGPState 57 public struct OGPState
58 { 58 {
59 public string first_name; 59 public string first_name;
60 public string last_name; 60 public string last_name;
61 public LLUUID agent_id; 61 public LLUUID agent_id;
62 public LLUUID local_agent_id; 62 public LLUUID local_agent_id;
63 public LLUUID region_id; 63 public LLUUID region_id;
64 public uint circuit_code; 64 public uint circuit_code;
65 public LLUUID secure_session_id; 65 public LLUUID secure_session_id;
66 public LLUUID session_id; 66 public LLUUID session_id;
67 public bool agent_access; 67 public bool agent_access;
68 public string sim_access; 68 public string sim_access;
69 public uint god_level; 69 public uint god_level;
70 public bool god_overide; 70 public bool god_overide;
71 public bool identified; 71 public bool identified;
72 public bool transacted; 72 public bool transacted;
73 public bool age_verified; 73 public bool age_verified;
74 public bool allow_redirect; 74 public bool allow_redirect;
75 public int limited_to_estate; 75 public int limited_to_estate;
76 public string inventory_host; 76 public string inventory_host;
77 public bool src_can_see_mainland; 77 public bool src_can_see_mainland;
78 public int src_estate_id; 78 public int src_estate_id;
79 } 79 }
80 80
81 81
82 public class OpenGridProtocolModule : IRegionModule 82 public class OpenGridProtocolModule : IRegionModule
83 { 83 {
84 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); 84 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
85 private List<Scene> m_scene = new List<Scene>(); 85 private List<Scene> m_scene = new List<Scene>();
86 86
87 private Dictionary<string, AgentCircuitData> CapsLoginID = new Dictionary<string, AgentCircuitData>(); 87 private Dictionary<string, AgentCircuitData> CapsLoginID = new Dictionary<string, AgentCircuitData>();
88 private Dictionary<LLUUID, OGPState> m_OGPState = new Dictionary<LLUUID, OGPState>(); 88 private Dictionary<LLUUID, OGPState> m_OGPState = new Dictionary<LLUUID, OGPState>();
89 89
90 90
91 91
92 #region IRegionModule Members 92 #region IRegionModule Members
93 93
94 public void Initialise(Scene scene, IConfigSource config) 94 public void Initialise(Scene scene, IConfigSource config)
95 { 95 {
96 bool enabled = false; 96 bool enabled = false;
97 IConfig cfg = null; 97 IConfig cfg = null;
98 try 98 try
99 { 99 {
100 cfg = config.Configs["OpenGridProtocol"]; 100 cfg = config.Configs["OpenGridProtocol"];
101 } catch (NullReferenceException) 101 } catch (NullReferenceException)
102 { 102 {
103 enabled = false; 103 enabled = false;
104 } 104 }
105 if (cfg != null) 105 if (cfg != null)
106 { 106 {
107 enabled = cfg.GetBoolean("ogp_enabled", false); 107 enabled = cfg.GetBoolean("ogp_enabled", false);
108 if (enabled) 108 if (enabled)
109 { 109 {
110 m_log.Warn("[OGP]: Open Grid Protocol is on, Listening for Clients on /agent/"); 110 m_log.Warn("[OGP]: Open Grid Protocol is on, Listening for Clients on /agent/");
111 lock (m_scene) 111 lock (m_scene)
112 { 112 {
113 if (m_scene.Count == 0) 113 if (m_scene.Count == 0)
114 { 114 {
115 scene.AddLLSDHandler("/agent/", ProcessAgentDomainMessage); 115 scene.AddLLSDHandler("/agent/", ProcessAgentDomainMessage);
116 } 116 }
117 117
118 if (!m_scene.Contains(scene)) 118 if (!m_scene.Contains(scene))
119 m_scene.Add(scene); 119 m_scene.Add(scene);
120 } 120 }
121 } 121 }
122 } 122 }
123 // Of interest to this module potentially 123 // Of interest to this module potentially
124 //scene.EventManager.OnNewClient += OnNewClient; 124 //scene.EventManager.OnNewClient += OnNewClient;
125 //scene.EventManager.OnGridInstantMessageToFriendsModule += OnGridInstantMessage; 125 //scene.EventManager.OnGridInstantMessageToFriendsModule += OnGridInstantMessage;
126 //scene.EventManager.OnAvatarEnteringNewParcel += AvatarEnteringParcel; 126 //scene.EventManager.OnAvatarEnteringNewParcel += AvatarEnteringParcel;
127 //scene.EventManager.OnMakeChildAgent += MakeChildAgent; 127 //scene.EventManager.OnMakeChildAgent += MakeChildAgent;
128 //scene.EventManager.OnClientClosed += ClientLoggedOut; 128 //scene.EventManager.OnClientClosed += ClientLoggedOut;
129 } 129 }
130 130
131 public void PostInitialise() 131 public void PostInitialise()
132 { 132 {
133 } 133 }
134 134
135 public void Close() 135 public void Close()
136 { 136 {
137 } 137 }
138 138
139 public string Name 139 public string Name
140 { 140 {
141 get { return "OpenGridProtocolModule"; } 141 get { return "OpenGridProtocolModule"; }
142 } 142 }
143 143
144 public bool IsSharedModule 144 public bool IsSharedModule
145 { 145 {
146 get { return true; } 146 get { return true; }
147 } 147 }
148 148
149 #endregion 149 #endregion
150 150
151 public LLSD ProcessAgentDomainMessage(string path, LLSD request, string endpoint) 151 public LLSD ProcessAgentDomainMessage(string path, LLSD request, string endpoint)
152 { 152 {
153 // /agent/* 153 // /agent/*
154 154
155 string[] pathSegments = path.Split('/'); 155 string[] pathSegments = path.Split('/');
156 if (pathSegments.Length < 1) 156 if (pathSegments.Length < 1)
157 { 157 {
158 return GenerateNoHandlerMessage(); 158 return GenerateNoHandlerMessage();
159 } 159 }
160 160
161 m_log.InfoFormat("[OGP]: path {0}, segments {1} segment[1] {2} Last segment {3}", 161 m_log.InfoFormat("[OGP]: path {0}, segments {1} segment[1] {2} Last segment {3}",
162 path, pathSegments.Length, pathSegments[1], pathSegments[pathSegments.Length - 1]); 162 path, pathSegments.Length, pathSegments[1], pathSegments[pathSegments.Length - 1]);
163 163
164 switch (pathSegments[pathSegments.Length - 1]) 164 switch (pathSegments[pathSegments.Length - 1])
165 { 165 {
166 case "rez_avatar": 166 case "rez_avatar":
167 return RezAvatarMethod(path, request); 167 return RezAvatarMethod(path, request);
168 //break; 168 //break;
169 case "derez_avatar": 169 case "derez_avatar":
170 return DerezAvatarMethod(path, request); 170 return DerezAvatarMethod(path, request);
171 //break; 171 //break;
172 172
173 } 173 }
174 if (path.Length < 2) 174 if (path.Length < 2)
175 { 175 {
176 return GenerateNoHandlerMessage(); 176 return GenerateNoHandlerMessage();
177 } 177 }
178 178
179 switch (pathSegments[pathSegments.Length - 2] + "/" + pathSegments[pathSegments.Length - 1]) 179 switch (pathSegments[pathSegments.Length - 2] + "/" + pathSegments[pathSegments.Length - 1])
180 { 180 {
181 case "rez_avatar/rez": 181 case "rez_avatar/rez":
182 return RezAvatarMethod(path, request); 182 return RezAvatarMethod(path, request);
183 //break; 183 //break;
184 case "rez_avatar/request": 184 case "rez_avatar/request":
185 return RequestRezAvatarMethod(path, request); 185 return RequestRezAvatarMethod(path, request);
186 //break; 186 //break;
187 default: 187 default:
188 return GenerateNoHandlerMessage(); 188 return GenerateNoHandlerMessage();
189 } 189 }
190 //return null; 190 //return null;
191 } 191 }
192 192
193 public LLSD RequestRezAvatarMethod(string path, LLSD request) 193 public LLSD RequestRezAvatarMethod(string path, LLSD request)
194 { 194 {
195 m_log.WarnFormat("[REQUESTREZAVATAR]: {0}", request.ToString()); 195 m_log.WarnFormat("[REQUESTREZAVATAR]: {0}", request.ToString());
196 196
197 LLSDMap requestMap = (LLSDMap)request; 197 LLSDMap requestMap = (LLSDMap)request;
198 198
199 Scene homeScene = GetRootScene(); 199 Scene homeScene = GetRootScene();
200 200
201 201
202 202
203 if (homeScene == null) 203 if (homeScene == null)
204 return GenerateNoHandlerMessage(); 204 return GenerateNoHandlerMessage();
205 205
206 206
207 RegionInfo reg = homeScene.RegionInfo; 207 RegionInfo reg = homeScene.RegionInfo;
208 ulong regionhandle = GetOSCompatibleRegionHandle(reg); 208 ulong regionhandle = GetOSCompatibleRegionHandle(reg);
209 string RegionURI = reg.ServerURI; 209 string RegionURI = reg.ServerURI;
210 int RegionPort = (int)reg.HttpPort; 210 int RegionPort = (int)reg.HttpPort;
211 211
212 LLUUID RemoteAgentID = requestMap["agent_id"].AsUUID(); 212 LLUUID RemoteAgentID = requestMap["agent_id"].AsUUID();
213 213
214 // will be used in the future. The client always connects with the aditi agentid currently 214 // will be used in the future. The client always connects with the aditi agentid currently
215 LLUUID LocalAgentID = RemoteAgentID; 215 LLUUID LocalAgentID = RemoteAgentID;
216 216
217 string FirstName = requestMap["first_name"].AsString(); 217 string FirstName = requestMap["first_name"].AsString();
218 string LastName = requestMap["last_name"].AsString(); 218 string LastName = requestMap["last_name"].AsString();
219 219
220 220
221 OGPState userState = GetOGPState(LocalAgentID); 221 OGPState userState = GetOGPState(LocalAgentID);
222 222
223 userState.first_name = requestMap["first_name"].AsString(); 223 userState.first_name = requestMap["first_name"].AsString();
224 userState.last_name = requestMap["last_name"].AsString(); 224 userState.last_name = requestMap["last_name"].AsString();
225 userState.age_verified = requestMap["age_verified"].AsBoolean(); 225 userState.age_verified = requestMap["age_verified"].AsBoolean();
226 userState.transacted = requestMap["transacted"].AsBoolean(); 226 userState.transacted = requestMap["transacted"].AsBoolean();
227 userState.agent_access = requestMap["agent_access"].AsBoolean(); 227 userState.agent_access = requestMap["agent_access"].AsBoolean();
228 userState.allow_redirect = requestMap["allow_redirect"].AsBoolean(); 228 userState.allow_redirect = requestMap["allow_redirect"].AsBoolean();
229 userState.identified = requestMap["identified"].AsBoolean(); 229 userState.identified = requestMap["identified"].AsBoolean();
230 userState.god_level = (uint)requestMap["god_level"].AsInteger(); 230 userState.god_level = (uint)requestMap["god_level"].AsInteger();
231 userState.sim_access = requestMap["sim_access"].AsString(); 231 userState.sim_access = requestMap["sim_access"].AsString();
232 userState.agent_id = RemoteAgentID; 232 userState.agent_id = RemoteAgentID;
233 userState.limited_to_estate = requestMap["limited_to_estate"].AsInteger(); 233 userState.limited_to_estate = requestMap["limited_to_estate"].AsInteger();
234 userState.src_can_see_mainland = requestMap["src_can_see_mainland"].AsBoolean(); 234 userState.src_can_see_mainland = requestMap["src_can_see_mainland"].AsBoolean();
235 userState.src_estate_id = requestMap["src_estate_id"].AsInteger(); 235 userState.src_estate_id = requestMap["src_estate_id"].AsInteger();
236 userState.local_agent_id = LocalAgentID; 236 userState.local_agent_id = LocalAgentID;
237 237
238 UpdateOGPState(LocalAgentID, userState); 238 UpdateOGPState(LocalAgentID, userState);
239 239
240 LLSDMap responseMap = new LLSDMap(); 240 LLSDMap responseMap = new LLSDMap();
241 responseMap["sim_host"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString()); 241 responseMap["sim_host"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString());
242 responseMap["sim_ip"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString()); 242 responseMap["sim_ip"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString());
243 responseMap["connect"] = LLSD.FromBoolean(true); 243 responseMap["connect"] = LLSD.FromBoolean(true);
244 responseMap["sim_port"] = LLSD.FromInteger(reg.InternalEndPoint.Port); 244 responseMap["sim_port"] = LLSD.FromInteger(reg.InternalEndPoint.Port);
245 responseMap["region_x"] = LLSD.FromInteger(reg.RegionLocX * (uint)Constants.RegionSize); // LLX 245 responseMap["region_x"] = LLSD.FromInteger(reg.RegionLocX * (uint)Constants.RegionSize); // LLX
246 responseMap["region_Y"] = LLSD.FromInteger(reg.RegionLocY * (uint)Constants.RegionSize); // LLY 246 responseMap["region_Y"] = LLSD.FromInteger(reg.RegionLocY * (uint)Constants.RegionSize); // LLY
247 responseMap["region_id"] = LLSD.FromUUID(reg.originRegionID); 247 responseMap["region_id"] = LLSD.FromUUID(reg.originRegionID);
248 responseMap["sim_access"] = LLSD.FromString((reg.RegionSettings.Maturity == 1) ? "Mature" : "PG"); 248 responseMap["sim_access"] = LLSD.FromString((reg.RegionSettings.Maturity == 1) ? "Mature" : "PG");
249 249
250 // Generate a dummy agent for the user so we can get back a CAPS path 250 // Generate a dummy agent for the user so we can get back a CAPS path
251 AgentCircuitData agentData = new AgentCircuitData(); 251 AgentCircuitData agentData = new AgentCircuitData();
252 agentData.AgentID = LocalAgentID; 252 agentData.AgentID = LocalAgentID;
253 agentData.BaseFolder=LLUUID.Zero; 253 agentData.BaseFolder=LLUUID.Zero;
254 agentData.CapsPath=Util.GetRandomCapsPath(); 254 agentData.CapsPath=Util.GetRandomCapsPath();
255 agentData.child = false; 255 agentData.child = false;
256 agentData.circuitcode = (uint)(Util.RandomClass.Next()); 256 agentData.circuitcode = (uint)(Util.RandomClass.Next());
257 agentData.firstname = FirstName; 257 agentData.firstname = FirstName;
258 agentData.lastname = LastName; 258 agentData.lastname = LastName;
259 agentData.SecureSessionID=LLUUID.Random(); 259 agentData.SecureSessionID=LLUUID.Random();
260 agentData.SessionID=LLUUID.Random(); 260 agentData.SessionID=LLUUID.Random();
261 agentData.startpos=LLVector3.Zero; 261 agentData.startpos=LLVector3.Zero;
262 262
263 // Pre-Fill our region cache with information on the agent. 263 // Pre-Fill our region cache with information on the agent.
264 UserAgentData useragent = new UserAgentData(); 264 UserAgentData useragent = new UserAgentData();
265 useragent.AgentIP="unknown"; 265 useragent.AgentIP="unknown";
266 useragent.AgentOnline=true; 266 useragent.AgentOnline=true;
267 useragent.AgentPort = (uint)0; 267 useragent.AgentPort = (uint)0;
268 useragent.Handle = regionhandle; 268 useragent.Handle = regionhandle;
269 useragent.InitialRegion = reg.originRegionID; 269 useragent.InitialRegion = reg.originRegionID;
270 useragent.LoginTime=Util.UnixTimeSinceEpoch(); 270 useragent.LoginTime=Util.UnixTimeSinceEpoch();
271 useragent.LogoutTime = 0; 271 useragent.LogoutTime = 0;
272 useragent.Position=agentData.startpos; 272 useragent.Position=agentData.startpos;
273 useragent.PositionX=agentData.startpos.X; 273 useragent.PositionX=agentData.startpos.X;
274 useragent.PositionY=agentData.startpos.Y; 274 useragent.PositionY=agentData.startpos.Y;
275 useragent.PositionZ=agentData.startpos.Z; 275 useragent.PositionZ=agentData.startpos.Z;
276 useragent.Region=reg.originRegionID; 276 useragent.Region=reg.originRegionID;
277 useragent.SecureSessionID=agentData.SecureSessionID; 277 useragent.SecureSessionID=agentData.SecureSessionID;
278 useragent.SessionID = agentData.SessionID; 278 useragent.SessionID = agentData.SessionID;
279 279
280 280
281 UserProfileData userProfile = new UserProfileData(); 281 UserProfileData userProfile = new UserProfileData();
282 userProfile.AboutText = "OGP User"; 282 userProfile.AboutText = "OGP User";
283 userProfile.CanDoMask = (uint)0; 283 userProfile.CanDoMask = (uint)0;
284 userProfile.Created = Util.UnixTimeSinceEpoch(); 284 userProfile.Created = Util.UnixTimeSinceEpoch();
285 userProfile.CurrentAgent = useragent; 285 userProfile.CurrentAgent = useragent;
286 userProfile.CustomType = "OGP"; 286 userProfile.CustomType = "OGP";
287 userProfile.FirstLifeAboutText = "I'm testing OpenGrid Protocol"; 287 userProfile.FirstLifeAboutText = "I'm testing OpenGrid Protocol";
288 userProfile.FirstLifeImage = LLUUID.Zero; 288 userProfile.FirstLifeImage = LLUUID.Zero;
289 userProfile.FirstName = agentData.firstname; 289 userProfile.FirstName = agentData.firstname;
290 userProfile.GodLevel = 0; 290 userProfile.GodLevel = 0;
291 userProfile.HomeLocation = agentData.startpos; 291 userProfile.HomeLocation = agentData.startpos;
292 userProfile.HomeLocationX = agentData.startpos.X; 292 userProfile.HomeLocationX = agentData.startpos.X;
293 userProfile.HomeLocationY = agentData.startpos.Y; 293 userProfile.HomeLocationY = agentData.startpos.Y;
294 userProfile.HomeLocationZ = agentData.startpos.Z; 294 userProfile.HomeLocationZ = agentData.startpos.Z;
295 userProfile.HomeLookAt = LLVector3.Zero; 295 userProfile.HomeLookAt = LLVector3.Zero;
296 userProfile.HomeLookAtX = userProfile.HomeLookAt.X; 296 userProfile.HomeLookAtX = userProfile.HomeLookAt.X;
297 userProfile.HomeLookAtY = userProfile.HomeLookAt.Y; 297 userProfile.HomeLookAtY = userProfile.HomeLookAt.Y;
298 userProfile.HomeLookAtZ = userProfile.HomeLookAt.Z; 298 userProfile.HomeLookAtZ = userProfile.HomeLookAt.Z;
299 userProfile.HomeRegion = reg.RegionHandle; 299 userProfile.HomeRegion = reg.RegionHandle;
300 userProfile.HomeRegionID = reg.originRegionID; 300 userProfile.HomeRegionID = reg.originRegionID;
301 userProfile.HomeRegionX = reg.RegionLocX; 301 userProfile.HomeRegionX = reg.RegionLocX;
302 userProfile.HomeRegionY = reg.RegionLocY; 302 userProfile.HomeRegionY = reg.RegionLocY;
303 userProfile.ID = agentData.AgentID; 303 userProfile.ID = agentData.AgentID;
304 userProfile.Image = LLUUID.Zero; 304 userProfile.Image = LLUUID.Zero;
305 userProfile.LastLogin = Util.UnixTimeSinceEpoch(); 305 userProfile.LastLogin = Util.UnixTimeSinceEpoch();
306 userProfile.Partner = LLUUID.Zero; 306 userProfile.Partner = LLUUID.Zero;
307 userProfile.PasswordHash = "$1$"; 307 userProfile.PasswordHash = "$1$";
308 userProfile.PasswordSalt = ""; 308 userProfile.PasswordSalt = "";
309 userProfile.RootInventoryFolderID = LLUUID.Zero; 309 userProfile.RootInventoryFolderID = LLUUID.Zero;
310 userProfile.SurName = agentData.lastname; 310 userProfile.SurName = agentData.lastname;
311 userProfile.UserAssetURI = homeScene.CommsManager.NetworkServersInfo.AssetURL; 311 userProfile.UserAssetURI = homeScene.CommsManager.NetworkServersInfo.AssetURL;
312 userProfile.UserFlags = 0; 312 userProfile.UserFlags = 0;
313 userProfile.UserInventoryURI = homeScene.CommsManager.NetworkServersInfo.InventoryURL; 313 userProfile.UserInventoryURI = homeScene.CommsManager.NetworkServersInfo.InventoryURL;
314 userProfile.WantDoMask = 0; 314 userProfile.WantDoMask = 0;
315 userProfile.WebLoginKey = LLUUID.Random(); 315 userProfile.WebLoginKey = LLUUID.Random();
316 316
317 // Do caps registration 317 // Do caps registration
318 // get seed cap 318 // get seed cap
319 319
320 320
321 // Stick our data in the cache so the region will know something about us 321 // Stick our data in the cache so the region will know something about us
322 homeScene.CommsManager.UserProfileCacheService.PreloadUserCache(agentData.AgentID, userProfile); 322 homeScene.CommsManager.UserProfileCacheService.PreloadUserCache(agentData.AgentID, userProfile);
323 323
324 // Call 'new user' event handler 324 // Call 'new user' event handler
325 homeScene.NewUserConnection(reg.RegionHandle, agentData); 325 homeScene.NewUserConnection(reg.RegionHandle, agentData);
326 326
327 327
328 string raCap = string.Empty; 328 string raCap = string.Empty;
329 329
330 LLUUID AvatarRezCapUUID = LLUUID.Random(); 330 LLUUID AvatarRezCapUUID = LLUUID.Random();
331 string rezAvatarPath = "/agent/" + AvatarRezCapUUID + "/rez_avatar"; 331 string rezAvatarPath = "/agent/" + AvatarRezCapUUID + "/rez_avatar";
332 332
333 // Get a reference to the user's cap so we can pull out the Caps Object Path 333 // Get a reference to the user's cap so we can pull out the Caps Object Path
334 OpenSim.Framework.Communications.Capabilities.Caps userCap = homeScene.GetCapsHandlerForUser(agentData.AgentID); 334 OpenSim.Framework.Communications.Capabilities.Caps userCap = homeScene.GetCapsHandlerForUser(agentData.AgentID);
335 335
336 responseMap["seed_capability"] = LLSD.FromString("http://" + reg.ExternalHostName + ":" + reg.HttpPort + "/CAPS/" + userCap.CapsObjectPath + "0000/"); 336 responseMap["seed_capability"] = LLSD.FromString("http://" + reg.ExternalHostName + ":" + reg.HttpPort + "/CAPS/" + userCap.CapsObjectPath + "0000/");
337 337
338 responseMap["rez_avatar/rez"] = LLSD.FromString("http://" + reg.ExternalHostName + ":" + reg.HttpPort + rezAvatarPath); 338 responseMap["rez_avatar/rez"] = LLSD.FromString("http://" + reg.ExternalHostName + ":" + reg.HttpPort + rezAvatarPath);
339 339
340 // Add the user to the list of CAPS that are outstanding. 340 // Add the user to the list of CAPS that are outstanding.
341 // well allow the caps hosts in this dictionary 341 // well allow the caps hosts in this dictionary
342 lock (CapsLoginID) 342 lock (CapsLoginID)
343 { 343 {
344 if (CapsLoginID.ContainsKey(rezAvatarPath)) 344 if (CapsLoginID.ContainsKey(rezAvatarPath))
345 { 345 {
346 m_log.Error("[OGP]: Holy anomoly batman! Caps path already existed! All the UUID Duplication worries were founded!"); 346 m_log.Error("[OGP]: Holy anomoly batman! Caps path already existed! All the UUID Duplication worries were founded!");
347 } 347 }
348 else 348 else
349 { 349 {
350 CapsLoginID.Add(rezAvatarPath, agentData); 350 CapsLoginID.Add(rezAvatarPath, agentData);
351 } 351 }
352 } 352 }
353 353
354 return responseMap; 354 return responseMap;
355 } 355 }
356 356
357 public LLSD RezAvatarMethod(string path, LLSD request) 357 public LLSD RezAvatarMethod(string path, LLSD request)
358 { 358 {
359 m_log.WarnFormat("[REZAVATAR]: {0}", request.ToString()); 359 m_log.WarnFormat("[REZAVATAR]: {0}", request.ToString());
360 360
361 LLSDMap responseMap = new LLSDMap(); 361 LLSDMap responseMap = new LLSDMap();
362 362
363 AgentCircuitData userData = null; 363 AgentCircuitData userData = null;
364 364
365 // Only people we've issued a cap can go further 365 // Only people we've issued a cap can go further
366 if (TryGetAgentCircuitData(path,out userData)) 366 if (TryGetAgentCircuitData(path,out userData))
367 { 367 {
368 LLSDMap requestMap = (LLSDMap)request; 368 LLSDMap requestMap = (LLSDMap)request;
369 369
370 // take these values to start. There's a few more 370 // take these values to start. There's a few more
371 LLUUID SecureSessionID=requestMap["secure_session_id"].AsUUID(); 371 LLUUID SecureSessionID=requestMap["secure_session_id"].AsUUID();
372 LLUUID SessionID = requestMap["session_id"].AsUUID(); 372 LLUUID SessionID = requestMap["session_id"].AsUUID();
373 int circuitcode = requestMap["circuit_code"].AsInteger(); 373 int circuitcode = requestMap["circuit_code"].AsInteger();
374 374
375 //Update our Circuit data with the real values 375 //Update our Circuit data with the real values
376 userData.SecureSessionID = SecureSessionID; 376 userData.SecureSessionID = SecureSessionID;
377 userData.SessionID = SessionID; 377 userData.SessionID = SessionID;
378 378
379 // Locate a home scene suitable for the user. 379 // Locate a home scene suitable for the user.
380 Scene homeScene = GetRootScene(); 380 Scene homeScene = GetRootScene();
381 381
382 if (homeScene != null) 382 if (homeScene != null)
383 { 383 {
384 // Get a reference to their Cap object so we can pull out the capobjectroot 384 // Get a reference to their Cap object so we can pull out the capobjectroot
385 OpenSim.Framework.Communications.Capabilities.Caps userCap = 385 OpenSim.Framework.Communications.Capabilities.Caps userCap =
386 homeScene.GetCapsHandlerForUser(userData.AgentID); 386 homeScene.GetCapsHandlerForUser(userData.AgentID);
387 387
388 //Update the circuit data in the region so this user is authorized 388 //Update the circuit data in the region so this user is authorized
389 homeScene.UpdateCircuitData(userData); 389 homeScene.UpdateCircuitData(userData);
390 homeScene.ChangeCircuitCode(userData.circuitcode,(uint)circuitcode); 390 homeScene.ChangeCircuitCode(userData.circuitcode,(uint)circuitcode);
391 391
392 // Load state 392 // Load state
393 OGPState userState = GetOGPState(userData.AgentID); 393 OGPState userState = GetOGPState(userData.AgentID);
394 394
395 // Keep state changes 395 // Keep state changes
396 userState.first_name = requestMap["first_name"].AsString(); 396 userState.first_name = requestMap["first_name"].AsString();
397 userState.secure_session_id = requestMap["secure_session_id"].AsUUID(); 397 userState.secure_session_id = requestMap["secure_session_id"].AsUUID();
398 userState.age_verified = requestMap["age_verified"].AsBoolean(); 398 userState.age_verified = requestMap["age_verified"].AsBoolean();
399 userState.region_id = homeScene.RegionInfo.originRegionID; // replace 0000000 with our regionid 399 userState.region_id = homeScene.RegionInfo.originRegionID; // replace 0000000 with our regionid
400 userState.transacted = requestMap["transacted"].AsBoolean(); 400 userState.transacted = requestMap["transacted"].AsBoolean();
401 userState.agent_access = requestMap["agent_access"].AsBoolean(); 401 userState.agent_access = requestMap["agent_access"].AsBoolean();
402 userState.inventory_host = requestMap["inventory_host"].AsString(); 402 userState.inventory_host = requestMap["inventory_host"].AsString();
403 userState.identified = requestMap["identified"].AsBoolean(); 403 userState.identified = requestMap["identified"].AsBoolean();
404 userState.session_id = requestMap["session_id"].AsUUID(); 404 userState.session_id = requestMap["session_id"].AsUUID();
405 userState.god_level = (uint)requestMap["god_level"].AsInteger(); 405 userState.god_level = (uint)requestMap["god_level"].AsInteger();
406 userState.last_name = requestMap["last_name"].AsString(); 406 userState.last_name = requestMap["last_name"].AsString();
407 userState.god_overide = requestMap["god_override"].AsBoolean(); 407 userState.god_overide = requestMap["god_override"].AsBoolean();
408 userState.circuit_code = (uint)requestMap["circuit_code"].AsInteger(); 408 userState.circuit_code = (uint)requestMap["circuit_code"].AsInteger();
409 userState.limited_to_estate = requestMap["limited_to_estate"].AsInteger(); 409 userState.limited_to_estate = requestMap["limited_to_estate"].AsInteger();
410 410
411 // Save state changes 411 // Save state changes
412 UpdateOGPState(userData.AgentID, userState); 412 UpdateOGPState(userData.AgentID, userState);
413 413
414 // Get the region information for the home region. 414 // Get the region information for the home region.
415 RegionInfo reg = homeScene.RegionInfo; 415 RegionInfo reg = homeScene.RegionInfo;
416 416
417 // Dummy positional and look at info.. we don't have it. 417 // Dummy positional and look at info.. we don't have it.
418 LLSDArray PositionArray = new LLSDArray(); 418 LLSDArray PositionArray = new LLSDArray();
419 PositionArray.Add(LLSD.FromInteger(128)); 419 PositionArray.Add(LLSD.FromInteger(128));
420 PositionArray.Add(LLSD.FromInteger(128)); 420 PositionArray.Add(LLSD.FromInteger(128));
421 PositionArray.Add(LLSD.FromInteger(40)); 421 PositionArray.Add(LLSD.FromInteger(40));
422 422
423 LLSDArray LookAtArray = new LLSDArray(); 423 LLSDArray LookAtArray = new LLSDArray();
424 LookAtArray.Add(LLSD.FromInteger(1)); 424 LookAtArray.Add(LLSD.FromInteger(1));
425 LookAtArray.Add(LLSD.FromInteger(1)); 425 LookAtArray.Add(LLSD.FromInteger(1));
426 LookAtArray.Add(LLSD.FromInteger(1)); 426 LookAtArray.Add(LLSD.FromInteger(1));
427 427
428 // Our region's X and Y position in OpenSimulator space. 428 // Our region's X and Y position in OpenSimulator space.
429 uint fooX = reg.RegionLocX; 429 uint fooX = reg.RegionLocX;
430 uint fooY = reg.RegionLocY; 430 uint fooY = reg.RegionLocY;
431 m_log.InfoFormat("[OGP]: region x({0}) region y({1})", fooX, fooY); 431 m_log.InfoFormat("[OGP]: region x({0}) region y({1})", fooX, fooY);
432 m_log.InfoFormat("[OGP]: region http {0} {1}", reg.ServerURI, reg.HttpPort); 432 m_log.InfoFormat("[OGP]: region http {0} {1}", reg.ServerURI, reg.HttpPort);
433 m_log.InfoFormat("[OGO]: region UUID {0} ", reg.RegionID); 433 m_log.InfoFormat("[OGO]: region UUID {0} ", reg.RegionID);
434 434
435 // Convert the X and Y position to LL space 435 // Convert the X and Y position to LL space
436 responseMap["region_x"] = LLSD.FromInteger(fooX * (uint)Constants.RegionSize); // convert it to LL X 436 responseMap["region_x"] = LLSD.FromInteger(fooX * (uint)Constants.RegionSize); // convert it to LL X
437 responseMap["region_y"] = LLSD.FromInteger(fooY * (uint)Constants.RegionSize); // convert it to LL Y 437 responseMap["region_y"] = LLSD.FromInteger(fooY * (uint)Constants.RegionSize); // convert it to LL Y
438 438
439 // Give em a new seed capability 439 // Give em a new seed capability
440 responseMap["seed_capability"] = LLSD.FromString("http://" + reg.ExternalHostName + ":" + reg.HttpPort + "/CAPS/" + userCap.CapsObjectPath + "0000/"); 440 responseMap["seed_capability"] = LLSD.FromString("http://" + reg.ExternalHostName + ":" + reg.HttpPort + "/CAPS/" + userCap.CapsObjectPath + "0000/");
441 responseMap["region"] = LLSD.FromUUID(reg.originRegionID); 441 responseMap["region"] = LLSD.FromUUID(reg.originRegionID);
442 responseMap["look_at"] = LookAtArray; 442 responseMap["look_at"] = LookAtArray;
443 443
444 responseMap["sim_port"] = LLSD.FromInteger(reg.InternalEndPoint.Port); 444 responseMap["sim_port"] = LLSD.FromInteger(reg.InternalEndPoint.Port);
445 responseMap["sim_host"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString());// + ":" + reg.InternalEndPoint.Port.ToString()); 445 responseMap["sim_host"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString());// + ":" + reg.InternalEndPoint.Port.ToString());
446 responseMap["sim_ip"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString()); 446 responseMap["sim_ip"] = LLSD.FromString(Util.GetHostFromDNS(reg.ExternalHostName).ToString());
447 447
448 responseMap["session_id"] = LLSD.FromUUID(SessionID); 448 responseMap["session_id"] = LLSD.FromUUID(SessionID);
449 responseMap["secure_session_id"] = LLSD.FromUUID(SecureSessionID); 449 responseMap["secure_session_id"] = LLSD.FromUUID(SecureSessionID);
450 responseMap["circuit_code"] = LLSD.FromInteger(circuitcode); 450 responseMap["circuit_code"] = LLSD.FromInteger(circuitcode);
451 451
452 responseMap["position"] = PositionArray; 452 responseMap["position"] = PositionArray;
453 453
454 responseMap["region_id"] = LLSD.FromUUID(reg.originRegionID); 454 responseMap["region_id"] = LLSD.FromUUID(reg.originRegionID);
455 455
456 responseMap["sim_access"] = LLSD.FromString("Mature"); 456 responseMap["sim_access"] = LLSD.FromString("Mature");
457 457
458 responseMap["connect"] = LLSD.FromBoolean(true); 458 responseMap["connect"] = LLSD.FromBoolean(true);
459 459
460 m_log.InfoFormat("[OGP]: host: {0}, IP {1}", responseMap["sim_host"].ToString(), responseMap["sim_ip"].ToString()); 460 m_log.InfoFormat("[OGP]: host: {0}, IP {1}", responseMap["sim_host"].ToString(), responseMap["sim_ip"].ToString());
461 461
462 } 462 }
463 463
464 } 464 }
465 465
466 return responseMap; 466 return responseMap;
467 } 467 }
468 468
469 469
470 470
471 public LLSD DerezAvatarMethod(string path, LLSD request) 471 public LLSD DerezAvatarMethod(string path, LLSD request)
472 { 472 {
473 473
474 474
475 m_log.ErrorFormat("DerezPath: {0}, Request: {1}", path, request.ToString()); 475 m_log.ErrorFormat("DerezPath: {0}, Request: {1}", path, request.ToString());
476 476
477 LLSD llsdResponse = null; 477 LLSD llsdResponse = null;
478 LLSDMap responseMap = new LLSDMap(); 478 LLSDMap responseMap = new LLSDMap();
479 479
480 480
481 481
482 string[] PathArray = path.Split('/'); 482 string[] PathArray = path.Split('/');
483 m_log.InfoFormat("[OGP]: prefix {0}, uuid {1}, suffix {2}", PathArray[1], PathArray[2], PathArray[3]); 483 m_log.InfoFormat("[OGP]: prefix {0}, uuid {1}, suffix {2}", PathArray[1], PathArray[2], PathArray[3]);
484 string uuidString = PathArray[2]; 484 string uuidString = PathArray[2];
485 m_log.InfoFormat("[OGP]: Request to Derez avatar with UUID {0}", uuidString); 485 m_log.InfoFormat("[OGP]: Request to Derez avatar with UUID {0}", uuidString);
486 LLUUID userUUID = LLUUID.Zero; 486 LLUUID userUUID = LLUUID.Zero;
487 if (Helpers.TryParse(uuidString, out userUUID)) 487 if (Helpers.TryParse(uuidString, out userUUID))
488 { 488 {
489 489
490 LLUUID RemoteID = uuidString; 490 LLUUID RemoteID = uuidString;
491 LLUUID LocalID = RemoteID; 491 LLUUID LocalID = RemoteID;
492 // FIXME: TODO: Routine to map RemoteUUIDs to LocalUUIds 492 // FIXME: TODO: Routine to map RemoteUUIDs to LocalUUIds
493 // would be done already.. but the client connects with the Aditi UUID 493 // would be done already.. but the client connects with the Aditi UUID
494 // regardless over the UDP stack 494 // regardless over the UDP stack
495 495
496 OGPState userState = GetOGPState(LocalID); 496 OGPState userState = GetOGPState(LocalID);
497 if (userState.agent_id != LLUUID.Zero) 497 if (userState.agent_id != LLUUID.Zero)
498 { 498 {
499 499
500 LLSDMap outboundRequestMap = new LLSDMap(); 500 LLSDMap outboundRequestMap = new LLSDMap();
501 LLSDMap inboundRequestMap = (LLSDMap)request; 501 LLSDMap inboundRequestMap = (LLSDMap)request;
502 string rezAvatarString = inboundRequestMap["rez_avatar"].AsString(); 502 string rezAvatarString = inboundRequestMap["rez_avatar"].AsString();
503 503
504 LLSDArray LookAtArray = new LLSDArray(); 504 LLSDArray LookAtArray = new LLSDArray();
505 LookAtArray.Add(LLSD.FromInteger(1)); 505 LookAtArray.Add(LLSD.FromInteger(1));
506 LookAtArray.Add(LLSD.FromInteger(1)); 506 LookAtArray.Add(LLSD.FromInteger(1));
507 LookAtArray.Add(LLSD.FromInteger(1)); 507 LookAtArray.Add(LLSD.FromInteger(1));
508 508
509 509
510 LLSDArray PositionArray = new LLSDArray(); 510 LLSDArray PositionArray = new LLSDArray();
511 PositionArray.Add(LLSD.FromInteger(128)); 511 PositionArray.Add(LLSD.FromInteger(128));
512 PositionArray.Add(LLSD.FromInteger(128)); 512 PositionArray.Add(LLSD.FromInteger(128));
513 PositionArray.Add(LLSD.FromInteger(40)); 513 PositionArray.Add(LLSD.FromInteger(40));
514 514
515 LLSDArray lookArray = new LLSDArray(); 515 LLSDArray lookArray = new LLSDArray();
516 lookArray.Add(LLSD.FromInteger(128)); 516 lookArray.Add(LLSD.FromInteger(128));
517 lookArray.Add(LLSD.FromInteger(128)); 517 lookArray.Add(LLSD.FromInteger(128));
518 lookArray.Add(LLSD.FromInteger(40)); 518 lookArray.Add(LLSD.FromInteger(40));
519 519
520 responseMap["connect"] = LLSD.FromBoolean(true);// it's okay to give this user up 520 responseMap["connect"] = LLSD.FromBoolean(true);// it's okay to give this user up
521 responseMap["look_at"] = LookAtArray; 521 responseMap["look_at"] = LookAtArray;
522 522
523 m_log.WarnFormat("[OGP]: Invoking rez_avatar on host:{0} for avatar: {1} {2}", rezAvatarString, userState.first_name, userState.last_name); 523 m_log.WarnFormat("[OGP]: Invoking rez_avatar on host:{0} for avatar: {1} {2}", rezAvatarString, userState.first_name, userState.last_name);
524 524
525 LLSDMap rezResponseMap = invokeRezAvatarCap(responseMap, rezAvatarString,userState); 525 LLSDMap rezResponseMap = invokeRezAvatarCap(responseMap, rezAvatarString,userState);
526 526
527 // If invoking it returned an error, parse and end 527 // If invoking it returned an error, parse and end
528 if (rezResponseMap.ContainsKey("connect")) 528 if (rezResponseMap.ContainsKey("connect"))
529 { 529 {
530 if (rezResponseMap["connect"].AsBoolean() == false) 530 if (rezResponseMap["connect"].AsBoolean() == false)
531 { 531 {
532 return responseMap; 532 return responseMap;
533 } 533 }
534 } 534 }
535 535
536 string rezRespSeedCap = rezResponseMap["seed_capability"].AsString(); 536 string rezRespSeedCap = rezResponseMap["seed_capability"].AsString();
537 string rezRespSim_ip = rezResponseMap["sim_ip"].AsString(); 537 string rezRespSim_ip = rezResponseMap["sim_ip"].AsString();
538 string rezRespSim_host = rezResponseMap["sim_host"].AsString(); 538 string rezRespSim_host = rezResponseMap["sim_host"].AsString();
539 539
540 int rrPort = rezResponseMap["sim_port"].AsInteger(); 540 int rrPort = rezResponseMap["sim_port"].AsInteger();
541 int rrX = rezResponseMap["region_x"].AsInteger(); 541 int rrX = rezResponseMap["region_x"].AsInteger();
542 int rrY = rezResponseMap["region_y"].AsInteger(); 542 int rrY = rezResponseMap["region_y"].AsInteger();
543 m_log.ErrorFormat("X:{0}, Y:{1}", rrX, rrY); 543 m_log.ErrorFormat("X:{0}, Y:{1}", rrX, rrY);
544 LLUUID rrRID = rezResponseMap["region_id"].AsUUID(); 544 LLUUID rrRID = rezResponseMap["region_id"].AsUUID();
545 545
546 string rrAccess = rezResponseMap["sim_access"].AsString(); 546 string rrAccess = rezResponseMap["sim_access"].AsString();
547 547
548 LLSDArray RezResponsePositionArray = (LLSDArray)rezResponseMap["position"]; 548 LLSDArray RezResponsePositionArray = (LLSDArray)rezResponseMap["position"];
549 549
550 responseMap["seed_capability"] = LLSD.FromString(rezRespSeedCap); 550 responseMap["seed_capability"] = LLSD.FromString(rezRespSeedCap);
551 responseMap["sim_ip"] = LLSD.FromString(Util.GetHostFromDNS(rezRespSim_ip).ToString()); 551 responseMap["sim_ip"] = LLSD.FromString(Util.GetHostFromDNS(rezRespSim_ip).ToString());
552 responseMap["sim_host"] = LLSD.FromString(Util.GetHostFromDNS(rezRespSim_host).ToString()); 552 responseMap["sim_host"] = LLSD.FromString(Util.GetHostFromDNS(rezRespSim_host).ToString());
553 responseMap["sim_port"] = LLSD.FromInteger(rrPort); 553 responseMap["sim_port"] = LLSD.FromInteger(rrPort);
554 responseMap["region_x"] = LLSD.FromInteger(rrX ); 554 responseMap["region_x"] = LLSD.FromInteger(rrX );
555 responseMap["region_y"] = LLSD.FromInteger(rrY ); 555 responseMap["region_y"] = LLSD.FromInteger(rrY );
556 responseMap["region_id"] = LLSD.FromUUID(rrRID); 556 responseMap["region_id"] = LLSD.FromUUID(rrRID);
557 responseMap["sim_access"] = LLSD.FromString(rrAccess); 557 responseMap["sim_access"] = LLSD.FromString(rrAccess);
558 558
559 559
560 560
561 responseMap["position"] = RezResponsePositionArray; 561 responseMap["position"] = RezResponsePositionArray;
562 responseMap["look_at"] = lookArray; 562 responseMap["look_at"] = lookArray;
563 responseMap["connect"] = LLSD.FromBoolean(true); 563 responseMap["connect"] = LLSD.FromBoolean(true);
564 564
565 ShutdownConnection(LocalID,this); 565 ShutdownConnection(LocalID,this);
566 566
567 567
568 m_log.Warn("RESPONSEDEREZ: " + responseMap.ToString()); 568 m_log.Warn("RESPONSEDEREZ: " + responseMap.ToString());
569 return responseMap; 569 return responseMap;
570 570
571 } 571 }
572 else 572 else
573 { 573 {
574 574
575 return GenerateNoHandlerMessage(); 575 return GenerateNoHandlerMessage();
576 } 576 }
577 } 577 }
578 else 578 else
579 { 579 {
580 return GenerateNoHandlerMessage(); 580 return GenerateNoHandlerMessage();
581 } 581 }
582 582
583 return responseMap; 583 return responseMap;
584 } 584 }
585 585
586 private LLSDMap invokeRezAvatarCap(LLSDMap responseMap, string CapAddress, OGPState userState) 586 private LLSDMap invokeRezAvatarCap(LLSDMap responseMap, string CapAddress, OGPState userState)
587 { 587 {
588 588
589 WebRequest DeRezRequest = WebRequest.Create(CapAddress); 589 WebRequest DeRezRequest = WebRequest.Create(CapAddress);
590 DeRezRequest.Method = "POST"; 590 DeRezRequest.Method = "POST";
591 DeRezRequest.ContentType = "application/xml+llsd"; 591 DeRezRequest.ContentType = "application/xml+llsd";
592 592
593 LLSDMap RAMap = new LLSDMap(); 593 LLSDMap RAMap = new LLSDMap();
594 LLSDMap AgentParms = new LLSDMap(); 594 LLSDMap AgentParms = new LLSDMap();
595 LLSDMap RegionParms = new LLSDMap(); 595 LLSDMap RegionParms = new LLSDMap();
596 596
597 597
598 AgentParms["first_name"] = LLSD.FromString(userState.first_name); 598 AgentParms["first_name"] = LLSD.FromString(userState.first_name);
599 AgentParms["last_name"] = LLSD.FromString(userState.last_name); 599 AgentParms["last_name"] = LLSD.FromString(userState.last_name);
600 AgentParms["agent_id"] = LLSD.FromUUID(userState.agent_id); 600 AgentParms["agent_id"] = LLSD.FromUUID(userState.agent_id);
601 RegionParms["region_id"] = LLSD.FromUUID(userState.region_id); 601 RegionParms["region_id"] = LLSD.FromUUID(userState.region_id);
602 AgentParms["circuit_code"] = LLSD.FromInteger(userState.circuit_code); 602 AgentParms["circuit_code"] = LLSD.FromInteger(userState.circuit_code);
603 AgentParms["secure_session_id"] = LLSD.FromUUID(userState.secure_session_id); 603 AgentParms["secure_session_id"] = LLSD.FromUUID(userState.secure_session_id);
604 AgentParms["session_id"] = LLSD.FromUUID(userState.session_id); 604 AgentParms["session_id"] = LLSD.FromUUID(userState.session_id);
605 AgentParms["agent_access"] = LLSD.FromBoolean(userState.agent_access); 605 AgentParms["agent_access"] = LLSD.FromBoolean(userState.agent_access);
606 AgentParms["god_level"] = LLSD.FromInteger(userState.god_level); 606 AgentParms["god_level"] = LLSD.FromInteger(userState.god_level);
607 AgentParms["god_overide"] = LLSD.FromBoolean(userState.god_overide); 607 AgentParms["god_overide"] = LLSD.FromBoolean(userState.god_overide);
608 AgentParms["identified"] = LLSD.FromBoolean(userState.identified); 608 AgentParms["identified"] = LLSD.FromBoolean(userState.identified);
609 AgentParms["transacted"] = LLSD.FromBoolean(userState.transacted); 609 AgentParms["transacted"] = LLSD.FromBoolean(userState.transacted);
610 AgentParms["age_verified"] = LLSD.FromBoolean(userState.age_verified); 610 AgentParms["age_verified"] = LLSD.FromBoolean(userState.age_verified);
611 AgentParms["limited_to_estate"] = LLSD.FromInteger(userState.limited_to_estate); 611 AgentParms["limited_to_estate"] = LLSD.FromInteger(userState.limited_to_estate);
612 AgentParms["inventory_host"] = LLSD.FromString(userState.inventory_host); 612 AgentParms["inventory_host"] = LLSD.FromString(userState.inventory_host);
613 RAMap["agent_params"] = AgentParms; 613 RAMap["agent_params"] = AgentParms;
614 RAMap["region_params"] = RegionParms; 614 RAMap["region_params"] = RegionParms;
615 615
616 string RAMapString = AgentParms.ToString(); 616 string RAMapString = AgentParms.ToString();
617 m_log.InfoFormat("[OGP] RAMap string {0}", RAMapString); 617 m_log.InfoFormat("[OGP] RAMap string {0}", RAMapString);
618 LLSD LLSDofRAMap = AgentParms; // RENAME if this works 618 LLSD LLSDofRAMap = AgentParms; // RENAME if this works
619 619
620 m_log.InfoFormat("[OGP]: LLSD of map as string was {0}", LLSDofRAMap.ToString()); 620 m_log.InfoFormat("[OGP]: LLSD of map as string was {0}", LLSDofRAMap.ToString());
621 byte[] buffer = LLSDParser.SerializeXmlBytes(LLSDofRAMap); 621 byte[] buffer = LLSDParser.SerializeXmlBytes(LLSDofRAMap);
622 622
623 //string bufferDump = System.Text.Encoding.ASCII.GetString(buffer); 623 //string bufferDump = System.Text.Encoding.ASCII.GetString(buffer);
624 //m_log.InfoFormat("[OGP]: buffer form is {0}",bufferDump); 624 //m_log.InfoFormat("[OGP]: buffer form is {0}",bufferDump);
625 //m_log.InfoFormat("[OGP]: LLSD of map was {0}",buffer.Length); 625 //m_log.InfoFormat("[OGP]: LLSD of map was {0}",buffer.Length);
626 626
627 Stream os = null; 627 Stream os = null;
628 try 628 try
629 { // send the Post 629 { // send the Post
630 DeRezRequest.ContentLength = buffer.Length; //Count bytes to send 630 DeRezRequest.ContentLength = buffer.Length; //Count bytes to send
631 os = DeRezRequest.GetRequestStream(); 631 os = DeRezRequest.GetRequestStream();
632 os.Write(buffer, 0, buffer.Length); //Send it 632 os.Write(buffer, 0, buffer.Length); //Send it
633 os.Close(); 633 os.Close();
634 m_log.InfoFormat("[OGP]: Derez Avatar Posted Rez Avatar request to remote sim {0}", CapAddress); 634 m_log.InfoFormat("[OGP]: Derez Avatar Posted Rez Avatar request to remote sim {0}", CapAddress);
635 } 635 }
636 catch (WebException ex) 636 catch (WebException ex)
637 { 637 {
638 m_log.InfoFormat("[OGP] Bad send on de_rez_avatar {0}", ex.Message); 638 m_log.InfoFormat("[OGP] Bad send on de_rez_avatar {0}", ex.Message);
639 responseMap["connect"] = LLSD.FromBoolean(false); 639 responseMap["connect"] = LLSD.FromBoolean(false);
640 640
641 return responseMap; 641 return responseMap;
642 } 642 }
643 643
644 m_log.Info("[OGP] waiting for a reply after rez avatar send"); 644 m_log.Info("[OGP] waiting for a reply after rez avatar send");
645 string rez_avatar_reply = null; 645 string rez_avatar_reply = null;
646 { // get the response 646 { // get the response
647 try 647 try
648 { 648 {
649 WebResponse webResponse = DeRezRequest.GetResponse(); 649 WebResponse webResponse = DeRezRequest.GetResponse();
650 if (webResponse == null) 650 if (webResponse == null)
651 { 651 {
652 m_log.Info("[OGP:] Null reply on rez_avatar post"); 652 m_log.Info("[OGP:] Null reply on rez_avatar post");
653 } 653 }
654 654
655 StreamReader sr = new StreamReader(webResponse.GetResponseStream()); 655 StreamReader sr = new StreamReader(webResponse.GetResponseStream());
656 rez_avatar_reply = sr.ReadToEnd().Trim(); 656 rez_avatar_reply = sr.ReadToEnd().Trim();
657 m_log.InfoFormat("[OGP]: rez_avatar reply was {0} ", rez_avatar_reply); 657 m_log.InfoFormat("[OGP]: rez_avatar reply was {0} ", rez_avatar_reply);
658 658
659 } 659 }
660 catch (WebException ex) 660 catch (WebException ex)
661 { 661 {
662 m_log.InfoFormat("[OGP]: exception on read after send of rez avatar {0}", ex.Message); 662 m_log.InfoFormat("[OGP]: exception on read after send of rez avatar {0}", ex.Message);
663 responseMap["connect"] = LLSD.FromBoolean(false); 663 responseMap["connect"] = LLSD.FromBoolean(false);
664 664
665 return responseMap; 665 return responseMap;
666 } 666 }
667 LLSD rezResponse = null; 667 LLSD rezResponse = null;
668 try 668 try
669 { 669 {
670 rezResponse = LLSDParser.DeserializeXml(rez_avatar_reply); 670 rezResponse = LLSDParser.DeserializeXml(rez_avatar_reply);
671 671
672 responseMap = (LLSDMap)rezResponse; 672 responseMap = (LLSDMap)rezResponse;
673 } 673 }
674 catch (Exception ex) 674 catch (Exception ex)
675 { 675 {
676 m_log.InfoFormat("[OGP]: exception on parse of rez reply {0}", ex.Message); 676 m_log.InfoFormat("[OGP]: exception on parse of rez reply {0}", ex.Message);
677 responseMap["connect"] = LLSD.FromBoolean(false); 677 responseMap["connect"] = LLSD.FromBoolean(false);
678 678
679 return responseMap; 679 return responseMap;
680 } 680 }
681 } 681 }
682 return responseMap; 682 return responseMap;
683 } 683 }
684 684
685 685
686 686
687 public LLSD GenerateNoHandlerMessage() 687 public LLSD GenerateNoHandlerMessage()
688 { 688 {
689 LLSDMap map = new LLSDMap(); 689 LLSDMap map = new LLSDMap();
690 map["reason"] = LLSD.FromString("LLSDRequest"); 690 map["reason"] = LLSD.FromString("LLSDRequest");
691 map["message"] = LLSD.FromString("No handler registered for LLSD Requests"); 691 map["message"] = LLSD.FromString("No handler registered for LLSD Requests");
692 map["login"] = LLSD.FromString("false"); 692 map["login"] = LLSD.FromString("false");
693 693
694 return map; 694 return map;
695 } 695 }
696 696
697 private bool TryGetAgentCircuitData(string path, out AgentCircuitData userdata) 697 private bool TryGetAgentCircuitData(string path, out AgentCircuitData userdata)
698 { 698 {
699 userdata = null; 699 userdata = null;
700 lock (CapsLoginID) 700 lock (CapsLoginID)
701 { 701 {
702 if (CapsLoginID.ContainsKey(path)) 702 if (CapsLoginID.ContainsKey(path))
703 { 703 {
704 userdata = CapsLoginID[path]; 704 userdata = CapsLoginID[path];
705 DiscardUsedCap(path); 705 DiscardUsedCap(path);
706 return true; 706 return true;
707 } 707 }
708 } 708 }
709 return false; 709 return false;
710 } 710 }
711 711
712 private void DiscardUsedCap(string path) 712 private void DiscardUsedCap(string path)
713 { 713 {
714 CapsLoginID.Remove(path); 714 CapsLoginID.Remove(path);
715 } 715 }
716 716
717 717
718 private Scene GetRootScene() 718 private Scene GetRootScene()
719 { 719 {
720 Scene ReturnScene = null; 720 Scene ReturnScene = null;
721 lock (m_scene) 721 lock (m_scene)
722 { 722 {
723 if (m_scene.Count > 0) 723 if (m_scene.Count > 0)
724 { 724 {
725 ReturnScene = m_scene[0]; 725 ReturnScene = m_scene[0];
726 } 726 }
727 } 727 }
728 728
729 return ReturnScene; 729 return ReturnScene;
730 730
731 } 731 }
732 732
733 private ulong GetOSCompatibleRegionHandle(RegionInfo reg) 733 private ulong GetOSCompatibleRegionHandle(RegionInfo reg)
734 { 734 {
735 return Util.UIntsToLong(reg.RegionLocX, reg.RegionLocY); 735 return Util.UIntsToLong(reg.RegionLocX, reg.RegionLocY);
736 } 736 }
737 737
738 private ulong GetOSCompatibleRegionHandle(uint x, uint y) 738 private ulong GetOSCompatibleRegionHandle(uint x, uint y)
739 { 739 {
740 return Util.UIntsToLong(x, y); 740 return Util.UIntsToLong(x, y);
741 } 741 }
742 742
743 private ulong GetOSCompatibleRegionHandle(ulong regionhandle) 743 private ulong GetOSCompatibleRegionHandle(ulong regionhandle)
744 { 744 {
745 uint x,y; 745 uint x,y;
746 Helpers.LongToUInts(regionhandle,out x, out y); 746 Helpers.LongToUInts(regionhandle,out x, out y);
747 return GetOSCompatibleRegionHandle(x,y); 747 return GetOSCompatibleRegionHandle(x,y);
748 } 748 }
749 749
750 750
751 private ulong GetOGPCompatibleRegionHandle(RegionInfo reg) 751 private ulong GetOGPCompatibleRegionHandle(RegionInfo reg)
752 { 752 {
753 return Util.UIntsToLong((reg.RegionLocX * (uint)Constants.RegionSize), (reg.RegionLocY * (uint)Constants.RegionSize)); 753 return Util.UIntsToLong((reg.RegionLocX * (uint)Constants.RegionSize), (reg.RegionLocY * (uint)Constants.RegionSize));
754 } 754 }
755 755
756 private ulong GetOGPCompatibleRegionHandle(uint x, uint y) 756 private ulong GetOGPCompatibleRegionHandle(uint x, uint y)
757 { 757 {
758 return Util.UIntsToLong((x * (uint)Constants.RegionSize), (y * (uint)Constants.RegionSize)); 758 return Util.UIntsToLong((x * (uint)Constants.RegionSize), (y * (uint)Constants.RegionSize));
759 } 759 }
760 760
761 private ulong GetOGPCompatibleRegionHandle(ulong regionhandle) 761 private ulong GetOGPCompatibleRegionHandle(ulong regionhandle)
762 { 762 {
763 uint x, y; 763 uint x, y;
764 Helpers.LongToUInts(regionhandle, out x, out y); 764 Helpers.LongToUInts(regionhandle, out x, out y);
765 return GetOGPCompatibleRegionHandle(x, y); 765 return GetOGPCompatibleRegionHandle(x, y);
766 } 766 }
767 767
768 private OGPState InitializeNewState() 768 private OGPState InitializeNewState()
769 { 769 {
770 OGPState returnState = new OGPState(); 770 OGPState returnState = new OGPState();
771 returnState.first_name = ""; 771 returnState.first_name = "";
772 returnState.last_name = ""; 772 returnState.last_name = "";
773 returnState.agent_id = LLUUID.Zero; 773 returnState.agent_id = LLUUID.Zero;
774 returnState.local_agent_id = LLUUID.Zero; 774 returnState.local_agent_id = LLUUID.Zero;
775 returnState.region_id = LLUUID.Zero; 775 returnState.region_id = LLUUID.Zero;
776 returnState.circuit_code = 0; 776 returnState.circuit_code = 0;
777 returnState.secure_session_id = LLUUID.Zero; 777 returnState.secure_session_id = LLUUID.Zero;
778 returnState.session_id = LLUUID.Zero; 778 returnState.session_id = LLUUID.Zero;
779 returnState.agent_access = true; 779 returnState.agent_access = true;
780 returnState.god_level = 0; 780 returnState.god_level = 0;
781 returnState.god_overide = false; 781 returnState.god_overide = false;
782 returnState.identified = false; 782 returnState.identified = false;
783 returnState.transacted = false; 783 returnState.transacted = false;
784 returnState.age_verified = false; 784 returnState.age_verified = false;
785 returnState.limited_to_estate = 1; 785 returnState.limited_to_estate = 1;
786 returnState.inventory_host = "http://inv4.mysql.aditi.lindenlab.com"; 786 returnState.inventory_host = "http://inv4.mysql.aditi.lindenlab.com";
787 returnState.allow_redirect = true; 787 returnState.allow_redirect = true;
788 returnState.sim_access = ""; 788 returnState.sim_access = "";
789 returnState.src_can_see_mainland = true; 789 returnState.src_can_see_mainland = true;
790 returnState.src_estate_id = 1; 790 returnState.src_estate_id = 1;
791 791
792 return returnState; 792 return returnState;
793 } 793 }
794 794
795 private OGPState GetOGPState(LLUUID agentId) 795 private OGPState GetOGPState(LLUUID agentId)
796 { 796 {
797 lock (m_OGPState) 797 lock (m_OGPState)
798 { 798 {
799 if (m_OGPState.ContainsKey(agentId)) 799 if (m_OGPState.ContainsKey(agentId))
800 { 800 {
801 return m_OGPState[agentId]; 801 return m_OGPState[agentId];
802 } 802 }
803 else 803 else
804 { 804 {
805 return InitializeNewState(); 805 return InitializeNewState();
806 } 806 }
807 } 807 }
808 } 808 }
809 809
810 public void DeleteOGPState(LLUUID agentId) 810 public void DeleteOGPState(LLUUID agentId)
811 { 811 {
812 lock (m_OGPState) 812 lock (m_OGPState)
813 if (m_OGPState.ContainsKey(agentId)) 813 if (m_OGPState.ContainsKey(agentId))
814 m_OGPState.Remove(agentId); 814 m_OGPState.Remove(agentId);
815 815
816 } 816 }
817 817
818 private void UpdateOGPState(LLUUID agentId, OGPState state) 818 private void UpdateOGPState(LLUUID agentId, OGPState state)
819 { 819 {
820 lock (m_OGPState) 820 lock (m_OGPState)
821 { 821 {
822 if (m_OGPState.ContainsKey(agentId)) 822 if (m_OGPState.ContainsKey(agentId))
823 { 823 {
824 m_OGPState[agentId] = state; 824 m_OGPState[agentId] = state;
825 } 825 }
826 else 826 else
827 { 827 {
828 m_OGPState.Add(agentId,state); 828 m_OGPState.Add(agentId,state);
829 } 829 }
830 } 830 }
831 } 831 }
832 public void ShutdownConnection(LLUUID avatarId, OpenGridProtocolModule mod) 832 public void ShutdownConnection(LLUUID avatarId, OpenGridProtocolModule mod)
833 { 833 {
834 Scene homeScene = GetRootScene(); 834 Scene homeScene = GetRootScene();
835 ScenePresence avatar = null; 835 ScenePresence avatar = null;
836 if (homeScene.TryGetAvatar(avatarId,out avatar)) 836 if (homeScene.TryGetAvatar(avatarId,out avatar))
837 { 837 {
838 KillAUser ku = new KillAUser(avatar,mod); 838 KillAUser ku = new KillAUser(avatar,mod);
839 Thread ta = new Thread(ku.ShutdownNoLogout); 839 Thread ta = new Thread(ku.ShutdownNoLogout);
840 ta.IsBackground = true; 840 ta.IsBackground = true;
841 ta.Name = "ShutdownThread"; 841 ta.Name = "ShutdownThread";
842 ta.Start(); 842 ta.Start();
843 } 843 }
844 } 844 }
845 } 845 }
846 846
847 public class KillAUser 847 public class KillAUser
848 { 848 {
849 private ScenePresence avToBeKilled = null; 849 private ScenePresence avToBeKilled = null;
850 private OpenGridProtocolModule m_mod = null; 850 private OpenGridProtocolModule m_mod = null;
851 851
852 public KillAUser(ScenePresence avatar, OpenGridProtocolModule mod) 852 public KillAUser(ScenePresence avatar, OpenGridProtocolModule mod)
853 { 853 {
854 avToBeKilled = avatar; 854 avToBeKilled = avatar;
855 m_mod = mod; 855 m_mod = mod;
856 } 856 }
857 857
858 public void ShutdownNoLogout() 858 public void ShutdownNoLogout()
859 { 859 {
860 LLUUID avUUID = LLUUID.Zero; 860 LLUUID avUUID = LLUUID.Zero;
861 861
862 if (avToBeKilled != null) 862 if (avToBeKilled != null)
863 { 863 {
864 avUUID = avToBeKilled.UUID; 864 avUUID = avToBeKilled.UUID;
865 avToBeKilled.MakeChildAgent(); 865 avToBeKilled.MakeChildAgent();
866 866
867 avToBeKilled.ControllingClient.SendLogoutPacketWhenClosing = false; 867 avToBeKilled.ControllingClient.SendLogoutPacketWhenClosing = false;
868 868
869 Thread.Sleep(30000); 869 Thread.Sleep(30000);
870 870
871 // test for child agent because they might have come back 871 // test for child agent because they might have come back
872 if (avToBeKilled.IsChildAgent) 872 if (avToBeKilled.IsChildAgent)
873 { 873 {
874 m_mod.DeleteOGPState(avUUID); 874 m_mod.DeleteOGPState(avUUID);
875 avToBeKilled.ControllingClient.Close(true); 875 avToBeKilled.ControllingClient.Close(true);
876 } 876 }
877 } 877 }
878 } 878 }
879 879
880 } 880 }
881} 881}