View Full Version : Vbulletin API - Change Usergroup
SwalyAaron
08-10-2013, 05:58 AM
Hey looking for a command/function from the vbulletin API (3.8.7) - I've read the documentation but found nothing useful in there, also did some searches found nothing.
Heres my plan, I have an automated donation system that is mostly linked to a 3rd party game, I made it so once this donation system gets a positive response from the paypal IPN, to send a confirmation PM to the user which is working fine ATM, the problem I'm having is I cant find a proper function to promote the user to a different usergroup.
Any help will be appreciated
I don't think there's a function just for doing that, but you can use the user datamanager. I was looking at includes/cron/promotion.php which changes usergroups based on the Promotions you have configured. For reasons I don't understand (maybe efficiency), it changes the database directly to update some of the fields, then uses the datamanger to update others. So there might be something there that would be useful.
I haven't tested this, but taking some code from promotions.php, you might be able to do this:
// $userid must already be set to the user's id. If you have the user's info array
// you can use that in place of $user below
$userdm =& datamanager_init('User', $vbulletin, ERRTYPE_SILENT);
$user = array('userid' => $userid);
$userdm->set_existing($user);
$userdm->set('usergroupid', X); // X is new primary usergroup id
$userdm->save();
Of course that changes the primary group. If you wanted to add a secondary group instead that would be a bit more complicated.
ETA: You could just use an SQL query to update the usergroupid field in the user table, and that's probably enough as long as the change in group doesn't result in changes to titles or ranks or anything like that.
SwalyAaron
08-15-2013, 03:43 PM
I don't think there's a function just for doing that, but you can use the user datamanager. I was looking at includes/cron/promotion.php which changes usergroups based on the Promotions you have configured. For reasons I don't understand (maybe efficiency), it changes the database directly to update some of the fields, then uses the datamanger to update others. So there might be something there that would be useful.
I haven't tested this, but taking some code from promotions.php, you might be able to do this:
// $userid must already be set to the user's id. If you have the user's info array
// you can use that in place of $user below
$userdm =& datamanager_init('User', $vbulletin, ERRTYPE_SILENT);
$user = array('userid' => $userid);
$userdm->set_existing($user);
$userdm->set('usergroupid', X); // X is new primary usergroup id
$userdm->save();
Of course that changes the primary group. If you wanted to add a secondary group instead that would be a bit more complicated.
ETA: You could just use an SQL query to update the usergroupid field in the user table, and that's probably enough as long as the change in group doesn't result in changes to titles or ranks or anything like that.
Nah that didn't work, I'll try and make it a function instead and see what happens
vBulletin® v3.8.12 by vBS, Copyright ©2000-2025, vBulletin Solutions Inc.