From e32efe5d22d5a062e07d4052541cdbe36fd9aa60 Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Sat, 20 Jan 2018 07:09:37 +0000 Subject: [PATCH] add sqlite files for mutes module ( done only minimal tests) --- .../SQLite/Resources/MuteListStore.migrations | 16 +++++ OpenSim/Data/SQLite/SQLiteMuteListData.cs | 71 +++++++++++++++++++ 2 files changed, 87 insertions(+) create mode 100644 OpenSim/Data/SQLite/Resources/MuteListStore.migrations create mode 100644 OpenSim/Data/SQLite/SQLiteMuteListData.cs diff --git a/OpenSim/Data/SQLite/Resources/MuteListStore.migrations b/OpenSim/Data/SQLite/Resources/MuteListStore.migrations new file mode 100644 index 0000000000..f981ded2af --- /dev/null +++ b/OpenSim/Data/SQLite/Resources/MuteListStore.migrations @@ -0,0 +1,16 @@ +:VERSION 1 + +BEGIN TRANSACTION; + +CREATE TABLE MuteList ( + AgentID char(36) NOT NULL, + MuteID char(36) NOT NULL DEFAULT '00000000-0000-0000-0000-000000000000', + MuteName varchar(64) NOT NULL DEFAULT '', + MuteType int(11) NOT NULL DEFAULT '1', + MuteFlags int(11) NOT NULL DEFAULT '0', + Stamp int(11) NOT NULL, + UNIQUE (AgentID, MuteID, MuteName), + PRIMARY KEY(AgentID) +); + +COMMIT; diff --git a/OpenSim/Data/SQLite/SQLiteMuteListData.cs b/OpenSim/Data/SQLite/SQLiteMuteListData.cs new file mode 100644 index 0000000000..80fd0192ad --- /dev/null +++ b/OpenSim/Data/SQLite/SQLiteMuteListData.cs @@ -0,0 +1,71 @@ +/* + * Copyright (c) Contributors, http://opensimulator.org/ + * See CONTRIBUTORS.TXT for a full list of copyright holders. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * * Neither the name of the OpenSimulator Project nor the + * names of its contributors may be used to endorse or promote products + * derived from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY + * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +using System; +using System.Collections; +using System.Collections.Generic; +using System.Data; +using OpenMetaverse; +using OpenSim.Framework; +#if CSharpSqlite + using Community.CsharpSqlite.Sqlite; +#else + using Mono.Data.Sqlite; +#endif + +namespace OpenSim.Data.SQLite +{ + public class SQLiteMuteListData : SQLiteGenericTableHandler, IMuteListData + { + public SQLiteMuteListData(string connectionString) + : base(connectionString, "MuteList", "MuteListStore") + { + } + + public MuteData[] Get(UUID agentID) + { + MuteData[] data = base.Get("AgentID", agentID.ToString()); + return data; + } + + public bool Delete(UUID agentID, UUID muteID, string muteName) + { + using (SqliteCommand cmd = new SqliteCommand()) + { + cmd.CommandText = "delete from MuteList where `AgentID` = :AgentID and `MuteID` = :MuteID and `MuteName` = :MuteName"; + + cmd.Parameters.AddWithValue(":AgentID", agentID.ToString()); + cmd.Parameters.AddWithValue(":MuteID", muteID.ToString()); + cmd.Parameters.AddWithValue(":MuteName", muteName); + + if (ExecuteNonQuery(cmd, m_Connection) > 0) + return true; + return false; + } + } + } +} \ No newline at end of file