Menu
Forums
All threads
Latest threads
New posts
Trending threads
New posts
Search forums
Trending
What's new
New posts
New profile posts
Latest activity
Members
Current visitors
New profile posts
Search profile posts
Upgrades
Log in
Register
What's new
Search
Search
Search titles only
By:
All threads
Latest threads
New posts
Trending threads
New posts
Search forums
Menu
Log in
Register
Navigation
Install the app
Install
More options
Contact us
Close Menu
Forums
Server Development
Habbo Retros
Habbo Q&A
How To Fix The Chatlogs In Snowlight
JavaScript is disabled. For a better experience, please enable JavaScript in your browser before proceeding.
You are using an out of date browser. It may not display this or other websites correctly.
You should upgrade or use an
alternative browser
.
Reply to thread
Message
<blockquote data-quote="Myworld" data-source="post: 53365" data-attributes="member: 3839"><p><span style="font-size: 15px">First We</span> <span style="font-size: 15px"><span style="font-family: 'Georgia'">Go to Game -> Moderation -> ModerationLogs.cs and We Remplace it With :</span></span></p><p>[CODE]using System;</p><p>using System.Data;</p><p>using System.Collections.Generic;</p><p>using System.Collections.ObjectModel;</p><p></p><p>using SnowLight.Storage;</p><p>using SnowLight.Game.Rooms;</p><p>using SnowLight.Specialized;</p><p></p><p>using SnowLight.Game.Sessions;</p><p>using SnowLight.Config;</p><p></p><p>namespace SnowLight.Game.Moderation</p><p>{</p><p> public static class ModerationLogs</p><p> {</p><p> public static void LogChatMessage(SqlDatabaseClient MySqlClient, uint UserId, uint RoomId, string Message)</p><p> {</p><p></p><p> MySqlClient.SetParameter("userid", UserId);</p><p> MySqlClient.SetParameter("roomid", RoomId);</p><p> MySqlClient.SetParameter("message", Message);</p><p> MySqlClient.SetParameter("timestamp", UnixTimestamp.GetCurrent());</p><p> MySqlClient.ExecuteNonQuery("INSERT INTO moderation_chatlogs (user_id,room_id,message,timestamp) VALUES (@userid,@roomid,@message,@timestamp)");</p><p> }</p><p></p><p> public static void LogRoomEntry(uint UserId, uint RoomId)</p><p> {</p><p> using (SqlDatabaseClient MySqlClient = SqlDatabaseManager.GetClient())</p><p> {</p><p> double Stamp = UnixTimestamp.GetCurrent();</p><p></p><p> MySqlClient.SetParameter("userid", UserId);</p><p> MySqlClient.SetParameter("timestamp", Stamp);</p><p> MySqlClient.ExecuteNonQuery("UPDATE room_visits SET timestamp_left = @timestamp WHERE user_id = @userid AND timestamp_left = 0 LIMIT 1");</p><p></p><p> MySqlClient.SetParameter("userid", UserId);</p><p> MySqlClient.SetParameter("roomid", RoomId);</p><p> MySqlClient.SetParameter("timestamp", Stamp);</p><p> MySqlClient.ExecuteNonQuery("INSERT INTO room_visits (user_id,room_id,timestamp_entered) VALUES (@userid,@roomid,@timestamp)");</p><p> }</p><p> }</p><p></p><p> public static ReadOnlyCollection<ModerationRoomVisit> GetRoomVistsForUser(uint UserId, double FromTimestamp)</p><p> {</p><p> List<ModerationRoomVisit> Visits = new List<ModerationRoomVisit>();</p><p></p><p> using (SqlDatabaseClient MySqlClient = SqlDatabaseManager.GetClient())</p><p> {</p><p> MySqlClient.SetParameter("userid", UserId);</p><p> MySqlClient.SetParameter("timestamp", FromTimestamp);</p><p> DataTable Table = MySqlClient.ExecuteQueryTable("SELECT room_id,timestamp_entered,timestamp_left FROM room_visits WHERE user_id = @userid AND timestamp_entered >= @timestamp ORDER BY timestamp_entered DESC");</p><p></p><p> foreach (DataRow Row in Table.Rows)</p><p> {</p><p> Visits.Add(new ModerationRoomVisit((uint)Row["room_id"], (double)Row["timestamp_entered"],</p><p> (double)Row["timestamp_left"]));</p><p> }</p><p> }</p><p></p><p> return Visits.AsReadOnly();</p><p> }</p><p></p><p> public static Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>> GetLogsForUser(uint UserId, double FromTimestamp)</p><p> {</p><p></p><p> Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>> Entries =</p><p> new Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>>();</p><p> ReadOnlyCollection<ModerationRoomVisit> Visits = GetRoomVistsForUser(UserId, FromTimestamp);</p><p></p><p> foreach (ModerationRoomVisit Visit in Visits)</p><p> {</p><p> Entries.Add(Visit, GetLogsForRoom(Visit.RoomId, Visit.TimestampEntered, Visit.TimestampLeft > 0 ?</p><p> Visit.TimestampLeft : UnixTimestamp.GetCurrent()));</p><p> }</p><p></p><p> return new Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>>(Entries);</p><p> }</p><p></p><p> public static ReadOnlyCollection<ModerationChatlogEntry> GetLogsForRoom(uint RoomId, double FromTimestamp, double ToTimestamp)</p><p> {</p><p> List<ModerationChatlogEntry> Entries = new List<ModerationChatlogEntry>();</p><p></p><p> using (SqlDatabaseClient MySqlClient = SqlDatabaseManager.GetClient())</p><p> {</p><p> MySqlClient.SetParameter("roomid", RoomId);</p><p> MySqlClient.SetParameter("timestamp_from", FromTimestamp);</p><p> MySqlClient.SetParameter("timestamp_to", ToTimestamp);</p><p></p><p> DataTable Table = MySqlClient.ExecuteQueryTable("SELECT user_id,room_id,timestamp,message FROM moderation_chatlogs WHERE room_id = @roomid AND timestamp >= @timestamp_from AND timestamp <= @timestamp_to ORDER BY timestamp DESC");</p><p></p><p> foreach (DataRow Row in Table.Rows)</p><p> {</p><p> Entries.Add(new ModerationChatlogEntry((uint)Row["user_id"], (uint)Row["room_id"], (double)Row["timestamp"],</p><p> (string)Row["message"]));</p><p> }</p><p> }</p><p></p><p> return Entries.AsReadOnly();</p><p> }</p><p></p><p> public static void LogModerationAction(SqlDatabaseClient MySqlClient, Session Session, string ActionDescr, string ActionDetail)</p><p> {</p><p> MySqlClient.SetParameter("userid", Session.CharacterId);</p><p> MySqlClient.SetParameter("username", Session.CharacterInfo.Username);</p><p> MySqlClient.SetParameter("timestamp", UnixTimestamp.GetCurrent());</p><p> MySqlClient.SetParameter("actiondescr", ActionDescr);</p><p> MySqlClient.SetParameter("actiondetail", ActionDetail);</p><p> MySqlClient.ExecuteNonQuery("INSERT INTO moderation_action_log (moderator_id,moderator_name,action_descr,action_detail,timestamp) VALUES (@userid,@username,@actiondescr,@actiondetail,@timestamp)");</p><p> }</p><p> }</p><p>}</p><p>[/CODE]</p><p></p><p>Good bye Annd U Welcome</p></blockquote><p></p>
[QUOTE="Myworld, post: 53365, member: 3839"] [SIZE=4]First We[/SIZE] [SIZE=15px][FONT=Georgia]Go to Game -> Moderation -> ModerationLogs.cs and We Remplace it With :[/FONT][/SIZE] [CODE]using System; using System.Data; using System.Collections.Generic; using System.Collections.ObjectModel; using SnowLight.Storage; using SnowLight.Game.Rooms; using SnowLight.Specialized; using SnowLight.Game.Sessions; using SnowLight.Config; namespace SnowLight.Game.Moderation { public static class ModerationLogs { public static void LogChatMessage(SqlDatabaseClient MySqlClient, uint UserId, uint RoomId, string Message) { MySqlClient.SetParameter("userid", UserId); MySqlClient.SetParameter("roomid", RoomId); MySqlClient.SetParameter("message", Message); MySqlClient.SetParameter("timestamp", UnixTimestamp.GetCurrent()); MySqlClient.ExecuteNonQuery("INSERT INTO moderation_chatlogs (user_id,room_id,message,timestamp) VALUES (@userid,@roomid,@message,@timestamp)"); } public static void LogRoomEntry(uint UserId, uint RoomId) { using (SqlDatabaseClient MySqlClient = SqlDatabaseManager.GetClient()) { double Stamp = UnixTimestamp.GetCurrent(); MySqlClient.SetParameter("userid", UserId); MySqlClient.SetParameter("timestamp", Stamp); MySqlClient.ExecuteNonQuery("UPDATE room_visits SET timestamp_left = @timestamp WHERE user_id = @userid AND timestamp_left = 0 LIMIT 1"); MySqlClient.SetParameter("userid", UserId); MySqlClient.SetParameter("roomid", RoomId); MySqlClient.SetParameter("timestamp", Stamp); MySqlClient.ExecuteNonQuery("INSERT INTO room_visits (user_id,room_id,timestamp_entered) VALUES (@userid,@roomid,@timestamp)"); } } public static ReadOnlyCollection<ModerationRoomVisit> GetRoomVistsForUser(uint UserId, double FromTimestamp) { List<ModerationRoomVisit> Visits = new List<ModerationRoomVisit>(); using (SqlDatabaseClient MySqlClient = SqlDatabaseManager.GetClient()) { MySqlClient.SetParameter("userid", UserId); MySqlClient.SetParameter("timestamp", FromTimestamp); DataTable Table = MySqlClient.ExecuteQueryTable("SELECT room_id,timestamp_entered,timestamp_left FROM room_visits WHERE user_id = @userid AND timestamp_entered >= @timestamp ORDER BY timestamp_entered DESC"); foreach (DataRow Row in Table.Rows) { Visits.Add(new ModerationRoomVisit((uint)Row["room_id"], (double)Row["timestamp_entered"], (double)Row["timestamp_left"])); } } return Visits.AsReadOnly(); } public static Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>> GetLogsForUser(uint UserId, double FromTimestamp) { Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>> Entries = new Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>>(); ReadOnlyCollection<ModerationRoomVisit> Visits = GetRoomVistsForUser(UserId, FromTimestamp); foreach (ModerationRoomVisit Visit in Visits) { Entries.Add(Visit, GetLogsForRoom(Visit.RoomId, Visit.TimestampEntered, Visit.TimestampLeft > 0 ? Visit.TimestampLeft : UnixTimestamp.GetCurrent())); } return new Dictionary<ModerationRoomVisit, ReadOnlyCollection<ModerationChatlogEntry>>(Entries); } public static ReadOnlyCollection<ModerationChatlogEntry> GetLogsForRoom(uint RoomId, double FromTimestamp, double ToTimestamp) { List<ModerationChatlogEntry> Entries = new List<ModerationChatlogEntry>(); using (SqlDatabaseClient MySqlClient = SqlDatabaseManager.GetClient()) { MySqlClient.SetParameter("roomid", RoomId); MySqlClient.SetParameter("timestamp_from", FromTimestamp); MySqlClient.SetParameter("timestamp_to", ToTimestamp); DataTable Table = MySqlClient.ExecuteQueryTable("SELECT user_id,room_id,timestamp,message FROM moderation_chatlogs WHERE room_id = @roomid AND timestamp >= @timestamp_from AND timestamp <= @timestamp_to ORDER BY timestamp DESC"); foreach (DataRow Row in Table.Rows) { Entries.Add(new ModerationChatlogEntry((uint)Row["user_id"], (uint)Row["room_id"], (double)Row["timestamp"], (string)Row["message"])); } } return Entries.AsReadOnly(); } public static void LogModerationAction(SqlDatabaseClient MySqlClient, Session Session, string ActionDescr, string ActionDetail) { MySqlClient.SetParameter("userid", Session.CharacterId); MySqlClient.SetParameter("username", Session.CharacterInfo.Username); MySqlClient.SetParameter("timestamp", UnixTimestamp.GetCurrent()); MySqlClient.SetParameter("actiondescr", ActionDescr); MySqlClient.SetParameter("actiondetail", ActionDetail); MySqlClient.ExecuteNonQuery("INSERT INTO moderation_action_log (moderator_id,moderator_name,action_descr,action_detail,timestamp) VALUES (@userid,@username,@actiondescr,@actiondetail,@timestamp)"); } } } [/CODE] Good bye Annd U Welcome [/QUOTE]
Insert quotes…
Verification
Post reply
Forums
Server Development
Habbo Retros
Habbo Q&A
How To Fix The Chatlogs In Snowlight
Top