aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorMelanie Thielker2009-06-22 13:25:47 +0000
committerMelanie Thielker2009-06-22 13:25:47 +0000
commitafbce6aa10f6028e82b7004851078a35075284dc (patch)
treef3309d4fd85f1286eb54c93922d13cb3006ec16c
parentCommitting RemoteUserServiceConnector out connector, local user service (diff)
downloadopensim-SC-afbce6aa10f6028e82b7004851078a35075284dc.zip
opensim-SC-afbce6aa10f6028e82b7004851078a35075284dc.tar.gz
opensim-SC-afbce6aa10f6028e82b7004851078a35075284dc.tar.bz2
opensim-SC-afbce6aa10f6028e82b7004851078a35075284dc.tar.xz
Forgot a file
-rw-r--r--OpenSim/Services/Connectors/User/UserServiceConnector.cs177
1 files changed, 177 insertions, 0 deletions
diff --git a/OpenSim/Services/Connectors/User/UserServiceConnector.cs b/OpenSim/Services/Connectors/User/UserServiceConnector.cs
new file mode 100644
index 0000000..8b136b5
--- /dev/null
+++ b/OpenSim/Services/Connectors/User/UserServiceConnector.cs
@@ -0,0 +1,177 @@
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 OpenSimulator 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 log4net;
29using System;
30using System.Collections.Generic;
31using System.IO;
32using System.Reflection;
33using Nini.Config;
34using OpenSim.Framework;
35using OpenSim.Framework.Communications;
36using OpenSim.Framework.Servers.HttpServer;
37using OpenSim.Services.Interfaces;
38using OpenMetaverse;
39
40namespace OpenSim.Services.Connectors
41{
42 public class UserServicesConnector : IUserDataService
43 {
44 private static readonly ILog m_log =
45 LogManager.GetLogger(
46 MethodBase.GetCurrentMethod().DeclaringType);
47
48 private string m_ServerURI = String.Empty;
49
50 public UserServicesConnector()
51 {
52 }
53
54 public UserServicesConnector(string serverURI)
55 {
56 m_ServerURI = serverURI.TrimEnd('/');
57 }
58
59 public UserServicesConnector(IConfigSource source)
60 {
61 Initialise(source);
62 }
63
64 public virtual void Initialise(IConfigSource source)
65 {
66 IConfig assetConfig = source.Configs["UserService"];
67 if (assetConfig == null)
68 {
69 m_log.Error("[USER CONNECTOR]: UserService missing from OpanSim.ini");
70 throw new Exception("User connector init error");
71 }
72
73 string serviceURI = assetConfig.GetString("UserServerURI",
74 String.Empty);
75
76 if (serviceURI == String.Empty)
77 {
78 m_log.Error("[USER CONNECTOR]: No Server URI named in section UserService");
79 throw new Exception("User connector init error");
80 }
81 m_ServerURI = serviceURI;
82 }
83
84 public UserData GetUserData(UUID scopeID, string firstName, string lastName)
85 {
86 string uri = m_ServerURI + "/users/";
87 UserData data = new UserData();
88 data.FirstName = firstName;
89 data.LastName = lastName;
90 data.ScopeID = scopeID;
91 data.UserID = UUID.Zero;
92
93 try
94 {
95 data = SynchronousRestObjectRequester.
96 MakeRequest<UserData, UserData>("POST", uri, data);
97 }
98 catch (Exception e)
99 {
100 m_log.WarnFormat("[USER CONNECTOR]: Unable to send request to user server. Reason: {1}", e.Message);
101 return null;
102 }
103
104 if (data.UserID == UUID.Zero)
105 return null;
106
107 return data;
108 }
109
110 public UserData GetUserData(UUID scopeID, UUID userID)
111 {
112 string uri = m_ServerURI + "/users/";
113 UserData data = new UserData();
114 data.FirstName = String.Empty;
115 data.LastName = String.Empty;
116 data.ScopeID = scopeID;
117 data.UserID = userID;
118
119 try
120 {
121 data = SynchronousRestObjectRequester.
122 MakeRequest<UserData, UserData>("POST", uri, data);
123 }
124 catch (Exception e)
125 {
126 m_log.WarnFormat("[USER CONNECTOR]: Unable to send request to user server. Reason: {1}", e.Message);
127 return null;
128 }
129
130 if (data.UserID == UUID.Zero)
131 return null;
132
133 return data;
134 }
135
136 public bool SetUserData(UserData data)
137 {
138 string uri = m_ServerURI + "/user/";
139 bool result = false;
140
141 try
142 {
143 result = SynchronousRestObjectRequester.
144 MakeRequest<UserData, bool>("POST", uri, data);
145 }
146 catch (Exception e)
147 {
148 m_log.WarnFormat("[USER CONNECTOR]: Unable to send request to user server. Reason: {1}", e.Message);
149 return false;
150 }
151
152 return result;
153 }
154
155 public List<UserData> GetAvatarPickerData(UUID scopeID, string query)
156 {
157 string uri = m_ServerURI + "/userlist/";
158 UserData data = new UserData();
159 data.FirstName = query;
160 data.ScopeID = scopeID;
161 List<UserData> result;
162
163 try
164 {
165 result = SynchronousRestObjectRequester.
166 MakeRequest<UserData, List<UserData>>("POST", uri, data);
167 }
168 catch (Exception e)
169 {
170 m_log.WarnFormat("[USER CONNECTOR]: Unable to send request to user server. Reason: {1}", e.Message);
171 return null;
172 }
173
174 return result;
175 }
176 }
177}