using System; using System.Data; using System.Collections; using System.Threading; using Ion.Storage; namespace Holo.Managers { /// /// Provides functions and tasks for the item Recycler, which allows users to trade in their items for special items. /// public static class recyclerManager { private static int sessionLength; private static int sessionExpireLength; private static int itemMinOwnershipLength; private static Hashtable sessionRewards; public static string setupString; /// /// Initializes the item Recycler, determining the state and creating the setup string. /// public static void Init(bool Update) { if (Config.getTableEntry("recycler_enable") == "1") { Config.enableRecycler = true; Out.WriteLine("Initializing recycler..."); DataTable dTable; using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { dTable = dbClient.getTable("SELECT rclr_cost, rclr_reward FROM system_recycler"); } sessionLength = int.Parse(Config.getTableEntry("recycler_session_length")); sessionExpireLength = int.Parse(Config.getTableEntry("recycler_session_expirelength")); itemMinOwnershipLength = int.Parse(Config.getTableEntry("recycler_minownertime")); sessionRewards = new Hashtable(); setupString = "I" + Encoding.encodeVL64(itemMinOwnershipLength) + Encoding.encodeVL64(sessionLength) + Encoding.encodeVL64(sessionExpireLength) + Encoding.encodeVL64(dTable.Rows.Count); foreach (DataRow dRow in dTable.Rows) { catalogueManager.itemTemplate Template = catalogueManager.getTemplate(Convert.ToInt32(dRow["rclr_reward"])); if (Template.Sprite != "") { sessionRewards.Add(Convert.ToInt32(dRow["rclr_cost"]), Convert.ToInt32(dRow["rclr_reward"])); setupString += Encoding.encodeVL64(Convert.ToInt32(dRow["rclr_cost"])) + "H" + Template.Sprite + Convert.ToChar(2) + "H" + Encoding.encodeVL64(Template.Length) + Encoding.encodeVL64(Template.Width) + Convert.ToChar(2); //setupString += Encoding.encodeVL64(rclrCosts[i]) + "H" + Template.cctName + Convert.ToChar(2) + "HJI" + Convert.ToChar(2); } } Out.WriteLine("Recycler enabled."); } else { setupString = "H"; Out.WriteLine("Recycler disabled."); } if (Update) Thread.CurrentThread.Abort(); } #region Session management /// /// Determines if there exists a reward for this amount of brought in items. /// /// The amount of items brought in. public static bool rewardExists(int itemCount) { return sessionRewards.ContainsKey(itemCount); } /// /// Creates a Recycler session for this user in the users_recycler table, with the userid, the timestamp where the session started and the reward template ID matching this amount of brought of items. /// /// The ID of the user who requests a Recycler session. /// The amount of items the user brought in. public static void createSession(int userID, int itemCount) { int rewardTemplateID = ((int)sessionRewards[itemCount]); using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { dbClient.AddParamWithValue("userID", userID); dbClient.AddParamWithValue("dateTime", DateTime.Now.ToString()); dbClient.AddParamWithValue("rewardTemplateID", rewardTemplateID); dbClient.runQuery("INSERT INTO users_recycler(userid,session_started,session_reward) VALUES (@userID, @dateTime, @rewardTemplateID)"); } } /// /// Deletes the user's session row in users_recycler, and brings items back to the users hand OR deletes them permanently from the database. /// /// The ID of the user who owns this session. /// When true, the items will be deleted from database, else the items will return back to the users Hand. public static void dropSession(int userID, bool dropItems) { using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { dbClient.runQuery("DELETE FROM users_recycler WHERE userid = '" + userID + "' LIMIT 1"); if (dropItems) dbClient.runQuery("DELETE FROM furniture WHERE ownerid = '" + userID + "' AND roomid = '-2'"); else dbClient.runQuery("UPDATE furniture SET roomid = '0' WHERE ownerid = '" + userID + "' AND roomid = '-2'"); } } /// /// Creates the reward for the user and handles special items such as teleporters, so user receives a pair etc. /// /// The ID of the user to reward the session of. public static void rewardSession(int userID) { int rewardTemplateID = sessionRewardID(userID); using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { dbClient.AddParamWithValue("reward", sessionRewardID(userID)); dbClient.AddParamWithValue("userID", userID); dbClient.runQuery("INSERT INTO furniture(tid,ownerid, roomid) VALUES (@reward, @userID, '0')"); } catalogueManager.handlePurchase(rewardTemplateID, userID, 0, "0", 0, 0); } /// /// Returns the amount of passed minutes since the user's session started. If the user hasn't got a session or any other error occurs, 0 is returned. /// /// The user ID of the session to lookup. public static int passedMinutes(int userID) { try { TimeSpan Span; using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { Span = DateTime.Now - DateTime.Parse(dbClient.getString("SELECT session_started FROM users_recycler WHERE userid = '" + userID + "' LIMIT 1")); } return Convert.ToInt32(Span.TotalMinutes); } catch { return 0; } } /// /// Returns the session string for a users session to use with the "Dp" packet. /// /// The ID of the user to retrieve the session string for. public static string sessionString(int userID) { if (Config.enableRecycler == false) return "H"; using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { if (dbClient.findsResult("SELECT * FROM users_recycler WHERE userid = '" + userID + "'") == false) return "H"; } int minutesPassed = passedMinutes(userID); if (minutesPassed < sessionLength) return "IH" + catalogueManager.getTemplate(sessionRewardID(userID)).Sprite + Convert.ToChar(2) + Encoding.encodeVL64(sessionLength - minutesPassed); if (minutesPassed > sessionLength) return "JH" + catalogueManager.getTemplate(sessionRewardID(userID)).Sprite + Convert.ToChar(2); if (minutesPassed > sessionExpireLength) return "K"; return "H"; } /// /// Returns a bool that indicates if a user has a session. /// /// The ID of the user to check for sessions. public static bool sessionExists(int userID) { using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { return dbClient.findsResult("SELECT userid FROM users_recycler WHERE userid = '" + userID + "'"); } } /// /// Returns a bool that indicates if a user's session is ready and hasn't expired yet /// /// The user ID of the user to lookup the session of. public static bool sessionReady(int userID) { if (sessionExists(userID)) { int minutesPassed = passedMinutes(userID); if ((minutesPassed > sessionLength) & (minutesPassed < sessionExpireLength)) return true; } return false; } /// /// Returns the template ID of reward item of the session of a user. /// /// The user ID of the session to lookup. private static int sessionRewardID(int userID) { using (DatabaseClient dbClient = Eucalypt.dbManager.GetClient()) { return dbClient.getInt("SELECT session_reward FROM users_recycler WHERE userid = '" + userID + "'"); } } #endregion } }