X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fserver%2Fplayerstats.qc;h=3186b1aa3b432f9060ac130554895e419e13c29e;hb=946bc1d132dcbbddcc276ad8f80ccda7eb09ab79;hp=2c6e941a6a4dfd7585986ea74c969702e8609b81;hpb=b7d32c1f333da63877913b30c861230243ce1213;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/server/playerstats.qc b/qcsrc/server/playerstats.qc index 2c6e941a6..3186b1aa3 100644 --- a/qcsrc/server/playerstats.qc +++ b/qcsrc/server/playerstats.qc @@ -5,6 +5,26 @@ string events_last; .float playerstats_addedglobalinfo; .string playerstats_id; +#define ALL_ANTICHEATS \ + ANTICHEAT("_time"); \ + ANTICHEAT("speedhack"); \ + ANTICHEAT("speedhack_m1"); \ + ANTICHEAT("speedhack_m2"); \ + ANTICHEAT("speedhack_m3"); \ + ANTICHEAT("speedhack_m4"); \ + ANTICHEAT("speedhack_m5"); \ + ANTICHEAT("div0_strafebot_old"); \ + ANTICHEAT("div0_strafebot_new"); \ + ANTICHEAT("div0_evade"); \ + ANTICHEAT("idle_snapaim"); \ + ANTICHEAT("idle_snapaim_signal"); \ + ANTICHEAT("idle_snapaim_noise"); \ + ANTICHEAT("idle_snapaim_m2"); \ + ANTICHEAT("idle_snapaim_m3"); \ + ANTICHEAT("idle_snapaim_m4"); \ + ANTICHEAT("idle_snapaim_m7"); \ + ANTICHEAT("idle_snapaim_m10"); + void PlayerStats_Init() // initiated before InitGameplayMode so that scores are added properly { string uri; @@ -44,6 +64,11 @@ void PlayerStats_Init() // initiated before InitGameplayMode so that scores are PlayerStats_AddEvent(strcat("acc-", w.netname, "-frags")); } +#define ANTICHEAT(name) \ + PlayerStats_AddEvent("anticheat-" name) + ALL_ANTICHEATS +#undef ANTICHEAT + PlayerStats_AddEvent(PLAYERSTATS_ACHIEVEMENT_KILL_SPREE_3); PlayerStats_AddEvent(PLAYERSTATS_ACHIEVEMENT_KILL_SPREE_5); PlayerStats_AddEvent(PLAYERSTATS_ACHIEVEMENT_KILL_SPREE_10); @@ -356,6 +381,18 @@ void PlayerStats_Accuracy(entity p) //backtrace(strcat("adding player stat accuracy for ", p.netname, ".\n")); } +void PlayerStats_Anticheat(entity p) +{ + entity oldself = self; + self = p; + +#define ANTICHEAT(name) \ + PlayerStats_Event(p, "anticheat-" name, anticheat_getvalue(name)) + ALL_ANTICHEATS +#undef ANTICHEAT + self = oldself; +} + void PlayerStats_AddGlobalInfo(entity p) { if(playerstats_db < 0) @@ -384,6 +421,8 @@ void PlayerStats_AddGlobalInfo(entity p) PlayerStats_Accuracy(p); + PlayerStats_Anticheat(p); + if(IS_REAL_CLIENT(p)) { if(p.latency_cnt) @@ -430,3 +469,5 @@ void PlayerStats_EndMatch(float finished) } } } + +#undef ALL_ANTICHEATS