aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorTeravus Ovares2008-01-07 01:39:26 +0000
committerTeravus Ovares2008-01-07 01:39:26 +0000
commitf43e75762a4fe4458d8fd70e0e029ee4113c413f (patch)
tree940178f6b2c221b597869a1841f7c8789832af44
parentMore inventory work for CharlieO. Final patch to make it all work yet to come. (diff)
downloadopensim-SC-f43e75762a4fe4458d8fd70e0e029ee4113c413f.zip
opensim-SC-f43e75762a4fe4458d8fd70e0e029ee4113c413f.tar.gz
opensim-SC-f43e75762a4fe4458d8fd70e0e029ee4113c413f.tar.bz2
opensim-SC-f43e75762a4fe4458d8fd70e0e029ee4113c413f.tar.xz
* Adding More to the MessageServer classes.
* Don't forget to prebuild
-rw-r--r--OpenSim/Framework/FriendListItem.cs3
-rw-r--r--OpenSim/Framework/Servers/MessageServerInfo.cs27
-rw-r--r--OpenSim/Grid/GridServer/GridManager.cs2
-rw-r--r--OpenSim/Grid/MessagingServer/MessageService.cs224
-rw-r--r--OpenSim/Grid/MessagingServer/UserPresenceData.cs49
-rw-r--r--OpenSim/Grid/UserServer/MessageServersConnector.cs27
-rw-r--r--prebuild.xml1
7 files changed, 333 insertions, 0 deletions
diff --git a/OpenSim/Framework/FriendListItem.cs b/OpenSim/Framework/FriendListItem.cs
index 0d7cb75..349ee97 100644
--- a/OpenSim/Framework/FriendListItem.cs
+++ b/OpenSim/Framework/FriendListItem.cs
@@ -42,6 +42,9 @@ namespace OpenSim.Framework
42 42
43 // These are what the friend gives the listowner permission to do 43 // These are what the friend gives the listowner permission to do
44 public uint FriendListOwnerPerms; 44 public uint FriendListOwnerPerms;
45
46 public bool onlinestatus = false;
47
45 48
46 } 49 }
47} 50}
diff --git a/OpenSim/Framework/Servers/MessageServerInfo.cs b/OpenSim/Framework/Servers/MessageServerInfo.cs
index 9d5fa8a..ec4155b 100644
--- a/OpenSim/Framework/Servers/MessageServerInfo.cs
+++ b/OpenSim/Framework/Servers/MessageServerInfo.cs
@@ -1,3 +1,30 @@
1/*
2* Copyright (c) Contributors, http://opensimulator.org/
3* See CONTRIBUTORS.TXT for a full list of copyright holders.
4*
5* Redistribution and use in source and binary forms, with or without
6* modification, are permitted provided that the following conditions are met:
7* * Redistributions of source code must retain the above copyright
8* notice, this list of conditions and the following disclaimer.
9* * Redistributions in binary form must reproduce the above copyright
10* notice, this list of conditions and the following disclaimer in the
11* documentation and/or other materials provided with the distribution.
12* * Neither the name of the OpenSim Project nor the
13* names of its contributors may be used to endorse or promote products
14* derived from this software without specific prior written permission.
15*
16* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
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
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
25* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*
27*/
1using System; 28using System;
2using System.Collections.Generic; 29using System.Collections.Generic;
3using System.Text; 30using System.Text;
diff --git a/OpenSim/Grid/GridServer/GridManager.cs b/OpenSim/Grid/GridServer/GridManager.cs
index 61f1fd7..52d087b 100644
--- a/OpenSim/Grid/GridServer/GridManager.cs
+++ b/OpenSim/Grid/GridServer/GridManager.cs
@@ -45,6 +45,8 @@ namespace OpenSim.Grid.GridServer
45 { 45 {
46 private Dictionary<string, IGridData> _plugins = new Dictionary<string, IGridData>(); 46 private Dictionary<string, IGridData> _plugins = new Dictionary<string, IGridData>();
47 private Dictionary<string, ILogData> _logplugins = new Dictionary<string, ILogData>(); 47 private Dictionary<string, ILogData> _logplugins = new Dictionary<string, ILogData>();
48
49 // This is here so that the grid server can hand out MessageServer settings to regions on registration
48 private List<MessageServerInfo> _MessageServers = new List<MessageServerInfo>(); 50 private List<MessageServerInfo> _MessageServers = new List<MessageServerInfo>();
49 51
50 public GridConfig config; 52 public GridConfig config;
diff --git a/OpenSim/Grid/MessagingServer/MessageService.cs b/OpenSim/Grid/MessagingServer/MessageService.cs
new file mode 100644
index 0000000..a4362c7
--- /dev/null
+++ b/OpenSim/Grid/MessagingServer/MessageService.cs
@@ -0,0 +1,224 @@
1/*
2* Copyright (c) Contributors, http://opensimulator.org/
3* See CONTRIBUTORS.TXT for a full list of copyright holders.
4*
5* Redistribution and use in source and binary forms, with or without
6* modification, are permitted provided that the following conditions are met:
7* * Redistributions of source code must retain the above copyright
8* notice, this list of conditions and the following disclaimer.
9* * Redistributions in binary form must reproduce the above copyright
10* notice, this list of conditions and the following disclaimer in the
11* documentation and/or other materials provided with the distribution.
12* * Neither the name of the OpenSim Project nor the
13* names of its contributors may be used to endorse or promote products
14* derived from this software without specific prior written permission.
15*
16* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
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
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
25* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*
27*/
28using System;
29using System.Net;
30using System.Net.Sockets;
31using System.Collections;
32using System.Collections.Generic;
33using System.Xml;
34using libsecondlife;
35using Nwc.XmlRpc;
36using OpenSim.Framework;
37using OpenSim.Framework.Console;
38using OpenSim.Framework.Data;
39using OpenSim.Framework.Servers;
40
41namespace OpenSim.Grid.MessagingServer
42{
43 public class MessageService
44 {
45 private LogBase m_log;
46 private MessageServerConfig m_cfg;
47 private Hashtable m_presences = new Hashtable();
48 private Hashtable m_regionInfoCache = new Hashtable();
49
50 public MessageService(LogBase log, MessageServerConfig cfg)
51 {
52 m_log = log;
53 m_cfg = cfg;
54 }
55
56 public XmlRpcResponse UserLoggedOn(XmlRpcRequest request)
57 {
58
59 Hashtable requestData = (Hashtable)request.Params[0];
60 AgentCircuitData agentData = new AgentCircuitData();
61 agentData.SessionID = new LLUUID((string)requestData["session_id"]);
62 agentData.SecureSessionID = new LLUUID((string)requestData["secure_session_id"]);
63 agentData.firstname = (string)requestData["firstname"];
64 agentData.lastname = (string)requestData["lastname"];
65 agentData.AgentID = new LLUUID((string)requestData["agent_id"]);
66 agentData.circuitcode = Convert.ToUInt32(requestData["circuit_code"]);
67 agentData.CapsPath = (string)requestData["caps_path"];
68
69 if (requestData.ContainsKey("child_agent") && requestData["child_agent"].Equals("1"))
70 {
71 agentData.child = true;
72 }
73 else
74 {
75 agentData.startpos =
76 new LLVector3(Convert.ToUInt32(requestData["startpos_x"]),
77 Convert.ToUInt32(requestData["startpos_y"]),
78 Convert.ToUInt32(requestData["startpos_z"]));
79 agentData.child = false;
80 }
81
82 ulong regionHandle = Convert.ToUInt64((string)requestData["regionhandle"]);
83
84 m_presences.Add(regionHandle, agentData);
85
86
87 return new XmlRpcResponse();
88 }
89
90
91 #region FriendList Gathering
92
93 /// <summary>
94 /// Returns a list of FriendsListItems that describe the friends and permissions in the friend relationship for LLUUID friendslistowner
95 /// </summary>
96 /// <param name="friendlistowner">The agent that we're retreiving the friends Data.</param>
97 public List<FriendListItem> GetUserFriendList(LLUUID friendlistowner)
98 {
99 List<FriendListItem> buddylist = new List<FriendListItem>();
100
101 try
102 {
103 Hashtable param = new Hashtable();
104 param["ownerID"] = friendlistowner.UUID.ToString();
105
106 IList parameters = new ArrayList();
107 parameters.Add(param);
108 XmlRpcRequest req = new XmlRpcRequest("get_user_friend_list", parameters);
109 XmlRpcResponse resp = req.Send(m_cfg.UserServerURL, 3000);
110 Hashtable respData = (Hashtable)resp.Value;
111
112 if (respData.Contains("avcount"))
113 {
114 buddylist = ConvertXMLRPCDataToFriendListItemList(respData);
115 }
116
117 }
118 catch (WebException e)
119 {
120 MainLog.Instance.Warn("Error when trying to fetch Avatar's friends list: " +
121 e.Message);
122 // Return Empty list (no friends)
123 }
124 return buddylist;
125
126 }
127 public List<FriendListItem> ConvertXMLRPCDataToFriendListItemList(Hashtable data)
128 {
129 List<FriendListItem> buddylist = new List<FriendListItem>();
130 int buddycount = Convert.ToInt32((string)data["avcount"]);
131
132
133 for (int i = 0; i < buddycount; i++)
134 {
135 FriendListItem buddylistitem = new FriendListItem();
136
137 buddylistitem.FriendListOwner = new LLUUID((string)data["ownerID" + i.ToString()]);
138 buddylistitem.Friend = new LLUUID((string)data["friendID" + i.ToString()]);
139 buddylistitem.FriendListOwnerPerms = (uint)Convert.ToInt32((string)data["ownerPerms" + i.ToString()]);
140 buddylistitem.FriendPerms = (uint)Convert.ToInt32((string)data["friendPerms" + i.ToString()]);
141
142 buddylist.Add(buddylistitem);
143 }
144
145
146 return buddylist;
147 }
148 #endregion
149
150 #region regioninfo gathering
151
152 /// <summary>
153 /// Gets and caches a RegionInfo object from the gridserver based on regionhandle
154 /// if the regionhandle is already cached, use the cached values
155 /// </summary>
156 /// <param name="regionhandle">handle to the XY of the region we're looking for</param>
157 /// <returns>A RegionInfo object to stick in the presence info</returns>
158 public RegionInfo GetRegionInfo(ulong regionhandle)
159 {
160 RegionInfo regionInfo = null;
161 if (m_regionInfoCache.Contains(regionhandle))
162 {
163 regionInfo = (RegionInfo)m_regionInfoCache[regionhandle];
164 }
165 else
166 {
167 regionInfo = RequestRegionInfo(regionhandle);
168 }
169 return regionInfo;
170 }
171 public RegionInfo RequestRegionInfo(ulong regionHandle)
172 { RegionInfo regionInfo = null;
173 try
174 {
175
176 Hashtable requestData = new Hashtable();
177 requestData["region_handle"] = regionHandle.ToString();
178 requestData["authkey"] = m_cfg.GridSendKey;
179 ArrayList SendParams = new ArrayList();
180 SendParams.Add(requestData);
181 XmlRpcRequest GridReq = new XmlRpcRequest("simulator_data_request", SendParams);
182 XmlRpcResponse GridResp = GridReq.Send(m_cfg.GridServerURL, 3000);
183
184 Hashtable responseData = (Hashtable)GridResp.Value;
185
186 if (responseData.ContainsKey("error"))
187 {
188 m_log.Error("GRID","error received from grid server" + responseData["error"]);
189 return null;
190 }
191
192 uint regX = Convert.ToUInt32((string)responseData["region_locx"]);
193 uint regY = Convert.ToUInt32((string)responseData["region_locy"]);
194 string internalIpStr = (string)responseData["sim_ip"];
195 uint port = Convert.ToUInt32(responseData["sim_port"]);
196 string externalUri = (string)responseData["sim_uri"];
197
198 IPEndPoint neighbourInternalEndPoint = new IPEndPoint(IPAddress.Parse(internalIpStr), (int)port);
199 string neighbourExternalUri = externalUri;
200 regionInfo = new RegionInfo(regX, regY, neighbourInternalEndPoint, internalIpStr);
201
202 regionInfo.RemotingPort = Convert.ToUInt32((string)responseData["remoting_port"]);
203 regionInfo.RemotingAddress = internalIpStr;
204
205 regionInfo.RegionID = new LLUUID((string)responseData["region_UUID"]);
206 regionInfo.RegionName = (string)responseData["region_name"];
207
208 m_regionInfoCache.Add(regionHandle, regionInfo);
209 }
210 catch (WebException)
211 {
212 MainLog.Instance.Error("GRID",
213 "Region lookup failed for: " + regionHandle.ToString() +
214 " - Is the GridServer down?");
215 return null;
216 }
217
218
219 return regionInfo;
220 }
221 #endregion
222 }
223
224}
diff --git a/OpenSim/Grid/MessagingServer/UserPresenceData.cs b/OpenSim/Grid/MessagingServer/UserPresenceData.cs
new file mode 100644
index 0000000..88007ae
--- /dev/null
+++ b/OpenSim/Grid/MessagingServer/UserPresenceData.cs
@@ -0,0 +1,49 @@
1/*
2* Copyright (c) Contributors, http://opensimulator.org/
3* See CONTRIBUTORS.TXT for a full list of copyright holders.
4*
5* Redistribution and use in source and binary forms, with or without
6* modification, are permitted provided that the following conditions are met:
7* * Redistributions of source code must retain the above copyright
8* notice, this list of conditions and the following disclaimer.
9* * Redistributions in binary form must reproduce the above copyright
10* notice, this list of conditions and the following disclaimer in the
11* documentation and/or other materials provided with the distribution.
12* * Neither the name of the OpenSim Project nor the
13* names of its contributors may be used to endorse or promote products
14* derived from this software without specific prior written permission.
15*
16* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
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
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
25* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*
27*/
28using System;
29using System.Collections;
30using System.Collections.Generic;
31using libsecondlife;
32using OpenSim.Framework;
33
34namespace OpenSim.Grid.MessagingServer
35{
36 public class UserPresenceData
37 {
38 public AgentCircuitData agentData = new AgentCircuitData();
39 public RegionInfo regionData = new RegionInfo();
40 public List<FriendListItem> friendData = new List<FriendListItem> ();
41
42 public UserPresenceData()
43 {
44
45
46 }
47
48 }
49}
diff --git a/OpenSim/Grid/UserServer/MessageServersConnector.cs b/OpenSim/Grid/UserServer/MessageServersConnector.cs
index 7966868..93d5925 100644
--- a/OpenSim/Grid/UserServer/MessageServersConnector.cs
+++ b/OpenSim/Grid/UserServer/MessageServersConnector.cs
@@ -1,3 +1,30 @@
1/*
2* Copyright (c) Contributors, http://opensimulator.org/
3* See CONTRIBUTORS.TXT for a full list of copyright holders.
4*
5* Redistribution and use in source and binary forms, with or without
6* modification, are permitted provided that the following conditions are met:
7* * Redistributions of source code must retain the above copyright
8* notice, this list of conditions and the following disclaimer.
9* * Redistributions in binary form must reproduce the above copyright
10* notice, this list of conditions and the following disclaimer in the
11* documentation and/or other materials provided with the distribution.
12* * Neither the name of the OpenSim Project nor the
13* names of its contributors may be used to endorse or promote products
14* derived from this software without specific prior written permission.
15*
16* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
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
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
25* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*
27*/
1using System; 28using System;
2using System.Collections; 29using System.Collections;
3using System.Collections.Generic; 30using System.Collections.Generic;
diff --git a/prebuild.xml b/prebuild.xml
index ad726bd..9833ecc 100644
--- a/prebuild.xml
+++ b/prebuild.xml
@@ -1117,6 +1117,7 @@
1117 <Reference name="OpenSim.Framework.Data"/> 1117 <Reference name="OpenSim.Framework.Data"/>
1118 <Reference name="OpenSim.Framework.Servers"/> 1118 <Reference name="OpenSim.Framework.Servers"/>
1119 <Reference name="libsecondlife.dll"/> 1119 <Reference name="libsecondlife.dll"/>
1120 <Reference name="XMLRPC.dll"/>
1120 1121
1121 <Files> 1122 <Files>
1122 <Match pattern="*.cs" recurse="true"/> 1123 <Match pattern="*.cs" recurse="true"/>