mirror of
https://github.com/azerothcore/mod-transmog
synced 2025-11-29 22:48:30 +08:00
feat: enable specific quality item based on transmog plus subscription (#139)
This commit is contained in:
@@ -256,5 +256,21 @@ Transmogrification.SetNpcText = 601084
|
|||||||
Transmogrification.SetCostModifier = 3.0
|
Transmogrification.SetCostModifier = 3.0
|
||||||
Transmogrification.SetCopperCost = 0
|
Transmogrification.SetCopperCost = 0
|
||||||
|
|
||||||
|
#
|
||||||
|
# TRANSMOG PLUS
|
||||||
|
#
|
||||||
|
# Transmogrification.EnablePlus
|
||||||
|
# Description: Enables/Disables TransmogPlus.
|
||||||
|
# Default: 0
|
||||||
|
#
|
||||||
|
# Transmogrification.MembershipLevels
|
||||||
|
# Description: Membership levels ID from acore_cms_subscriptions.
|
||||||
|
# Example: Transmogrification.MembershipLevels = "1,2,3"
|
||||||
|
# Default: ""
|
||||||
|
#
|
||||||
|
|
||||||
|
Transmogrification.EnablePlus = 0
|
||||||
|
Transmogrification.MembershipLevels = ""
|
||||||
|
|
||||||
#
|
#
|
||||||
###################################################################################################
|
###################################################################################################
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
#include "Transmogrification.h"
|
#include "Transmogrification.h"
|
||||||
#include "ItemTemplate.h"
|
#include "ItemTemplate.h"
|
||||||
#include "DatabaseEnv.h"
|
#include "DatabaseEnv.h"
|
||||||
|
#include "Tokenize.h"
|
||||||
|
|
||||||
Transmogrification* Transmogrification::instance()
|
Transmogrification* Transmogrification::instance()
|
||||||
{
|
{
|
||||||
@@ -721,7 +722,7 @@ bool Transmogrification::SuitableForTransmogrification(Player* player, ItemTempl
|
|||||||
if (IsAllowed(proto->ItemId))
|
if (IsAllowed(proto->ItemId))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (!IsItemTransmogrifiable(proto))
|
if (!IsItemTransmogrifiable(proto, player->GetGUID().GetCounter()))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
//[AZTH] Yehonal
|
//[AZTH] Yehonal
|
||||||
@@ -781,10 +782,10 @@ bool Transmogrification::SuitableForTransmogrification(ObjectGuid guid, ItemTemp
|
|||||||
if (IsAllowed(proto->ItemId))
|
if (IsAllowed(proto->ItemId))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (!IsItemTransmogrifiable(proto))
|
auto playerGuid = guid.GetCounter();
|
||||||
|
if (!IsItemTransmogrifiable(proto, playerGuid))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
auto playerGuid = guid.GetCounter();
|
|
||||||
CharacterCacheEntry const* playerData = sCharacterCache->GetCharacterCacheByGuid(guid);
|
CharacterCacheEntry const* playerData = sCharacterCache->GetCharacterCacheByGuid(guid);
|
||||||
if (!playerData)
|
if (!playerData)
|
||||||
return false;
|
return false;
|
||||||
@@ -854,7 +855,7 @@ bool Transmogrification::SuitableForTransmogrification(ObjectGuid guid, ItemTemp
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Transmogrification::IsItemTransmogrifiable(ItemTemplate const* proto) const
|
bool Transmogrification::IsItemTransmogrifiable(ItemTemplate const* proto, ObjectGuid::LowType playerGuid) const
|
||||||
{
|
{
|
||||||
if (!proto)
|
if (!proto)
|
||||||
return false;
|
return false;
|
||||||
@@ -865,7 +866,7 @@ bool Transmogrification::IsItemTransmogrifiable(ItemTemplate const* proto) const
|
|||||||
if (!AllowFishingPoles && proto->Class == ITEM_CLASS_WEAPON && proto->SubClass == ITEM_SUBCLASS_WEAPON_FISHING_POLE)
|
if (!AllowFishingPoles && proto->Class == ITEM_CLASS_WEAPON && proto->SubClass == ITEM_SUBCLASS_WEAPON_FISHING_POLE)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!IsAllowedQuality(proto->Quality)) // (proto->Quality == ITEM_QUALITY_LEGENDARY)
|
if (!IsAllowedQuality(proto->Quality, playerGuid)) // (proto->Quality == ITEM_QUALITY_LEGENDARY)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// If World Event is not active, prevent using event dependant items
|
// If World Event is not active, prevent using event dependant items
|
||||||
@@ -918,12 +919,12 @@ bool Transmogrification::IsNotAllowed(uint32 entry) const
|
|||||||
return NotAllowed.find(entry) != NotAllowed.end();
|
return NotAllowed.find(entry) != NotAllowed.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Transmogrification::IsAllowedQuality(uint32 quality) const
|
bool Transmogrification::IsAllowedQuality(uint32 quality, ObjectGuid::LowType playerGuid) const
|
||||||
{
|
{
|
||||||
switch (quality)
|
switch (quality)
|
||||||
{
|
{
|
||||||
case ITEM_QUALITY_POOR: return AllowPoor;
|
case ITEM_QUALITY_POOR: return AllowPoor || isPlusEligible(playerGuid);
|
||||||
case ITEM_QUALITY_NORMAL: return AllowCommon;
|
case ITEM_QUALITY_NORMAL: return AllowCommon || isPlusEligible(playerGuid);
|
||||||
case ITEM_QUALITY_UNCOMMON: return AllowUncommon;
|
case ITEM_QUALITY_UNCOMMON: return AllowUncommon;
|
||||||
case ITEM_QUALITY_RARE: return AllowRare;
|
case ITEM_QUALITY_RARE: return AllowRare;
|
||||||
case ITEM_QUALITY_EPIC: return AllowEpic;
|
case ITEM_QUALITY_EPIC: return AllowEpic;
|
||||||
@@ -1039,6 +1040,12 @@ void Transmogrification::LoadConfig(bool reload)
|
|||||||
{
|
{
|
||||||
TokenEntry = 49426;
|
TokenEntry = 49426;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
IsTransmogPlusEnabled = sConfigMgr->GetOption<bool>("Transmogrification.EnablePlus", false);
|
||||||
|
std::string stringMembershipIds = sConfigMgr->GetOption<std::string>("Transmogrification.MembershipLevels", "");
|
||||||
|
for (auto& itr : Acore::Tokenize(stringMembershipIds, ',', false)) {
|
||||||
|
MembershipIds.push_back(Acore::StringTo<uint32>(itr).value());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Transmogrification::DeleteFakeFromDB(ObjectGuid::LowType itemLowGuid, CharacterDatabaseTransaction* trans /*= nullptr*/)
|
void Transmogrification::DeleteFakeFromDB(ObjectGuid::LowType itemLowGuid, CharacterDatabaseTransaction* trans /*= nullptr*/)
|
||||||
@@ -1057,6 +1064,37 @@ void Transmogrification::DeleteFakeFromDB(ObjectGuid::LowType itemLowGuid, Chara
|
|||||||
CharacterDatabase.Execute("DELETE FROM custom_transmogrification WHERE GUID = {}", itemGUID.GetCounter());
|
CharacterDatabase.Execute("DELETE FROM custom_transmogrification WHERE GUID = {}", itemGUID.GetCounter());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Transmogrification::isPlusEligible(ObjectGuid::LowType playerGuid) const {
|
||||||
|
if (!IsTransmogPlusEnabled) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (MembershipIds.size() == 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
QueryResult result = CharacterDatabase.Query("SELECT `account` FROM `characters` WHERE `guid` = {}", playerGuid);
|
||||||
|
|
||||||
|
if (result) {
|
||||||
|
|
||||||
|
uint32 accountId = (*result)[0].Get<uint32>();
|
||||||
|
QueryResult resultAcc = LoginDatabase.Query("SELECT `membership_level` FROM `acore_cms_subscriptions` WHERE `account_name` COLLATE utf8mb4_general_ci = (SELECT `username` FROM `account` WHERE `id` = {})", accountId);
|
||||||
|
|
||||||
|
if (resultAcc) {
|
||||||
|
const uint32 membershipLevel = (*resultAcc)[0].Get<uint32>();
|
||||||
|
for (const auto& itr : MembershipIds)
|
||||||
|
{
|
||||||
|
if (itr == membershipLevel) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
bool Transmogrification::GetEnableTransmogInfo() const
|
bool Transmogrification::GetEnableTransmogInfo() const
|
||||||
{
|
{
|
||||||
return EnableTransmogInfo;
|
return EnableTransmogInfo;
|
||||||
|
|||||||
@@ -161,7 +161,7 @@ public:
|
|||||||
|
|
||||||
bool IsAllowed(uint32 entry) const;
|
bool IsAllowed(uint32 entry) const;
|
||||||
bool IsNotAllowed(uint32 entry) const;
|
bool IsNotAllowed(uint32 entry) const;
|
||||||
bool IsAllowedQuality(uint32 quality) const;
|
bool IsAllowedQuality(uint32 quality, ObjectGuid::LowType playerGuid) const;
|
||||||
bool IsRangedWeapon(uint32 Class, uint32 SubClass) const;
|
bool IsRangedWeapon(uint32 Class, uint32 SubClass) const;
|
||||||
bool CanNeverTransmog(ItemTemplate const* itemTemplate);
|
bool CanNeverTransmog(ItemTemplate const* itemTemplate);
|
||||||
|
|
||||||
@@ -184,7 +184,7 @@ public:
|
|||||||
bool CanTransmogrifyItemWithItem(Player* player, ItemTemplate const* destination, ItemTemplate const* source) const;
|
bool CanTransmogrifyItemWithItem(Player* player, ItemTemplate const* destination, ItemTemplate const* source) const;
|
||||||
bool SuitableForTransmogrification(Player* player, ItemTemplate const* proto) const;
|
bool SuitableForTransmogrification(Player* player, ItemTemplate const* proto) const;
|
||||||
bool SuitableForTransmogrification(ObjectGuid guid, ItemTemplate const* proto) const;
|
bool SuitableForTransmogrification(ObjectGuid guid, ItemTemplate const* proto) const;
|
||||||
bool IsItemTransmogrifiable(ItemTemplate const* proto) const;
|
bool IsItemTransmogrifiable(ItemTemplate const* proto, ObjectGuid::LowType playerGuid) const;
|
||||||
uint32 GetSpecialPrice(ItemTemplate const* proto) const;
|
uint32 GetSpecialPrice(ItemTemplate const* proto) const;
|
||||||
|
|
||||||
void DeleteFakeFromDB(ObjectGuid::LowType itemLowGuid, CharacterDatabaseTransaction* trans = nullptr);
|
void DeleteFakeFromDB(ObjectGuid::LowType itemLowGuid, CharacterDatabaseTransaction* trans = nullptr);
|
||||||
@@ -211,6 +211,11 @@ public:
|
|||||||
bool EnableRetroActiveAppearances() const;
|
bool EnableRetroActiveAppearances() const;
|
||||||
bool EnableResetRetroActiveAppearances() const;
|
bool EnableResetRetroActiveAppearances() const;
|
||||||
[[nodiscard]] bool IsEnabled() const;
|
[[nodiscard]] bool IsEnabled() const;
|
||||||
|
|
||||||
|
// Transmog Plus
|
||||||
|
bool IsTransmogPlusEnabled;
|
||||||
|
std::vector<uint32> MembershipIds;
|
||||||
|
bool isPlusEligible(ObjectGuid::LowType playerGuid) const;
|
||||||
};
|
};
|
||||||
#define sTransmogrification Transmogrification::instance()
|
#define sTransmogrification Transmogrification::instance()
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user