Can anyone help me to fix a query on a piece of script written for vb2? What the code is supposed to do is limit the number of concurrent searches being done on the forum. The original thread is here:
https://vborg.vbsupport.ru/showthrea...limit+searches
However, it is closed to new posts, I assume because it is so old. However, I think the mod would work in my circumstances but I think one of the queries in it is incorrect. I realize the original coder is no longer supporting the mod, nor was the code widely installed so there is not a lot of feedback or troubleshooting for it in the thread.
Basically, what the code does is create a new USER column called 'searching'. All users start with '0' in that field. When they go to do a search the field is changed to a '1'. When they finish searching (ie. are taken to the search results page) that field is reset back to '0'. In other words, while a user is in the middle of a search their searching field is set to '1'. When a new user goes to do a search, the system first adds up the total '1's in that field to decide whether a new search can be untaken at this time. So, if I have a limit of 4 concurrent searches allowed, the 5th searcher is turned away and told to try later. Make sense?
Here's the problem...I think everything is working in the script except at the very beginning...the query where it tries to find the total of all the '1's in the searching column. Here is how it is written:
PHP Code:
$usdb = $DB_site->query_first("SELECT COUNT(searching) FROM user WHERE searching='1'");
$usdb_query = mysql_fetch_row($usdb);
$userssearch = $usdb_query[0];
However, that returns an error on the page...I think due to query_first returning an array, not a single number. Changing query_first to just query gets rid of the error message on the search page but the code still doesn't do what it's supposed to. I don't know coding...I don't know how to create a query, I can only follow along and glean what I think it is trying to do. I've tried using a SUM instead of COUNT, but again, I just don't know enough coding to make it work.
Can anyone help me fix the query?
Later in the code, when it is deciding whether to allow a new user to do a search this is the code it uses (where $ups is the maximum number of concurrent searches allowed, set in the admin panel):
PHP Code:
if ($userssearch>=$ups) {
eval("standarderror(\"".gettemplate('restrictsearch')."\");");
In other words, if concurrent searches are limited to 4 and user #5 shows up to do a search then they are turned away and given an error message.
Can anyone help?