OpenSim
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Events Macros
UserProfilesServiceBase.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 System;
29 using System.Reflection;
30 using Nini.Config;
31 using log4net;
32 using OpenSim.Services.Base;
33 using OpenSim.Data;
34 
35 namespace OpenSim.Services.ProfilesService
36 {
38  {
39  static readonly ILog m_log =
40  LogManager.GetLogger(
41  MethodBase.GetCurrentMethod().DeclaringType);
42 
44 
45  public string ConfigName
46  {
47  get; private set;
48  }
49 
50  public UserProfilesServiceBase(IConfigSource config, string configName):
51  base(config)
52  {
53  if(string.IsNullOrEmpty(configName))
54  {
55  m_log.WarnFormat("[PROFILES SERVICE]: Configuration section not given!");
56  return;
57  }
58 
59  string dllName = String.Empty;
60  string connString = null;
61  string realm = String.Empty;
62 
63  IConfig dbConfig = config.Configs["DatabaseService"];
64  if (dbConfig != null)
65  {
66  if (dllName == String.Empty)
67  dllName = dbConfig.GetString("StorageProvider", String.Empty);
68  if (string.IsNullOrEmpty(connString))
69  connString = dbConfig.GetString("ConnectionString", String.Empty);
70  }
71 
72  IConfig ProfilesConfig = config.Configs[configName];
73  if (ProfilesConfig != null)
74  {
75  dllName = ProfilesConfig.GetString("StorageProvider", dllName);
76  connString = ProfilesConfig.GetString("ConnectionString", connString);
77  realm = ProfilesConfig.GetString("Realm", realm);
78  }
79 
80  ProfilesData = LoadPlugin<IProfilesData>(dllName, new Object[] { connString });
81  if (ProfilesData == null)
82  throw new Exception("Could not find a storage interface in the given module");
83 
84  }
85  }
86 }
87 
UserProfilesServiceBase(IConfigSource config, string configName)