From e1140a4f9ba4b0d6b62002927dcde27d85a22ff0 Mon Sep 17 00:00:00 2001
From: Sean Dague
Date: Thu, 12 Jun 2008 15:47:33 +0000
Subject: this, in theory, adds migration support to mysql for all data sources
besides the grid store. It is only lightly tested so the less adventurous
should wait a couple of checkins before upgrading.
---
OpenSim/Data/MySQL/MySQLAssetData.cs | 84 ++++++++++-------
OpenSim/Data/MySQL/MySQLDataStore.cs | 156 +++++++++++++++++--------------
OpenSim/Data/MySQL/MySQLInventoryData.cs | 34 ++++++-
OpenSim/Data/MySQL/MySQLUserData.cs | 32 ++++++-
4 files changed, 194 insertions(+), 112 deletions(-)
(limited to 'OpenSim')
diff --git a/OpenSim/Data/MySQL/MySQLAssetData.cs b/OpenSim/Data/MySQL/MySQLAssetData.cs
index a2215ef..f51eee2 100644
--- a/OpenSim/Data/MySQL/MySQLAssetData.cs
+++ b/OpenSim/Data/MySQL/MySQLAssetData.cs
@@ -42,6 +42,48 @@ namespace OpenSim.Data.MySQL
private MySQLManager _dbConnection;
+ #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.
+ if (connect == String.Empty)
+ {
+ // This is old seperate config file
+ m_log.Warn("no connect string, using old mysql_connection.ini instead");
+ Initialise();
+ }
+ else
+ {
+ _dbConnection = new MySQLManager(connect);
+ }
+
+ // This actually does the roll forward assembly stuff
+ Assembly assem = GetType().Assembly;
+ Migration m = new Migration(_dbConnection.Connection, assem, "AssetStore");
+
+ // TODO: After rev 6000, remove this. People should have
+ // been rolled onto the new migration code by then.
+ TestTables(m);
+
+ m.Update();
+ }
+
+ override public void Initialise()
+ {
+ IniFile GridDataMySqlFile = new IniFile("mysql_connection.ini");
+ string hostname = GridDataMySqlFile.ParseFileReadValue("hostname");
+ string database = GridDataMySqlFile.ParseFileReadValue("database");
+ string username = GridDataMySqlFile.ParseFileReadValue("username");
+ string password = GridDataMySqlFile.ParseFileReadValue("password");
+ string pooling = GridDataMySqlFile.ParseFileReadValue("pooling");
+ string port = GridDataMySqlFile.ParseFileReadValue("port");
+
+ _dbConnection = new MySQLManager(hostname, database, username, password, pooling, port);
+
+ }
+
#region IAssetProvider Members
private void UpgradeAssetsTable(string oldVersion)
@@ -58,14 +100,20 @@ namespace OpenSim.Data.MySQL
///
/// Ensure that the assets related tables exists and are at the latest version
///
- private void TestTables()
+ private void TestTables(Migration m)
{
Dictionary tableList = new Dictionary();
tableList["assets"] = null;
_dbConnection.GetTableVersion(tableList);
- UpgradeAssetsTable(tableList["assets"]);
+ // if there is no table, return, migrations will handle it.
+ if (tableList["assets"] == null)
+ return;
+
+ // if there is a table, and we don't have a migration, set it to 1
+ if (m.Version == 0)
+ m.Version = 1;
}
override public AssetBase FetchAsset(LLUUID assetID)
@@ -208,38 +256,6 @@ namespace OpenSim.Data.MySQL
#endregion
- #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.
- if (connect == String.Empty)
- {
- // This is old seperate config file
- Initialise();
- }
- else
- {
- _dbConnection = new MySQLManager(connect);
- TestTables();
- }
- }
-
- override public void Initialise()
- {
- IniFile GridDataMySqlFile = new IniFile("mysql_connection.ini");
- string hostname = GridDataMySqlFile.ParseFileReadValue("hostname");
- string database = GridDataMySqlFile.ParseFileReadValue("database");
- string username = GridDataMySqlFile.ParseFileReadValue("username");
- string password = GridDataMySqlFile.ParseFileReadValue("password");
- string pooling = GridDataMySqlFile.ParseFileReadValue("pooling");
- string port = GridDataMySqlFile.ParseFileReadValue("port");
-
- _dbConnection = new MySQLManager(hostname, database, username, password, pooling, port);
-
- TestTables();
- }
override public string Version
{
diff --git a/OpenSim/Data/MySQL/MySQLDataStore.cs b/OpenSim/Data/MySQL/MySQLDataStore.cs
index a38a8b2..60aca7a 100644
--- a/OpenSim/Data/MySQL/MySQLDataStore.cs
+++ b/OpenSim/Data/MySQL/MySQLDataStore.cs
@@ -91,7 +91,16 @@ namespace OpenSim.Data.MySQL
m_log.Info("[REGION DB]: MySql - connecting: " + connectionstring);
m_connection = new MySqlConnection(connectionstring);
- TestTablesVersionable(m_connection);
+ // This actually does the roll forward assembly stuff
+ Assembly assem = GetType().Assembly;
+ Migration m = new Migration(m_connection, assem, "RegionStore");
+
+ // TODO: After rev 6000, remove this. People should have
+ // been rolled onto the new migration code by then.
+ TestTables(m_connection, m);
+
+ m.Update();
+
MySqlCommand primSelectCmd = new MySqlCommand(m_primSelect, m_connection);
m_primDataAdapter = new MySqlDataAdapter(primSelectCmd);
@@ -112,8 +121,6 @@ namespace OpenSim.Data.MySQL
m_landAccessListDataAdapter = new MySqlDataAdapter(landAccessListSelectCmd);
- TestTables(m_connection);
-
lock (m_dataSet)
{
m_primTable = createPrimTable();
@@ -185,18 +192,18 @@ namespace OpenSim.Data.MySQL
}
}
}
- private void TestTablesVersionable(MySqlConnection dbconn)
- {
- Dictionary tableList = new Dictionary();
+ // private void TestTablesVersionable(MySqlConnection dbconn)
+ // {
+ // Dictionary tableList = new Dictionary();
- tableList["land"] = null;
- dbconn.Open();
- GetTableVersion(tableList,dbconn);
+ // tableList["land"] = null;
+ // dbconn.Open();
+ // GetTableVersion(tableList,dbconn);
- UpgradeLandTable(tableList["land"], dbconn);
- //database.Close();
+ // UpgradeLandTable(tableList["land"], dbconn);
+ // //database.Close();
- }
+ // }
///
/// Execute a SQL statement stored in a resource, as a string
@@ -1660,7 +1667,7 @@ namespace OpenSim.Data.MySQL
conn.Close();
}
- private bool TestTables(MySqlConnection conn)
+ private bool TestTables(MySqlConnection conn, Migration m)
{
MySqlCommand primSelectCmd = new MySqlCommand(m_primSelect, conn);
MySqlDataAdapter pDa = new MySqlDataAdapter(primSelectCmd);
@@ -1681,8 +1688,7 @@ namespace OpenSim.Data.MySQL
pDa.Fill(tmpDS, "prims");
sDa.Fill(tmpDS, "primshapes");
- if (persistPrimInventories)
- iDa.Fill(tmpDS, "primitems");
+ iDa.Fill(tmpDS, "primitems");
tDa.Fill(tmpDS, "terrain");
lDa.Fill(tmpDS, "land");
@@ -1691,67 +1697,73 @@ namespace OpenSim.Data.MySQL
catch (MySqlException)
{
m_log.Info("[DATASTORE]: MySql Database doesn't exist... creating");
- InitDB(conn);
+ return false;
}
- pDa.Fill(tmpDS, "prims");
- sDa.Fill(tmpDS, "primshapes");
-
- if (persistPrimInventories)
- iDa.Fill(tmpDS, "primitems");
-
- tDa.Fill(tmpDS, "terrain");
- lDa.Fill(tmpDS, "land");
- lalDa.Fill(tmpDS, "landaccesslist");
-
- foreach (DataColumn col in createPrimTable().Columns)
- {
- if (!tmpDS.Tables["prims"].Columns.Contains(col.ColumnName))
- {
- m_log.Info("[REGION DB]: Missing required column:" + col.ColumnName);
- return false;
- }
- }
-
- foreach (DataColumn col in createShapeTable().Columns)
- {
- if (!tmpDS.Tables["primshapes"].Columns.Contains(col.ColumnName))
- {
- m_log.Info("[REGION DB]: Missing required column:" + col.ColumnName);
- return false;
- }
- }
-
- // XXX primitems should probably go here eventually
-
- foreach (DataColumn col in createTerrainTable().Columns)
- {
- if (!tmpDS.Tables["terrain"].Columns.Contains(col.ColumnName))
- {
- m_log.Info("[REGION DB]: Missing require column:" + col.ColumnName);
- return false;
- }
- }
-
- foreach (DataColumn col in createLandTable().Columns)
- {
- if (!tmpDS.Tables["land"].Columns.Contains(col.ColumnName))
- {
- m_log.Info("[REGION DB]: Missing require column:" + col.ColumnName);
- return false;
- }
- }
-
- foreach (DataColumn col in createLandAccessListTable().Columns)
- {
- if (!tmpDS.Tables["landaccesslist"].Columns.Contains(col.ColumnName))
- {
- m_log.Info("[DATASTORE]: Missing require column:" + col.ColumnName);
- return false;
- }
- }
+ // we have tables, but not a migration model yet
+ if (m.Version == 0)
+ m.Version = 1;
return true;
+
+ // pDa.Fill(tmpDS, "prims");
+ // sDa.Fill(tmpDS, "primshapes");
+
+ // if (persistPrimInventories)
+ // iDa.Fill(tmpDS, "primitems");
+
+ // tDa.Fill(tmpDS, "terrain");
+ // lDa.Fill(tmpDS, "land");
+ // lalDa.Fill(tmpDS, "landaccesslist");
+
+ // foreach (DataColumn col in createPrimTable().Columns)
+ // {
+ // if (!tmpDS.Tables["prims"].Columns.Contains(col.ColumnName))
+ // {
+ // m_log.Info("[REGION DB]: Missing required column:" + col.ColumnName);
+ // return false;
+ // }
+ // }
+
+ // foreach (DataColumn col in createShapeTable().Columns)
+ // {
+ // if (!tmpDS.Tables["primshapes"].Columns.Contains(col.ColumnName))
+ // {
+ // m_log.Info("[REGION DB]: Missing required column:" + col.ColumnName);
+ // return false;
+ // }
+ // }
+
+ // // XXX primitems should probably go here eventually
+
+ // foreach (DataColumn col in createTerrainTable().Columns)
+ // {
+ // if (!tmpDS.Tables["terrain"].Columns.Contains(col.ColumnName))
+ // {
+ // m_log.Info("[REGION DB]: Missing require column:" + col.ColumnName);
+ // return false;
+ // }
+ // }
+
+ // foreach (DataColumn col in createLandTable().Columns)
+ // {
+ // if (!tmpDS.Tables["land"].Columns.Contains(col.ColumnName))
+ // {
+ // m_log.Info("[REGION DB]: Missing require column:" + col.ColumnName);
+ // return false;
+ // }
+ // }
+
+ // foreach (DataColumn col in createLandAccessListTable().Columns)
+ // {
+ // if (!tmpDS.Tables["landaccesslist"].Columns.Contains(col.ColumnName))
+ // {
+ // m_log.Info("[DATASTORE]: Missing require column:" + col.ColumnName);
+ // return false;
+ // }
+ // }
+
+ // return true;
}
/***********************************************************************
diff --git a/OpenSim/Data/MySQL/MySQLInventoryData.cs b/OpenSim/Data/MySQL/MySQLInventoryData.cs
index 8e160b7..1b86abf 100644
--- a/OpenSim/Data/MySQL/MySQLInventoryData.cs
+++ b/OpenSim/Data/MySQL/MySQLInventoryData.cs
@@ -69,7 +69,16 @@ namespace OpenSim.Data.MySQL
new MySQLManager(settingHostname, settingDatabase, settingUsername, settingPassword, settingPooling,
settingPort);
}
- TestTables(database.Connection);
+
+ // This actually does the roll forward assembly stuff
+ Assembly assem = GetType().Assembly;
+ Migration m = new Migration(database.Connection, assem, "AssetStore");
+
+ // TODO: After rev 6000, remove this. People should have
+ // been rolled onto the new migration code by then.
+ TestTables(database.Connection, m);
+
+ m.Update();
}
#region Test and initialization code
@@ -107,7 +116,7 @@ namespace OpenSim.Data.MySQL
}
}
- private void TestTables(MySqlConnection conn)
+ private void TestTables(MySqlConnection conn, Migration m)
{
Dictionary tableList = new Dictionary();
@@ -115,11 +124,28 @@ namespace OpenSim.Data.MySQL
tableList["inventoryitems"] = null;
database.GetTableVersion(tableList);
- m_log.Info("[INVENTORY DB]: Inventory Folder Version: " + tableList["inventoryfolders"]);
- m_log.Info("[INVENTORY DB]: Inventory Items Version: " + tableList["inventoryitems"]);
+ // if we've already started using migrations, get out of
+ // here, we've got this under control
+ if (m.Version > 0)
+ return;
+
+ // if there are no tables, get out of here and let
+ // migrations do their job
+ if(
+ tableList["inventoryfolders"] == null &&
+ tableList["inventoryitems"] == null
+ )
+ return;
+
+ // otherwise, let the upgrade on legacy proceed...
UpgradeFoldersTable(tableList["inventoryfolders"]);
UpgradeItemsTable(tableList["inventoryitems"]);
+
+ // ... and set the version
+ if (m.Version == 0)
+ m.Version = 1;
+
}
#endregion
diff --git a/OpenSim/Data/MySQL/MySQLUserData.cs b/OpenSim/Data/MySQL/MySQLUserData.cs
index f717609..7d2da3a 100644
--- a/OpenSim/Data/MySQL/MySQLUserData.cs
+++ b/OpenSim/Data/MySQL/MySQLUserData.cs
@@ -105,7 +105,15 @@ namespace OpenSim.Data.MySQL
database = new MySQLManager(m_connectString);
}
- TestTables();
+ // This actually does the roll forward assembly stuff
+ Assembly assem = GetType().Assembly;
+ Migration m = new Migration(database.Connection, assem, "AssetStore");
+
+ // TODO: After rev 6000, remove this. People should have
+ // been rolled onto the new migration code by then.
+ TestTables(m);
+
+ m.Update();
}
#region Test and initialization code
@@ -113,7 +121,7 @@ namespace OpenSim.Data.MySQL
///
/// Ensure that the user related tables exists and are at the latest version
///
- private void TestTables()
+ private void TestTables(Migration m)
{
Dictionary tableList = new Dictionary();
@@ -123,10 +131,30 @@ namespace OpenSim.Data.MySQL
tableList[m_appearanceTableName] = null;
database.GetTableVersion(tableList);
+ // if we've already started using migrations, get out of
+ // here, we've got this under control
+ if (m.Version > 0)
+ return;
+
+ // if there are no tables, get out of here and let
+ // migrations do their job
+ if(
+ tableList[m_agentsTableName] == null &&
+ tableList[m_usersTableName] == null &&
+ tableList[m_userFriendsTableName] == null &&
+ tableList[m_appearanceTableName] == null
+ )
+ return;
+
+ // otherwise, let the upgrade on legacy proceed...
UpgradeAgentsTable(tableList[m_agentsTableName]);
UpgradeUsersTable(tableList[m_usersTableName]);
UpgradeFriendsTable(tableList[m_userFriendsTableName]);
UpgradeAppearanceTable(tableList[m_appearanceTableName]);
+
+ // ... and set the version
+ if (m.Version == 0)
+ m.Version = 1;
}
///
--
cgit v1.1