-
Notifications
You must be signed in to change notification settings - Fork 24
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Feature] Add SourceBans to profile information #159
Comments
Given how complex this would be, I'm going to try to get this working by itself and hopefully come back with at least part of a pull request. |
IMO, since this is simply presented in profile information when viewing someones profile (i.e. the player details modal or something), i think the following would be needed for an intro implementation:
And for the frontend, we would need:
Decisions that need to be made:
This is not a small task, and requires front-end integration for work. Tbh this should also be paired with work needed doing on the front end to integrate other preference items into the preferences panel. |
I should note: design philosophy has it as the requirement that the Back end is the one making these API requests. So hacking the information into just the front-end presentation layer is not acceptable, at least for the main repo. The front-end should only ever interact with the associated client-backend and never to the internet. Further it should be heavily considered how these API requests are batched and sent, because players can join a server with upwards of 99 other players on it, and we don't want to be slamming out 99 requests per SourceBans API. So a batching mechanism, if the API supports it, would be amazing. Otherwise, we would need a backoff or maximum amount of requests per time period mechanism. The above is also why I deem it mandatory that there be an associated toggle option for the SourceBans info, and that its opt-in, not opt-out. (Default to NO) |
Happy for other dev input on the usefulness of this Feature Request, and on my above checklist |
https://steamhistory.net/ turned out to be an exciting lead. I contacted its author and maintainer, @0x000015, requesting comment on this issue. It turns out they stood up an API specifically in anticipation of use-cases like ours, saving us the effort of indexing all the TF2 servers hosting source bans on the server browser and warehousing that data ourselves. Alternatively, it spares community server maintainers the pain of being burst with 24 Steam ID requests every time a MAC user joins a new session and getting DDoSed by everyone running MAC. The only stipulation is that we use some intermediate centralized broker to cache the results. Hence, I've created a tracking issue in the MB repo: MegaAntiCheat/masterbase#75. Re: Lilith's implementation outline SteamHistory eliminates the need for any configurable list of SB servers by providing a pretty comprehensive aggregation of source bans from popular community hosting providers. Requests to SH can be proxied (and transparently cached) via masterbase. |
Re: the updates to the checklist, @lili7h, I don't mind the client having a local TTL for any given player's results from the MB; we could return the age of the cached data from our endpoint to set it dynamically if you prefer. I also found an example JSON response on the SH API's index page that I'm copying here for completeness. I won't bother formalizing it; we aren't exactly developing a compiler here. The data should be pretty homogenous, with most deviations indicating error cases. {
"response": [
{
"SteamID": "7656XXXXXXXXXXXXX",
"Name": "Username",
"CurrentState": "Permanent",
"BanReason": "Hacker",
"UnbanReason": null,
"BanTimestamp": 1685513965,
"UnbanTimestamp": 0,
"Server": "Skial"
}
]
} |
@lili7h I've received additional clarification from @0x000015. SteamHistory's backend is much better optimized to handle distributed requests than the Sourceban web server implementation as long as we batch them properly, so centralizing the cache isn't as pressing of a need as first anticipated. XVH says they'll advise us to implement MB#75 if there are any issues supporting our throughput. |
Tracking this feature request in branch |
A useful addition to profile information would be SourceBans. MAC could search through public ban lists with a user's steam ID, like what https://steamhistory.net does.
https://www.skial.com/sourcebans/index.php?p=banlist
https://sourcebans.gflclan.com/index.php?p=banlist
https://bans.scrap.tf/index.php?p=banlist
(and many more available with some basic research)
The text was updated successfully, but these errors were encountered: