aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorsfan5 <sfan5@live.de>2022-06-07 21:27:05 +0200
committerGitHub <noreply@github.com>2022-06-07 21:27:05 +0200
commit3ac5a24b12950a2d92860d000b9477a11c1ad68b (patch)
treea4f6730c1bf7c93841b9a2bea63df3331c9ffe99
parent3107c9859114336989855a2c9ee2cbde0e88e3d3 (diff)
downloadhax-minetest-server-3ac5a24b12950a2d92860d000b9477a11c1ad68b.tar.gz
hax-minetest-server-3ac5a24b12950a2d92860d000b9477a11c1ad68b.zip
Sanitize player position and speed server-side (#12396)
-rw-r--r--src/player.h5
-rw-r--r--src/server/player_sao.cpp12
-rw-r--r--src/server/player_sao.h2
-rw-r--r--src/util/serialize.h12
4 files changed, 25 insertions, 6 deletions
diff --git a/src/player.h b/src/player.h
index d769acdad..cc1357010 100644
--- a/src/player.h
+++ b/src/player.h
@@ -134,13 +134,14 @@ public:
std::vector<CollisionInfo> *collision_info)
{}
- const v3f &getSpeed() const
+ v3f getSpeed() const
{
return m_speed;
}
- void setSpeed(const v3f &speed)
+ void setSpeed(v3f speed)
{
+ clampToF1000(speed);
m_speed = speed;
}
diff --git a/src/server/player_sao.cpp b/src/server/player_sao.cpp
index d076d5783..27759ba9d 100644
--- a/src/server/player_sao.cpp
+++ b/src/server/player_sao.cpp
@@ -319,8 +319,14 @@ std::string PlayerSAO::generateUpdatePhysicsOverrideCommand() const
return os.str();
}
-void PlayerSAO::setBasePosition(const v3f &position)
+void PlayerSAO::setBasePosition(v3f position)
{
+ // It's not entirely clear which parts of the network protocol still use
+ // v3f1000, but the script API enforces its bound on all float vectors
+ // (maybe it shouldn't?). For that reason we need to make sure the position
+ // isn't ever set to values that fail this restriction.
+ clampToF1000(position);
+
if (m_player && position != m_base_position)
m_player->setDirty(true);
@@ -344,7 +350,7 @@ void PlayerSAO::setPos(const v3f &pos)
setBasePosition(pos);
// Movement caused by this command is always valid
- m_last_good_position = pos;
+ m_last_good_position = getBasePosition();
m_move_pool.empty();
m_time_from_last_teleport = 0.0;
m_env->getGameDef()->SendMovePlayer(m_peer_id);
@@ -357,7 +363,7 @@ void PlayerSAO::moveTo(v3f pos, bool continuous)
setBasePosition(pos);
// Movement caused by this command is always valid
- m_last_good_position = pos;
+ m_last_good_position = getBasePosition();
m_move_pool.empty();
m_time_from_last_teleport = 0.0;
m_env->getGameDef()->SendMovePlayer(m_peer_id);
diff --git a/src/server/player_sao.h b/src/server/player_sao.h
index 1067801e7..b84bf1e82 100644
--- a/src/server/player_sao.h
+++ b/src/server/player_sao.h
@@ -87,7 +87,7 @@ public:
std::string getClientInitializationData(u16 protocol_version) override;
void getStaticData(std::string *result) const override;
void step(float dtime, bool send_recommended) override;
- void setBasePosition(const v3f &position);
+ void setBasePosition(v3f position);
void setPos(const v3f &pos) override;
void moveTo(v3f pos, bool continuous) override;
void setPlayerYaw(const float yaw);
diff --git a/src/util/serialize.h b/src/util/serialize.h
index 15bdd050d..2203fff0c 100644
--- a/src/util/serialize.h
+++ b/src/util/serialize.h
@@ -439,6 +439,18 @@ MAKE_STREAM_WRITE_FXN(video::SColor, ARGB8, 4);
//// More serialization stuff
////
+inline void clampToF1000(float &v)
+{
+ v = core::clamp(v, F1000_MIN, F1000_MAX);
+}
+
+inline void clampToF1000(v3f &v)
+{
+ clampToF1000(v.X);
+ clampToF1000(v.Y);
+ clampToF1000(v.Z);
+}
+
// Creates a string with the length as the first two bytes
std::string serializeString16(const std::string &plain);