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 Tutorials
[NEW] Purchase LTDs Limit
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="Pollak" data-source="post: 454137" data-attributes="member: 77990"><p style="text-align: center"><strong>Hi!</strong> I coded this system and now I'm going to share it for everyone. <img src="/styles/default/xenforo/smilies/emojione/smile.png" class="smilie" loading="lazy" alt=":)" title="Smile :)" data-shortname=":)" /></p> <p style="text-align: center"></p> <p style="text-align: center"><strong>1</strong>- HabboHotel>Catalog>CatalogItem.cs</p> <p style="text-align: center">After OfferID, enter this code (ex: print)</p> <p style="text-align: center"></p> <p style="text-align: center">[CODE] public int LTDLimit { get; set; }</p> <p style="text-align: center">[/CODE]</p> <p style="text-align: center"></p> <p style="text-align: center">[ATTACH=full]9709[/ATTACH]</p> <p style="text-align: center"></p> <p style="text-align: center">Now in ' public CatalogItem( ' after int OfferID, add <strong>int LTDLimit </strong>(ex: print)</p> <p style="text-align: center"></p> <p style="text-align: center">[ATTACH=full]9710[/ATTACH]</p> <p style="text-align: center"></p> <p style="text-align: center">After ' this.OfferId = OfferId; ' add <strong>this.LTDLimit = LTDLimit; </strong>(ex: print)</p> <p style="text-align: center"></p> <p style="text-align: center">[ATTACH=full]9711[/ATTACH]</p> <p style="text-align: center"></p> <p style="text-align: center"><strong>2</strong>- HabboHotel>Catalog>CatalogManager.cs</p> <p style="text-align: center">In the query ' SELECT `id`,`item_id`,`catalog_name`,`cost_credits`,`cost_pixels`,`cost_diamonds`,`cost_gotw`... ' after offer_id add <strong>`ltd_limit` </strong>(ex: print)</p> <p style="text-align: center"></p> <p style="text-align: center">[ATTACH=full]9712[/ATTACH]</p> <p style="text-align: center"></p> <p style="text-align: center">Now in this._items[PageId].Add after Convert.ToInt32(Row["offer_id"]), add <strong>Convert.ToInt32(Row["ltd_limit"])</strong></p> <p style="text-align: center"></p> <p style="text-align: center"><strong>3- </strong>HabboHotel>Catalog>CatalogDeal (only if it exists)</p> <p style="text-align: center">In ItemDataList.Add(new CatalogItem( add more one <strong>,</strong> <strong>0</strong></p> <p style="text-align: center"></p> <p style="text-align: center"><strong>4-</strong> Communication>Packets>Incoming>Catalog>PurchaseFromCatalogEvent.cs</p> <p style="text-align: center">Below that add this code</p> <p style="text-align: center">if (Item.IsLimited)</p> <p style="text-align: center"> {</p><p>[CODE=csharp] #region Limit LTDs</p><p> if (Item.LTDLimit > 0)</p><p> {</p><p> using (IQueryAdapter dbclient = PlusEnvironment.GetDatabaseManager().GetQueryReactor())</p><p> {</p><p> dbclient.SetQuery("SELECT * FROM `catalog_user_ltds` WHERE `user_id`='" + Session.GetHabbo().Id + "' AND `catalog_id`='" + Item.Id + "'");</p><p> DataTable table = dbclient.getTable();</p><p></p><p> dbclient.SetQuery("SELECT COUNT(id) as count FROM `catalog_user_ltds` WHERE `user_id`='" + Session.GetHabbo().Id + "' AND `catalog_id`='" + Item.Id + "'");</p><p> DataTable tablecount = dbclient.getTable();</p><p></p><p> foreach (DataRow rows in table.Rows)</p><p> {</p><p> int CountLtds = Convert.ToInt32(rows["count"]);</p><p></p><p> if (table != null)</p><p> {</p><p> if (CountLtds >= Item.LTDLimit)</p><p> {</p><p> Session.SendMessage(new PurchaseErrorComposer(1));</p><p> Session.SendNotification("Limit LTD: " + Convert.ToString(Item.LTDLimit));</p><p> return;</p><p> }</p><p> }</p><p> }</p><p></p><p> foreach (DataRow row in tablecount.Rows)</p><p> {</p><p> if (tablecount != null)</p><p> {</p><p> if (Convert.ToInt32(row["count"]) == 0)</p><p> {</p><p> dbclient.RunQuery("INSERT INTO `catalog_user_ltds` (`user_id`, `base_id`, `catalog_id`, `count`, `last_purchase`) VALUES ('" + Session.GetHabbo().Id + "', '" + Item.ItemId + "', '" + Item.Id + "', '1', '" + PlusEnvironment.GetUnixTimestamp() + "')");</p><p> }</p><p> else</p><p> {</p><p> dbclient.RunQuery("UPDATE `catalog_user_ltds` SET `count` = `count` + 1, `last_purchase`='" + PlusEnvironment.GetUnixTimestamp() + "' WHERE `user_id`='" + Session.GetHabbo().Id + "' AND `catalog_id`='" + Item.Id + "'");</p><p> }</p><p> }</p><p> }</p><p> }</p><p> }</p><p></p><p> #endregion[/CODE]</p><p></p><p style="text-align: center"><strong>5</strong>- Insert the table into your database. </p><p>[CODE]CREATE TABLE `catalog_user_ltds` (</p><p> `id` INT(3) NOT NULL AUTO_INCREMENT,</p><p> `user_id` INT(11) NOT NULL,</p><p> `base_id` INT(11) NOT NULL,</p><p> `catalog_id` INT(11) NOT NULL,</p><p> `count` INT(3) NOT NULL,</p><p> `last_purchase` DOUBLE NOT NULL DEFAULT '0',</p><p> PRIMARY KEY (`id`),</p><p> INDEX `catalog_id` (`catalog_id`),</p><p> INDEX `base_id` (`base_id`)</p><p>)</p><p>COLLATE='latin1_swedish_ci'</p><p>ENGINE=InnoDB</p><p>AUTO_INCREMENT=1</p><p>;</p><p></p><p>ALTER TABLE `catalog_items`</p><p> ADD COLUMN `ltd_limit` INT(4) NOT NULL DEFAULT '0' AFTER `offer_id`;[/CODE]</p><p></p><p style="text-align: center">If you want to have a purchase limit per user for that particular item only change the value of ltd_limit to the limit quantity that the user can buy that item.</p> <p style="text-align: center">I'm sorry if I didn't explain how to add it, but if you already know how to move it will be easy to add.</p> <p style="text-align: center">If you have questions just comment! I appreciate your attention! <img src="/styles/default/xenforo/smilies/emojione/smile.png" class="smilie" loading="lazy" alt=":)" title="Smile :)" data-shortname=":)" /></p> <p style="text-align: center"></p> <p style="text-align: center"><strong>CREDITS: </strong></p> <p style="text-align: center"><strong>Snaiker (Pollak)</strong></p> <p style="text-align: center"></p> <p style="text-align: center"></p></blockquote><p></p>
[QUOTE="Pollak, post: 454137, member: 77990"] [CENTER][B]Hi![/B] I coded this system and now I'm going to share it for everyone. :) [B]1[/B]- HabboHotel>Catalog>CatalogItem.cs After OfferID, enter this code (ex: print) [CODE] public int LTDLimit { get; set; } [/CODE] [ATTACH=full]9709[/ATTACH] Now in ' public CatalogItem( ' after int OfferID, add [B]int LTDLimit [/B](ex: print) [ATTACH=full]9710[/ATTACH] After ' this.OfferId = OfferId; ' add [B]this.LTDLimit = LTDLimit; [/B](ex: print) [ATTACH=full]9711[/ATTACH] [B]2[/B]- HabboHotel>Catalog>CatalogManager.cs In the query ' SELECT `id`,`item_id`,`catalog_name`,`cost_credits`,`cost_pixels`,`cost_diamonds`,`cost_gotw`... ' after offer_id add [B]`ltd_limit` [/B](ex: print) [ATTACH=full]9712[/ATTACH] Now in this._items[PageId].Add after Convert.ToInt32(Row["offer_id"]), add [B]Convert.ToInt32(Row["ltd_limit"])[/B] [B]3- [/B]HabboHotel>Catalog>CatalogDeal (only if it exists) In ItemDataList.Add(new CatalogItem( add more one [B],[/B] [B]0[/B] [B]4-[/B] Communication>Packets>Incoming>Catalog>PurchaseFromCatalogEvent.cs Below that add this code if (Item.IsLimited) {[/CENTER] [CODE=csharp] #region Limit LTDs if (Item.LTDLimit > 0) { using (IQueryAdapter dbclient = PlusEnvironment.GetDatabaseManager().GetQueryReactor()) { dbclient.SetQuery("SELECT * FROM `catalog_user_ltds` WHERE `user_id`='" + Session.GetHabbo().Id + "' AND `catalog_id`='" + Item.Id + "'"); DataTable table = dbclient.getTable(); dbclient.SetQuery("SELECT COUNT(id) as count FROM `catalog_user_ltds` WHERE `user_id`='" + Session.GetHabbo().Id + "' AND `catalog_id`='" + Item.Id + "'"); DataTable tablecount = dbclient.getTable(); foreach (DataRow rows in table.Rows) { int CountLtds = Convert.ToInt32(rows["count"]); if (table != null) { if (CountLtds >= Item.LTDLimit) { Session.SendMessage(new PurchaseErrorComposer(1)); Session.SendNotification("Limit LTD: " + Convert.ToString(Item.LTDLimit)); return; } } } foreach (DataRow row in tablecount.Rows) { if (tablecount != null) { if (Convert.ToInt32(row["count"]) == 0) { dbclient.RunQuery("INSERT INTO `catalog_user_ltds` (`user_id`, `base_id`, `catalog_id`, `count`, `last_purchase`) VALUES ('" + Session.GetHabbo().Id + "', '" + Item.ItemId + "', '" + Item.Id + "', '1', '" + PlusEnvironment.GetUnixTimestamp() + "')"); } else { dbclient.RunQuery("UPDATE `catalog_user_ltds` SET `count` = `count` + 1, `last_purchase`='" + PlusEnvironment.GetUnixTimestamp() + "' WHERE `user_id`='" + Session.GetHabbo().Id + "' AND `catalog_id`='" + Item.Id + "'"); } } } } } #endregion[/CODE] [CENTER][B]5[/B]- Insert the table into your database. [/CENTER] [CODE]CREATE TABLE `catalog_user_ltds` ( `id` INT(3) NOT NULL AUTO_INCREMENT, `user_id` INT(11) NOT NULL, `base_id` INT(11) NOT NULL, `catalog_id` INT(11) NOT NULL, `count` INT(3) NOT NULL, `last_purchase` DOUBLE NOT NULL DEFAULT '0', PRIMARY KEY (`id`), INDEX `catalog_id` (`catalog_id`), INDEX `base_id` (`base_id`) ) COLLATE='latin1_swedish_ci' ENGINE=InnoDB AUTO_INCREMENT=1 ; ALTER TABLE `catalog_items` ADD COLUMN `ltd_limit` INT(4) NOT NULL DEFAULT '0' AFTER `offer_id`;[/CODE] [CENTER]If you want to have a purchase limit per user for that particular item only change the value of ltd_limit to the limit quantity that the user can buy that item. I'm sorry if I didn't explain how to add it, but if you already know how to move it will be easy to add. If you have questions just comment! I appreciate your attention! :) [B]CREDITS: Snaiker (Pollak)[/B] [/CENTER] [/QUOTE]
Insert quotes…
Verification
Post reply
Forums
Server Development
Habbo Retros
Habbo Tutorials
[NEW] Purchase LTDs Limit
Top