OpenSim
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Events Macros
AuthenticationServicesConnector.cs
Go to the documentation of this file.
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 
28 using log4net;
29 using System;
30 using System.Collections.Generic;
31 using System.IO;
32 using System.Reflection;
33 using Nini.Config;
34 using OpenSim.Framework;
35 using OpenSim.Framework.ServiceAuth;
36 using OpenSim.Services.Interfaces;
37 using OpenSim.Server.Base;
38 using OpenMetaverse;
39 
40 namespace OpenSim.Services.Connectors
41 {
43  {
44  private static readonly ILog m_log =
45  LogManager.GetLogger(
46  MethodBase.GetCurrentMethod().DeclaringType);
47 
48  private string m_ServerURI = String.Empty;
49 
51  {
52  }
53 
54  public AuthenticationServicesConnector(string serverURI)
55  {
56  m_ServerURI = serverURI.TrimEnd('/');
57  }
58 
59  public AuthenticationServicesConnector(IConfigSource source)
60  : base(source, "AuthenticationService")
61  {
62  Initialise(source);
63  }
64 
65  public virtual void Initialise(IConfigSource source)
66  {
67  IConfig assetConfig = source.Configs["AuthenticationService"];
68  if (assetConfig == null)
69  {
70  m_log.Error("[AUTH CONNECTOR]: AuthenticationService missing from OpenSim.ini");
71  throw new Exception("Authentication connector init error");
72  }
73 
74  string serviceURI = assetConfig.GetString("AuthenticationServerURI",
75  String.Empty);
76 
77  if (serviceURI == String.Empty)
78  {
79  m_log.Error("[AUTH CONNECTOR]: No Server URI named in section AuthenticationService");
80  throw new Exception("Authentication connector init error");
81  }
82  m_ServerURI = serviceURI;
83 
84  base.Initialise(source, "AuthenticationService");
85  }
86 
87  public string Authenticate(UUID principalID, string password, int lifetime, out UUID realID)
88  {
89  realID = UUID.Zero;
90 
91  return Authenticate(principalID, password, lifetime);
92  }
93 
94  public string Authenticate(UUID principalID, string password, int lifetime)
95  {
96  Dictionary<string, object> sendData = new Dictionary<string, object>();
97  sendData["LIFETIME"] = lifetime.ToString();
98  sendData["PRINCIPAL"] = principalID.ToString();
99  sendData["PASSWORD"] = password;
100 
101  sendData["METHOD"] = "authenticate";
102 
103  string reply = SynchronousRestFormsRequester.MakeRequest("POST",
104  m_ServerURI + "/auth/plain",
105  ServerUtils.BuildQueryString(sendData), m_Auth);
106 
107  Dictionary<string, object> replyData = ServerUtils.ParseXmlResponse(
108  reply);
109 
110  if (replyData["Result"].ToString() != "Success")
111  return String.Empty;
112 
113  return replyData["Token"].ToString();
114  }
115 
116  public bool Verify(UUID principalID, string token, int lifetime)
117  {
118 // m_log.Error("[XXX]: Verify");
119  Dictionary<string, object> sendData = new Dictionary<string, object>();
120  sendData["LIFETIME"] = lifetime.ToString();
121  sendData["PRINCIPAL"] = principalID.ToString();
122  sendData["TOKEN"] = token;
123 
124  sendData["METHOD"] = "verify";
125 
126  string reply = SynchronousRestFormsRequester.MakeRequest("POST",
127  m_ServerURI + "/auth/plain",
128  ServerUtils.BuildQueryString(sendData), m_Auth);
129 
130  Dictionary<string, object> replyData = ServerUtils.ParseXmlResponse(
131  reply);
132 
133  if (replyData["Result"].ToString() != "Success")
134  return false;
135 
136  return true;
137  }
138 
139  public bool Release(UUID principalID, string token)
140  {
141  Dictionary<string, object> sendData = new Dictionary<string, object>();
142  sendData["PRINCIPAL"] = principalID.ToString();
143  sendData["TOKEN"] = token;
144 
145  sendData["METHOD"] = "release";
146 
147  string reply = SynchronousRestFormsRequester.MakeRequest("POST",
148  m_ServerURI + "/auth/plain",
149  ServerUtils.BuildQueryString(sendData), m_Auth);
150 
151  Dictionary<string, object> replyData = ServerUtils.ParseXmlResponse(
152  reply);
153 
154  if (replyData["Result"].ToString() != "Success")
155  return false;
156 
157  return true;
158  }
159 
160  public bool SetPassword(UUID principalID, string passwd)
161  {
162  // nope, we don't do this
163  return false;
164  }
165 
166  public AuthInfo GetAuthInfo(UUID principalID)
167  {
168  // not done from remote simulators
169  return null;
170  }
171 
172  public bool SetAuthInfo(AuthInfo info)
173  {
174  // not done from remote simulators
175  return false;
176  }
177  }
178 }
string Authenticate(UUID principalID, string password, int lifetime)
string Authenticate(UUID principalID, string password, int lifetime, out UUID realID)