Protectors can access the Forum post and Q&A pending message queues, and either approve it for publication, or reject it as spam / abuse. We then raise the member in the "Spam & Abuse" forum, so members can vote to close the offenders account.
This is important, because the process absolutely needs human input - it's too easy for the automated system to assume it's spam when it really isn't. And the need for multiple members to vote to close an account is also important as it's far to easy to hit the wrong button, and we do need a "double check" before closing an account.
But... during a spam wave you get lots of users in the queue, and the manual process to report them is both intensive and RSI inducing. So, I assembled this quick and dirty bit of code to make the process simpler.
Using the code
The first thing to note is that this doesn't automate the reporting process - all it does is assemble a list of links to users from the HTML of the report page. This is deliberate.
To automate it would require fetching the report page from the CP server (doable) once the HTMLAgilityPack had been told to log in as you (probably doable), parsing the HTML and extracting the links (trivial), formatting them for a S&A message (trivial), and reporting each of the users (probably doable).
But ... that has problems:
- Fetching the report page and automatically processing it could add "false positives" because the automated system could have added messages to it since you looked.
- Logging in as you would require me storing your email and password in a safe and secure manner appropriate for GDPR.
- You might have logged in using Facebook or Google and I really don't want to see how deep that rabbit hole goes ...
To use the code, just approve all the "non-spam" messages, then use your browser to inspect the page source, copy it to the clipboard, then run the code. Open a report in S&A, and paste the clipboard "as is".
Reject all the messages.
This is pretty easy: for Chrome CTRL+U, CTRL+A, CTRL+C, CTRL+F4 will copy the HTML source and close the view.
Please, not too many comments on the code quality - this is a quick and dirty, brute force and ignorance approach in C#:
private void DoClipboardToClipboard()
private string ExtractAndDisplay(string rawPageHtml)
rawHTML.Text = rawPageHtml;
string processedData = MakeReportableLinks(rawPageHtml);
links.Text = processedData;
private static string MakeReportableLinks(string rawPageHtml)
string userLink = "<a href=\"https://www.codeproject.com/script/Membership/View.aspx?mid=%ID%\">Member %ID% - Professional Profile</a>[<a href=\"https://www.codeproject.com/script/Membership/View.aspx?mid=%ID%\" target=\"_blank\" title=\"New Window\">^</a>]";
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
HtmlNodeCollection nodes = doc.DocumentNode.SelectNodes("//a[contains(@id,'ctl00_MC_PendingQA_ct')]");
if (nodes == null) return "** No links found **";
StringBuilder sb = new StringBuilder(nodes.Count);
int rows = 0;
foreach (HtmlNode node in nodes)
if (rows == 5)
rows = 0;
string url = node.Attributes["href"].Value;
string mid = url.Substring(url.IndexOf("?mid=") + 5);
2022-05-20 First Version
2022-05-20 Typos, and updated code (the version from my standalone app)
2022-05-20 BotReport Winforms app project source code (no Solution files) added.