eqemu-server/common/repositories/character_exp_modifiers_repository.h
Alex King 73a099c5ea
[Character] Character EXP Modifiers in Memory (#3934)
* Cleanup

* Final push.

* Update zonedb.cpp

* Update zone.h

* Update exp.cpp

* Update zonedb.cpp

---------

Co-authored-by: Chris Miles <akkadius1@gmail.com>
2024-01-13 00:03:36 -06:00

105 lines
2.9 KiB
C++

#ifndef EQEMU_CHARACTER_EXP_MODIFIERS_REPOSITORY_H
#define EQEMU_CHARACTER_EXP_MODIFIERS_REPOSITORY_H
#include "../database.h"
#include "../strings.h"
#include "base/base_character_exp_modifiers_repository.h"
class CharacterExpModifiersRepository: public BaseCharacterExpModifiersRepository {
public:
/**
* This file was auto generated and can be modified and extended upon
*
* Base repository methods are automatically
* generated in the "base" version of this repository. The base repository
* is immutable and to be left untouched, while methods in this class
* are used as extension methods for more specific persistence-layer
* accessors or mutators.
*
* Base Methods (Subject to be expanded upon in time)
*
* Note: Not all tables are designed appropriately to fit functionality with all base methods
*
* InsertOne
* UpdateOne
* DeleteOne
* FindOne
* GetWhere(std::string where_filter)
* DeleteWhere(std::string where_filter)
* InsertMany
* All
*
* Example custom methods in a repository
*
* CharacterExpModifiersRepository::GetByZoneAndVersion(int zone_id, int zone_version)
* CharacterExpModifiersRepository::GetWhereNeverExpires()
* CharacterExpModifiersRepository::GetWhereXAndY()
* CharacterExpModifiersRepository::DeleteWhereXAndY()
*
* Most of the above could be covered by base methods, but if you as a developer
* find yourself re-using logic for other parts of the code, its best to just make a
* method that can be re-used easily elsewhere especially if it can use a base repository
* method and encapsulate filters there
*/
// Custom extended repository methods here
static EXPModifier GetEXPModifier(
Database& db,
uint32 character_id,
uint32 zone_id,
int16 instance_version
)
{
const auto& l = CharacterExpModifiersRepository::GetWhere(
db,
fmt::format(
SQL(
`character_id` = {} AND
(`zone_id` = {} OR `zone_id` = 0) AND
(`instance_version` = {} OR `instance_version` = -1)
ORDER BY `zone_id`, `instance_version` DESC
LIMIT 1
),
character_id,
zone_id,
instance_version
)
);
if (l.empty()) {
return EXPModifier{
.aa_modifier = 1.0f,
.exp_modifier = 1.0f
};
}
return EXPModifier{
.aa_modifier = l[0].aa_modifier,
.exp_modifier = l[0].exp_modifier
};
}
static void SetEXPModifier(
Database& db,
uint32 character_id,
uint32 zone_id,
int16 instance_version,
EXPModifier m
)
{
CharacterExpModifiersRepository::ReplaceOne(
db,
CharacterExpModifiersRepository::CharacterExpModifiers{
.character_id = static_cast<int32_t>(character_id),
.zone_id = static_cast<int32_t>(zone_id),
.instance_version = instance_version,
.aa_modifier = m.aa_modifier,
.exp_modifier = m.exp_modifier
}
);
}
};
#endif //EQEMU_CHARACTER_EXP_MODIFIERS_REPOSITORY_H