From b92cb6126d8ca59121468fce44dc7b4c3b805181 Mon Sep 17 00:00:00 2001 From: Melanie Date: Fri, 5 Feb 2010 12:31:29 +0000 Subject: Implement the friends data adaptor --- OpenSim/Data/IFriendsData.cs | 4 ++-- OpenSim/Data/MySQL/MySQLFriendsData.cs | 19 +++++++++++++------ OpenSim/Data/MySQL/Resources/001_FriendsStore.sql | 5 +++++ OpenSim/Data/MySQL/Resources/002_FriendsStore.sql | 5 +++++ 4 files changed, 25 insertions(+), 8 deletions(-) create mode 100644 OpenSim/Data/MySQL/Resources/001_FriendsStore.sql create mode 100644 OpenSim/Data/MySQL/Resources/002_FriendsStore.sql (limited to 'OpenSim') diff --git a/OpenSim/Data/IFriendsData.cs b/OpenSim/Data/IFriendsData.cs index 7618976..1f1a031 100644 --- a/OpenSim/Data/IFriendsData.cs +++ b/OpenSim/Data/IFriendsData.cs @@ -45,7 +45,7 @@ namespace OpenSim.Data public interface IFriendsData { bool Store(FriendsData data); - bool Delete(UUID ownerID, UUID friendID); - FriendsData[] GetFriends(UUID owner); + bool Delete(UUID ownerID, string friend); + FriendsData[] GetFriends(UUID principalID); } } diff --git a/OpenSim/Data/MySQL/MySQLFriendsData.cs b/OpenSim/Data/MySQL/MySQLFriendsData.cs index 923810b..9f7e850 100644 --- a/OpenSim/Data/MySQL/MySQLFriendsData.cs +++ b/OpenSim/Data/MySQL/MySQLFriendsData.cs @@ -38,19 +38,26 @@ namespace OpenSim.Data.MySQL public class MySqlFriendsData : MySQLGenericTableHandler, IFriendsData { public MySqlFriendsData(string connectionString, string realm) - : base(connectionString, realm, "Friends") + : base(connectionString, realm, "FriendsStore") { } - public bool Delete(UUID principalID, UUID friendID) + public bool Delete(UUID principalID, string friend) { - // We need to delete the row where PrincipalID=principalID AND FriendID=firnedID - return false; + MySqlCommand cmd = new MySqlCommand(); + + cmd.CommandText = String.Format("delete from {0} where PrincipalID = ?PrincipalID and Friend = ?Friend", m_Realm); + cmd.Parameters.AddWithValue("?PrincipalID", principalID.ToString()); + cmd.Parameters.AddWithValue("?Friend", friend); + + ExecuteNonQuery(cmd); + + return true; } - public FriendsData[] GetFriends(UUID userID) + public FriendsData[] GetFriends(UUID principalID) { - return Get("PrincipalID =\'" + userID.ToString() + "'"); + return Get("PrincipalID", principalID.ToString()); } } } diff --git a/OpenSim/Data/MySQL/Resources/001_FriendsStore.sql b/OpenSim/Data/MySQL/Resources/001_FriendsStore.sql new file mode 100644 index 0000000..da2c59c --- /dev/null +++ b/OpenSim/Data/MySQL/Resources/001_FriendsStore.sql @@ -0,0 +1,5 @@ +BEGIN; + +CREATE TABLE `Friends` (`PrincipalID` CHAR(36) NOT NULL, `Friend` VARCHAR(255) NOT NULL, `Flags` VARCHAR(16) NOT NULL DEFAULT 0, `Offered` VARCHAR(32) NOT NULL DEFAULT 0, PRIMARY KEY(`PrincipalID`, `Friend`), KEY(`PrincipalID`)); + +COMMIT; diff --git a/OpenSim/Data/MySQL/Resources/002_FriendsStore.sql b/OpenSim/Data/MySQL/Resources/002_FriendsStore.sql new file mode 100644 index 0000000..a363867 --- /dev/null +++ b/OpenSim/Data/MySQL/Resources/002_FriendsStore.sql @@ -0,0 +1,5 @@ +BEGIN; + +INSERT INTO `Friends` SELECT `ownerID`, `friendID`, `friendPerms`, 0 FROM `userfriends`; + +COMMIT; -- cgit v1.1 From 1b44711ceb6f84c6eaa503d5d08ce30cb49a01e8 Mon Sep 17 00:00:00 2001 From: Melanie Date: Fri, 5 Feb 2010 13:11:33 +0000 Subject: Clarify some names --- OpenSim/Services/Interfaces/IFriendsService.cs | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) (limited to 'OpenSim') diff --git a/OpenSim/Services/Interfaces/IFriendsService.cs b/OpenSim/Services/Interfaces/IFriendsService.cs index ed77c1a..4e665cd 100644 --- a/OpenSim/Services/Interfaces/IFriendsService.cs +++ b/OpenSim/Services/Interfaces/IFriendsService.cs @@ -35,15 +35,14 @@ namespace OpenSim.Region.Framework.Interfaces { public UUID PrincipalID; public string Friend; - int MyRights; - int TheirRights; + int MyFlags; + int TheirFlags; } public interface IFriendsService { FriendInfo[] GetFriends(UUID PrincipalID); bool StoreFriend(UUID PrincipalID, string Friend, int flags); - bool SetFlags(UUID PrincipalID, int flags); bool Delete(UUID PrincipalID, string Friend); } } -- cgit v1.1