antihacks: Patch fast/teleport vulnerability when attached to an entity
* backported https://github.com/minetest/minetest/pull/10340/commits * Fixed God Mode * use core::radToDeg and a single v3f to multiply attachment_pos with * Use getLength() for diffvec
This commit is contained in:
parent
c632ff4aa2
commit
d99faef084
@ -1373,12 +1373,34 @@ std::string PlayerSAO::getPropertyPacket()
|
|||||||
|
|
||||||
bool PlayerSAO::checkMovementCheat()
|
bool PlayerSAO::checkMovementCheat()
|
||||||
{
|
{
|
||||||
if (isAttached() || m_is_singleplayer ||
|
if (m_is_singleplayer ||
|
||||||
g_settings->getBool("disable_anticheat")) {
|
g_settings->getBool("disable_anticheat")) {
|
||||||
m_last_good_position = m_base_position;
|
m_last_good_position = m_base_position;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
if (UnitSAO *parent = dynamic_cast<UnitSAO *>(getParent())) {
|
||||||
|
v3f attachment_pos;
|
||||||
|
{
|
||||||
|
int parent_id;
|
||||||
|
std::string bone;
|
||||||
|
v3f attachment_rot;
|
||||||
|
getAttachment(&parent_id, &bone, &attachment_pos, &attachment_rot);
|
||||||
|
}
|
||||||
|
|
||||||
|
v3f parent_pos = parent->getBasePosition();
|
||||||
|
f32 diff = m_base_position.getDistanceFromSQ(parent_pos) - attachment_pos.getLengthSQ();
|
||||||
|
const f32 maxdiff = 4.0f * BS; // fair trade-off value for various latencies
|
||||||
|
|
||||||
|
if (diff > maxdiff * maxdiff) {
|
||||||
|
setBasePosition(parent_pos);
|
||||||
|
actionstream << "Server: " << m_player->getName()
|
||||||
|
<< " moved away from parent; diff=" << sqrtf(diff) / BS
|
||||||
|
<< " resetting position." << std::endl;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
// Player movement is locked to the entity. Skip further checks
|
||||||
|
return false;
|
||||||
|
}
|
||||||
bool cheated = false;
|
bool cheated = false;
|
||||||
/*
|
/*
|
||||||
Check player movements
|
Check player movements
|
||||||
|
Loading…
x
Reference in New Issue
Block a user