Adds the possibility to individually upgrade items. EVERY stat can be upgraded, provided you enable them in the .conf file and add them in database. Upgrades are rank-based, meaning you can incrementally upgrade each stat, starting with rank 1 to rank n. Players will need to purchase the previous rank in order to advance to the next. Stats that can be upgraded along with their ranks are in reloadable tables, meaning you can add stats and/or ranks, modify or even delete them without restarting the server. Player's upgrades will be updated accordingly after the data is reloaded.
- Due to the nature of WOTLK client, the upgraded STATS increase will not be visible (to both the owner and other players when inspecting, or when linking the item), everyone can always see the original item stats. This can be partially resolved by sending SMSG_ITEM_QUERY_SINGLE_RESPONSE packet to the player, but this will show ALL items with the same entry as being upgraded and only the owner will see these stats anyway. So I don't bother with it.
- You CAN'T add or replace stats, you can only upgrade current item's stats.
- Upgrades will be lost (of course) when trading, sending mail, depositing to guild bank, deposit to auction.
- Clone this repository somewhere on your device.
- Copy mod-item-upgrade to your AzerothCore repo modules folder.
- Copy item_upgrades.patch to your AzerothCore repo (root level).
- Open a git command prompt in your AzerothCore repo root and use "patch -p1 < item_upgrades.patch" (no quotes). Ignore any warnings about whitespace if any. The patch should always apply with no problems on pretty much every version of AzerothCore since only two core files are modified with just a few lines of code.
- Re-run cmake to generate the solution.
- Re-build your project.
- You should have mod_item_upgrade.conf.dist copied in configs/modules after building, copy this to your server's binaries folder.
- Start the server, .sql files should automatically be imported in DB, if not, apply them manually.
Let's say you want players to be able to upgrade STAMINA by 5% and 10% respectively. All you need to do is insert two lines in mod_item_upgrade_stats table:
- id - this is an unique identifier for this stat/rank, just choose the next available id (current maximum + 1), try to keep it consecutive
- stat_type - since we want stamina, put 7 for this. This column corresponds to ItemModType enum in ItemTemplate.h. Consult this enum to find each stat, the enum names should be self-explanatory. EVERY stat is allowed for upgrade!
- stat_mod_pct - percentage increase for the rank, since we want 5% and 10%, put 5 for first line and 10 for second line.
- stat_rank - this MUST ALWAYS start with 1 and be consecutive. Each rank MUST ALWAYS be an upgrade, meaning stat_mod_pct for rank x must be SMALLER that stat_mod_pct for rank x+1. So put 1 for the 5% increase line and 2 for the 10% increase line. If later you want to add the upgrade possibility to 20% for stamina, just add another line with stat_mod_pct = 20 and stat_rank = 3.
Let's say you inserted the two lines and their id is 10 (for rank 1) and 11 (for rank 2). Now players are ready to upgrade item's stamina by 5% and 10% respectively. But now they CAN do it for free, since these two ranks have no requirements! If you want these ranks to have some requirements, let's use the second table mod_item_upgrade_stats_req:
- id - this is just an unique identifier with AUTO_INCREMENT, just leave it null and MySQL will generate an id for you
- stat_id - this corresponds to mod_item_upgrade_stats.id, in our case we have 10 (for rank 1) and 11 (for rank 2).
- req_type - type of requirement, this corresponds to UpgradeStatReqType enum in item_upgrade.h. Possible values:
- 1 - requires money
- 2 - requires honor points
- 3 - requires arena points
- 4 - requires item(s)
- req_val1 - based on req_type:
- when req_type = 1 (money), then this is a numeric value corresponding to the amount of required copper (e.g 10000000 means the rank will require 1000 gold to be bought)
- when req_type = 2 (honor), then this is a numeric value corresponding to how many honor points are required to buy the rank
- when req_type = 3 (arena), then this is a numeric value corresponding to how many arena points are required to buy the rank
- when req_type = 4 (item), then this is the entry (see item_template.entry) of the required item(s) to buy the rank
- req_val2 - based on req_type:
- UNUSED when req_type is not 4
- when req_type = 4 (item), then this is the amount of req_val1 item(s) required to buy the rank
So let's say you want players to upgrade stamina by 5% for FREE, then you don't have to insert anything in this table for stat_id 10. But for the 10% increase, you want the players to have 10x Badge of Justice and 1000 honor. So, we need to insert two lines: one with stat_id = 11, req_type = 2 (honor) and req_val1 = 1000 and another line with stat_id = 11, req_type = 4 (item), req_val1 = 29434 (entry for Badge of Justice) and req_val2 = 10 (requires 10x badges).
There is some sample data already inserted in these tables.
Use .npc add 200003 to spawn the Master Item Upgrade NPC. The rest is self explanatory. Use .item_upgrade reload command to reload associated tables.
- silviu20092