From a1cc0e436ff9081f3c0a76de861ed0673cd36142 Mon Sep 17 00:00:00 2001 From: Sean Dague Date: Wed, 23 Apr 2008 19:13:06 +0000 Subject: changes to allow asset_source to be specified in the opensim.ini this will work for sqlite and nhibernate, but will be ignored for mysql and mssql (reverting to their ini files) until someone writes that bit. --- OpenSim/Data/AssetDataBase.cs | 1 + OpenSim/Data/MSSQL/MSSQLAssetData.cs | 7 +++++++ OpenSim/Data/MySQL/MySQLAssetData.cs | 7 +++++++ OpenSim/Data/NHibernate/NHibernateAssetData.cs | 16 +++++++++++----- OpenSim/Data/SQLite/SQLiteAssetData.cs | 9 ++++++--- 5 files changed, 32 insertions(+), 8 deletions(-) (limited to 'OpenSim/Data') diff --git a/OpenSim/Data/AssetDataBase.cs b/OpenSim/Data/AssetDataBase.cs index b30ae73..e3b5c25 100644 --- a/OpenSim/Data/AssetDataBase.cs +++ b/OpenSim/Data/AssetDataBase.cs @@ -40,6 +40,7 @@ namespace OpenSim.Data public abstract string Version { get; } public abstract string Name { get; } + public abstract void Initialise(string connect); public abstract void Initialise(); } } diff --git a/OpenSim/Data/MSSQL/MSSQLAssetData.cs b/OpenSim/Data/MSSQL/MSSQLAssetData.cs index 2029b80..d837e4e 100644 --- a/OpenSim/Data/MSSQL/MSSQLAssetData.cs +++ b/OpenSim/Data/MSSQL/MSSQLAssetData.cs @@ -191,6 +191,13 @@ namespace OpenSim.Data.MSSQL #region IPlugin Members + override public void Initialise(string connect) + { + // TODO: this would allow you to pass in connnect info as + // a string instead of file, if someone writes the support + Initialise(); + } + override public void Initialise() { IniFile GridDataMySqlFile = new IniFile("mssql_connection.ini"); diff --git a/OpenSim/Data/MySQL/MySQLAssetData.cs b/OpenSim/Data/MySQL/MySQLAssetData.cs index 111f7d1..b6545d7 100644 --- a/OpenSim/Data/MySQL/MySQLAssetData.cs +++ b/OpenSim/Data/MySQL/MySQLAssetData.cs @@ -170,6 +170,13 @@ namespace OpenSim.Data.MySQL #region IPlugin Members + override public void Initialise(string connect) + { + // TODO: This will let you pass in the connect string in + // the config, though someone will need to write that. + Initialise(); + } + override public void Initialise() { IniFile GridDataMySqlFile = new IniFile("mysql_connection.ini"); diff --git a/OpenSim/Data/NHibernate/NHibernateAssetData.cs b/OpenSim/Data/NHibernate/NHibernateAssetData.cs index db90d09..7bd4a0b 100644 --- a/OpenSim/Data/NHibernate/NHibernateAssetData.cs +++ b/OpenSim/Data/NHibernate/NHibernateAssetData.cs @@ -50,18 +50,24 @@ namespace OpenSim.Data.NHibernate public override void Initialise() { - // TODO: hard coding for sqlite based stuff to begin with, just making it easier to test + Initialise("SQLiteDialect;SqliteClientDriver;URI=file:Asset.db,version=3"); + } + public override void Initialise(string connect) + { + // TODO: hard coding for sqlite based stuff to begin with, just making it easier to test + char[] split = {';'}; + string[] parts = connect.Split(split); + // This is stubbing for now, it will become dynamic later and support different db backends cfg = new Configuration(); cfg.SetProperty(Environment.ConnectionProvider, "NHibernate.Connection.DriverConnectionProvider"); cfg.SetProperty(Environment.Dialect, - "NHibernate.Dialect.SQLiteDialect"); + "NHibernate.Dialect." + parts[0]); cfg.SetProperty(Environment.ConnectionDriver, - "NHibernate.Driver.SqliteClientDriver"); - cfg.SetProperty(Environment.ConnectionString, - "URI=file:Asset.db,version=3"); + "NHibernate.Driver." + parts[1]); + cfg.SetProperty(Environment.ConnectionString, parts[2]); cfg.AddAssembly("OpenSim.Data.NHibernate"); HbmSerializer.Default.Validate = true; diff --git a/OpenSim/Data/SQLite/SQLiteAssetData.cs b/OpenSim/Data/SQLite/SQLiteAssetData.cs index 2b63d2b..0d8b468 100644 --- a/OpenSim/Data/SQLite/SQLiteAssetData.cs +++ b/OpenSim/Data/SQLite/SQLiteAssetData.cs @@ -56,9 +56,12 @@ namespace OpenSim.Data.SQLite private SqliteConnection m_conn; - public void Initialise(string dbfile, string dbname) + override public void Initialise(string dbconnect) { - m_conn = new SqliteConnection("URI=file:" + dbfile + ",version=3"); + if (dbconnect == string.Empty) { + dbconnect = "URI=file:AssetStorage.db,version=3"; + } + m_conn = new SqliteConnection(dbconnect); m_conn.Open(); TestTables(m_conn); return; @@ -289,7 +292,7 @@ namespace OpenSim.Data.SQLite override public void Initialise() { - Initialise("AssetStorage.db", ""); + Initialise("URI=file:AssetStorage.db,version=3"); } override public string Name -- cgit v1.1