akanevsky
10-09-2005, 10:00 PM
vBulletin API Basics: Variables, Functions, Objects
This How-To should serve as a reference to coders, who have a basic knowledge of PHP and who want to make their own mods.
$vbulletin (Type: Object)
Contains vBulletin data that has been in separate variables in vB 3.0.x.
Below you can find a translation table of changed variables and functions.
This is an expanded version of the list that you can find in vBulletin's source code (functions_legacy.php).
vBulletin 3.0.3 locations are on the left hand side, and the corresponding vBulletin 3.5.0 locations are on the right hand side.
Legacy locations can be enabled by running legacy_enable(), although this is officially not recommended for long term compatibility.
* $vboptions['x'] --> $vbulletin->options['x']
* $iforumcache --> $vbulletin->iforumcache
* $forumcache --> $vbulletin->forumcache
* $usergroupcache --> $vbulletin->usergroupcache
* $datastore['wol_spiders'] --> $vbulletin->wol_spiders
* $smiliecache --> $vbulletin->smiliecache
* $stylechoosercache --> $vbulletin->stylecache
* $datastore['x'] --> $vbulletin->x
* $bbuserinfo['x'] --> $vbulletin->userinfo['x']
* $session['x'] --> $vbulletin->session->vars['x']
*
* $_BITFIELD['usergroup'] --> $vbulletin->bf_ugp
* $_BITFIELD['usergroup']['x'] --> $vbulletin->bf_ugp_x
* $_BITFIELD['usergroup']['x']['y'] --> $vbulletin->bf_ugp_x['y']
* $_BITFIELD['calmoderatorpermissions']['x'] --> $vbulletin->bf_misc_calmoderatorpermissions['x']
* $_BITFIELD['moderatorpermissions']['x'] --> $vbulletin->bf_misc_moderatorpermissions['x']
* $_BITFIELD['languageoptions']['x'] --> $vbulletin->bf_misc_languageoptions['x']
* $_USEROPTIONS['x'] --> $vbulletin->bf_misc_useroptions['x']
* $_FORUMOPTIONS['x'] --> $vbulletin->bf_misc_forumoptions['x']
* $_INTPERMS --> $vbulletin->bf_misc_intperms
* $_INTPERMS['x'] --> $vbulletin->bf_misc_intperms['x']
*
* ------------------------------------------------------------------------------
* Variables and Functions below are NOT affected/re-enabled by legacy_enable()
* ------------------------------------------------------------------------------
*
* $_GET/$_POST/$_REQUEST/$_COOKIE/$_FILES --> $vbulletin->GPC['x']
* $DB_Site->x() --> $vbulletin->db->x()
* $url --> $vbulletin->url
* $nozip --> $vbulletin->nozip
* $script --> $vbulletin->script
* $scriptpath --> $vbulletin->scriptpath
*
* HTML_SELECTED --> not defined anymore in vB 3.5
* HTML_CHECKED --> not defined anymore in vB 3.5
*
* bbcode_parse() --> $bbcode_parser->parse
* iif($condition, $r_true, $r_false) --> obsolete, use ($condition ? $r_true : $r_false) instead;
Please note the following:
$vbulletin
Inside of object classes, you should access $vbulletin->[...] as $this->registry->[...]. Therefore, use that structure when modifying code inside of any classes.
.
VARIABLES ENABLED FOR TEMPLATES
$vboptions['x'], $bbuserinfo['x'] and $session['x'] do work in the template system without running legacy_enable().
.
SUPERGLOBALS
$_GET/$_POST/$_REQUEST/$_COOKIE/$_FILES/$_SERVER/$_ENV are available anywhere, but generally you should avoid using them. Instead, "clean" those variables and place them into $vbulletin->GPC using $vbulletin->input->clean_gpc() and $vbulletin->input->clean_array_gpc() methods.
You can read more about these two "cleaning" methods here (http://www.vbulletin.com/docs/html/codestandards_gpc).
As a summary:
Use $vbulletin->input->clean_gpc() for a single variable, and $vbulletin->input->clean_array_gpc() for arrays.
After variables are patched through, they can be accessed using $vbulltin->GPC (which is an array).
Cleaning 'somevar' will not create variable $somevar.
$vbulletin->input->clean_gpc() returns the clean value, therefore the following code will work out nicely:
$id = $vbulletin->input->clean_gpc('r', 'id', TYPE_UINT);
Once you get to know the syntax of those functions, you can use the following as a reference:
------------------------------------
SOURCES AND THEIR EQUIVALENTS
------------------------------------
'g' - $_GET
'p' - $_POST
'r' - $_REQUEST
'c' - $_COOKIE
's' - $_SERVER
'e' - $_ENV
'f' - $_FILES
------------------------------------
VALID DATA TYPES
------------------------------------
TYPE_BOOL - Boolean
TYPE_INT - Integer
TYPE_UINT - Unsigned Integer
TYPE_NUM - Floating Point Number
TYPE_UNUM - Unsigned Floating Point Number
TYPE_UNIXTIME - Unix Timestamp (Unsigned Integer)
TYPE_STR - Trimmed String (No leading or trailing whitespace)
TYPE_NOTRIM - String
TYPE_NOHTML - Trimmed String sent through htmlspecialchars_uni()
TYPE_ARRAY - Array
TYPE_FILE - File
TYPE_NOCLEAN - Unvalidated
GLOBALIZING VARIABLES IN FUNCTIONS
Since most of the variables can be found within the $vbulletin class, there is generally no need to globalize more than one variable (which is $vbulletin). An exception would be the $vbphrase array, which currently cannot be found within the $vbulletin class.
Taking the above account, the following code is not good:
function foo()
{
global $forumcache, $vbulletin, $vboptions;
$forumcache =& $vbulletin->forumcache;
$vboptions =& $vbulletin->options;
foreach ($forumcache AS $forumid => $forum)
{
if ($vboptions['something'])
{
// do stuff
}
}
}
Instead, you should use the following code (which is, obviously, shorter and easier to use):
function foo()
{
global $vbulletin;
foreach ($vbulletin->forumcache AS $forumid => $forum)
{
if ($vbulletin->options['something'])
{
// do something
}
}
}
DATASTORE ITEMS
In vBulletin 3.0.x you could commonly see the following code:
if (isset($datastore_item))
Unfortunately, this does not work in vBulletin 3.5.0, since the datastore items are now contained within $vbulletin class.
You need to use the following code instead:
if ($vbulletin->datastore_item !== null)
BITFIELDS
In case you have been wondering, "ugp" stands for "UserGroup Permissions".
To avoid the confusing "$object->array[key1][key2][key3][key4]...[key10]" stuff, there are references set up that allow you to talk to deep elements quickly. For example, $vbulletin->bf_ugp_adminpermissions is a reference to $vbulletin->bf_ugp['adminpermissions'].
.
BBCODE PARSE
BBCode Parser has changed slightly in vBulletin 3.5.
To familiarize yourself with the new syntax, check out KirbyDE's How-To (https://vborg.vbsupport.ru/showthread.php?t=82693).
.
MISCELLANEOUS
It is impossible to list here every aspect of vBulletin code, therefore you should familizarize yourself with the contents of init.php and class_core.php before beginning to hack into the system (and I know you are in a rush ;)).
$db (Type: Object)
As you might have judged from the Table 1 in this tutorial, the database object in vB3.5 is $vbulletin->db.
However, $db is another way to access that object; it is the way that used everywhere unless you call it from within a function. In functions, use $vbulletin->db.
Obviously, the purpose of the database method is to perform various operations on the database. Most common methods are described below.
$db->query();
Deprecated in favor of below methods (to save memory).
Returns: MySQL Resource
.
$db->query_read();
Performs SELECT and SHOW operations only.
These queries will execute on the slave server, if one is defined.
Returns: MySQL Resource
.
$db->query_write();
Performs INSERT, REPLACE, UPDATE, DROP, ALTER and other data-modifying queries.
These queries will execute on the master server.
Returns: MySQL Resource
.
$db->query_first();
Same as query_read(), but returns first result as an array.
Returns: array on success / boolean false on failure
.
$db->num_rows($mysql_resource_var);
Input: A MySQL resource variable (usually output of the first three methods).
Returns: int Amount of Resulting Rows
.
$db->fetch_array($mysql_resource_var);
Input: A MySQL resource variable (usually output of the first three methods).
Returns: array One row from the mysql results on success / boolean false on failure
To fetch each row consecutively, use the following code:
while ($var = $db->fetch_array($mysql_resource_var))
{
// your code ($var contains the array);
}
$db->insert_id();
Input: None.
Returns: int Row ID of the latest INSERT operation.
.
$db->escape_string(); and $db->escape_string_like();
Input: String.
Returns: string A string with appropriate characters escaped.
These two functions must be used instead of the PHP built-in addslashes() and addslashes_like().
Using the PHP built-in functions may cause problems on non-MySQL systems.
.
$db->show_errors(); and $db->hide_errors();
Input: None.
Returns: None.
The first function enables sql error output (default), whereas the second function disables such output.
Useful when you do not want the script to die on error (example: no die on product installation if a table already exists).
Data Managers
Data Managers (DMs) are an interface to various data objects used within vBulletin. They enforce necessary constraints and administrator-set options on the data to ensure that the data is valid.
You can read more about Data Managers in vBulletin's online manual (http://www.vbulletin.com/docs/html/data_managers).
Also, you can read specifically about the User DM in this KirbyDE's How-To (https://vborg.vbsupport.ru/showthread.php?t=82836), and about Thread DM here (https://vborg.vbsupport.ru/showthread.php?t=97283).
Authentication Storage
The authentication data is stored in the following way (thank to Kirby for this info):
$_COOKIE:
{cookiepfx}userid - plain(userid)
{cookiepfx}password - md5(md5(md5('PlaintextPassword') . salt) . 'LicenseNo').
TABLE user:
password - md5(md5('PlaintextPassword') . salt)
Note that for cookie, {cookiepfx} is your board's cookie prefix. It is configurable via admincp and is accessible via the COOKIE_PREFIX constant.
Important Functions
construct_page_nav($pagenumber, $perpage, $results, $address, $address2 = '');
Returns the HTML for multi-page navigation.
Two latest arguments are not used yet, therefore they are not documented.
$pagenumber int Total number of items found
$perpage string Base address for links eg: showthread.php?t=99{&page=4}
$results string Ending portion of address for links
eval(standard_error(fetch_error('error_phrase')));
Outputs a standard error message with a phrase of your choice.
fetch_error looks up the phrase you specify in the "Front-End Error Messages" phrase category.
Error phrases must be prefixed with "error_".
.
print_standard_redirect($redir_phrase, $doquery = true, $forceredirect = false);
Returns eval()-able code to initiate a standard redirect
$vbulletin->url should contain the target url for the redirect.
$redir_phrase string Name of redirect phrase
$doquery boolean If true, it will fetch $redir_phrase from "Front-End Redirect Messages" phrase category. Must be prefixed with "redirect_".
If false, it will use the value of $redir_phrase as the phrase itself.
$forceredirect boolean Should generally be set to true.
is_valid_email($email);
Checks an email for validity and returns true or false.
.
can_moderate($forumid = 0, $do = '', $userid = -1, $usergroupids = '');
Checks whether a user can moderate a certain forum.
$forumid int Specific forum to check. If not set, will check whether the user is a moderator of any forum at all.
$do string Specific mod action to check. If not set, will check whether the user is a moderator of the forum specified in $forumid.
$userid int User ID to check. If not set, will use $vbulletin->userinfo.
$usergroupids string List of group IDs, separate by commas, to which the user belongs. Should be generally left blank.
can_administer();
Checks whether or not the visiting user has administrative permissions
This function can optionally take any number of parameters, each of which
should be a particular administrative permission you want to check. For example:
can_administer('canadminsettings', 'canadminstyles', 'canadminlanguages')
If any one of these permissions is met, the function will return true.
If no parameters are specified, the function will simply check that the user is an administrator.
.
convert_bits_to_array(&$bitfield, $_FIELDNAMES);
Converts a bitfield into an array of 1 / 0 values based on the array describing the resulting fields. Returns an array.
&$bitfield int (ref) Bitfield
$_FIELDNAMES array Array containing field definitions - array('canx' => 1, 'cany' => 2, 'canz' => 4) etc.
function convert_array_to_bits(&$arry, $_FIELDNAMES, $unset = 0);
Takes an array and returns the bitwise value.
&arry array Array for input.
$_FIELDNAMES array Array containing field definitions - array('canx' => 1, 'cany' => 2, 'canz' => 4) etc.
$unset int Defines whether to unset the array data once it has been converted to bits
fetch_template($templatename, $escape = 0, $gethtmlcomments = true);
Returns a single template from the templatecache or the database.
$templatename string Name of template to be fetched
$escape int Escape quotes in template? 1: escape; -1: unescape; 0: do nothing
$gethtmlcomments boolean Wrap template in HTML comments showing the template name?
Two most common uses are:
eval('$mycustomvar .= "' . fetch_template('mycustomtemplate') . '";');
eval('print_output("' . fetch_template('mycustomtemplate') . '");');
vbsetcookie($name, $value = '', $permanent = true);
Sets a cookie based on vBulletin environmental settings.
$name string Cookie name
$value mixed Value to store in the cookie
$permanent boolean If true, do not set an expiry date for the cookie
vb_number_format($number, $decimals = 0, $bytesize = false, $decimalsep = null, $thousandsep = null);
Formats a number with user's own decimal and thousands chars and returns the formatted number.
$number mixed Number to be formatted: integer / 8MB / 16 GB / 6.0 KB / 3M / 5K / ETC
$decimals integer Number of decimal places to display
$bytesize boolean Special case for byte-based numbers
$decimalsep string Custom decimal separator (to override user's preference)
$thousandsep string Custom thousands separator (to override user's preference)
vbmail($toemail, $subject, $message, $notsubscription = false, $from = '', $uheaders = '', $username = '');
Starts the process of sending an email - either immediately or by adding it to the mail queue.
$toemail string Destination email address
$subject string Email message subject
$message string Email message body
$notsubscription boolean If true, do not use the mail queue and send immediately
$from string Optional name/email to use in 'From' header
$uheaders string Additional headers
$username string Username of person sending the email
Sources Used
vBulletin's source code
vBulletin Online Manual (http://www.vbulletin.com/docs/html/)
Kier's message for developers, released here by Wayne Luke (https://vborg.vbsupport.ru/showpost.php?p=663572&postcount=5)
Scotsmist's contribution post (nice one!) (https://vborg.vbsupport.ru/showpost.php?p=725943&postcount=46)
>> EOD
This How-To should serve as a reference to coders, who have a basic knowledge of PHP and who want to make their own mods.
$vbulletin (Type: Object)
Contains vBulletin data that has been in separate variables in vB 3.0.x.
Below you can find a translation table of changed variables and functions.
This is an expanded version of the list that you can find in vBulletin's source code (functions_legacy.php).
vBulletin 3.0.3 locations are on the left hand side, and the corresponding vBulletin 3.5.0 locations are on the right hand side.
Legacy locations can be enabled by running legacy_enable(), although this is officially not recommended for long term compatibility.
* $vboptions['x'] --> $vbulletin->options['x']
* $iforumcache --> $vbulletin->iforumcache
* $forumcache --> $vbulletin->forumcache
* $usergroupcache --> $vbulletin->usergroupcache
* $datastore['wol_spiders'] --> $vbulletin->wol_spiders
* $smiliecache --> $vbulletin->smiliecache
* $stylechoosercache --> $vbulletin->stylecache
* $datastore['x'] --> $vbulletin->x
* $bbuserinfo['x'] --> $vbulletin->userinfo['x']
* $session['x'] --> $vbulletin->session->vars['x']
*
* $_BITFIELD['usergroup'] --> $vbulletin->bf_ugp
* $_BITFIELD['usergroup']['x'] --> $vbulletin->bf_ugp_x
* $_BITFIELD['usergroup']['x']['y'] --> $vbulletin->bf_ugp_x['y']
* $_BITFIELD['calmoderatorpermissions']['x'] --> $vbulletin->bf_misc_calmoderatorpermissions['x']
* $_BITFIELD['moderatorpermissions']['x'] --> $vbulletin->bf_misc_moderatorpermissions['x']
* $_BITFIELD['languageoptions']['x'] --> $vbulletin->bf_misc_languageoptions['x']
* $_USEROPTIONS['x'] --> $vbulletin->bf_misc_useroptions['x']
* $_FORUMOPTIONS['x'] --> $vbulletin->bf_misc_forumoptions['x']
* $_INTPERMS --> $vbulletin->bf_misc_intperms
* $_INTPERMS['x'] --> $vbulletin->bf_misc_intperms['x']
*
* ------------------------------------------------------------------------------
* Variables and Functions below are NOT affected/re-enabled by legacy_enable()
* ------------------------------------------------------------------------------
*
* $_GET/$_POST/$_REQUEST/$_COOKIE/$_FILES --> $vbulletin->GPC['x']
* $DB_Site->x() --> $vbulletin->db->x()
* $url --> $vbulletin->url
* $nozip --> $vbulletin->nozip
* $script --> $vbulletin->script
* $scriptpath --> $vbulletin->scriptpath
*
* HTML_SELECTED --> not defined anymore in vB 3.5
* HTML_CHECKED --> not defined anymore in vB 3.5
*
* bbcode_parse() --> $bbcode_parser->parse
* iif($condition, $r_true, $r_false) --> obsolete, use ($condition ? $r_true : $r_false) instead;
Please note the following:
$vbulletin
Inside of object classes, you should access $vbulletin->[...] as $this->registry->[...]. Therefore, use that structure when modifying code inside of any classes.
.
VARIABLES ENABLED FOR TEMPLATES
$vboptions['x'], $bbuserinfo['x'] and $session['x'] do work in the template system without running legacy_enable().
.
SUPERGLOBALS
$_GET/$_POST/$_REQUEST/$_COOKIE/$_FILES/$_SERVER/$_ENV are available anywhere, but generally you should avoid using them. Instead, "clean" those variables and place them into $vbulletin->GPC using $vbulletin->input->clean_gpc() and $vbulletin->input->clean_array_gpc() methods.
You can read more about these two "cleaning" methods here (http://www.vbulletin.com/docs/html/codestandards_gpc).
As a summary:
Use $vbulletin->input->clean_gpc() for a single variable, and $vbulletin->input->clean_array_gpc() for arrays.
After variables are patched through, they can be accessed using $vbulltin->GPC (which is an array).
Cleaning 'somevar' will not create variable $somevar.
$vbulletin->input->clean_gpc() returns the clean value, therefore the following code will work out nicely:
$id = $vbulletin->input->clean_gpc('r', 'id', TYPE_UINT);
Once you get to know the syntax of those functions, you can use the following as a reference:
------------------------------------
SOURCES AND THEIR EQUIVALENTS
------------------------------------
'g' - $_GET
'p' - $_POST
'r' - $_REQUEST
'c' - $_COOKIE
's' - $_SERVER
'e' - $_ENV
'f' - $_FILES
------------------------------------
VALID DATA TYPES
------------------------------------
TYPE_BOOL - Boolean
TYPE_INT - Integer
TYPE_UINT - Unsigned Integer
TYPE_NUM - Floating Point Number
TYPE_UNUM - Unsigned Floating Point Number
TYPE_UNIXTIME - Unix Timestamp (Unsigned Integer)
TYPE_STR - Trimmed String (No leading or trailing whitespace)
TYPE_NOTRIM - String
TYPE_NOHTML - Trimmed String sent through htmlspecialchars_uni()
TYPE_ARRAY - Array
TYPE_FILE - File
TYPE_NOCLEAN - Unvalidated
GLOBALIZING VARIABLES IN FUNCTIONS
Since most of the variables can be found within the $vbulletin class, there is generally no need to globalize more than one variable (which is $vbulletin). An exception would be the $vbphrase array, which currently cannot be found within the $vbulletin class.
Taking the above account, the following code is not good:
function foo()
{
global $forumcache, $vbulletin, $vboptions;
$forumcache =& $vbulletin->forumcache;
$vboptions =& $vbulletin->options;
foreach ($forumcache AS $forumid => $forum)
{
if ($vboptions['something'])
{
// do stuff
}
}
}
Instead, you should use the following code (which is, obviously, shorter and easier to use):
function foo()
{
global $vbulletin;
foreach ($vbulletin->forumcache AS $forumid => $forum)
{
if ($vbulletin->options['something'])
{
// do something
}
}
}
DATASTORE ITEMS
In vBulletin 3.0.x you could commonly see the following code:
if (isset($datastore_item))
Unfortunately, this does not work in vBulletin 3.5.0, since the datastore items are now contained within $vbulletin class.
You need to use the following code instead:
if ($vbulletin->datastore_item !== null)
BITFIELDS
In case you have been wondering, "ugp" stands for "UserGroup Permissions".
To avoid the confusing "$object->array[key1][key2][key3][key4]...[key10]" stuff, there are references set up that allow you to talk to deep elements quickly. For example, $vbulletin->bf_ugp_adminpermissions is a reference to $vbulletin->bf_ugp['adminpermissions'].
.
BBCODE PARSE
BBCode Parser has changed slightly in vBulletin 3.5.
To familiarize yourself with the new syntax, check out KirbyDE's How-To (https://vborg.vbsupport.ru/showthread.php?t=82693).
.
MISCELLANEOUS
It is impossible to list here every aspect of vBulletin code, therefore you should familizarize yourself with the contents of init.php and class_core.php before beginning to hack into the system (and I know you are in a rush ;)).
$db (Type: Object)
As you might have judged from the Table 1 in this tutorial, the database object in vB3.5 is $vbulletin->db.
However, $db is another way to access that object; it is the way that used everywhere unless you call it from within a function. In functions, use $vbulletin->db.
Obviously, the purpose of the database method is to perform various operations on the database. Most common methods are described below.
$db->query();
Deprecated in favor of below methods (to save memory).
Returns: MySQL Resource
.
$db->query_read();
Performs SELECT and SHOW operations only.
These queries will execute on the slave server, if one is defined.
Returns: MySQL Resource
.
$db->query_write();
Performs INSERT, REPLACE, UPDATE, DROP, ALTER and other data-modifying queries.
These queries will execute on the master server.
Returns: MySQL Resource
.
$db->query_first();
Same as query_read(), but returns first result as an array.
Returns: array on success / boolean false on failure
.
$db->num_rows($mysql_resource_var);
Input: A MySQL resource variable (usually output of the first three methods).
Returns: int Amount of Resulting Rows
.
$db->fetch_array($mysql_resource_var);
Input: A MySQL resource variable (usually output of the first three methods).
Returns: array One row from the mysql results on success / boolean false on failure
To fetch each row consecutively, use the following code:
while ($var = $db->fetch_array($mysql_resource_var))
{
// your code ($var contains the array);
}
$db->insert_id();
Input: None.
Returns: int Row ID of the latest INSERT operation.
.
$db->escape_string(); and $db->escape_string_like();
Input: String.
Returns: string A string with appropriate characters escaped.
These two functions must be used instead of the PHP built-in addslashes() and addslashes_like().
Using the PHP built-in functions may cause problems on non-MySQL systems.
.
$db->show_errors(); and $db->hide_errors();
Input: None.
Returns: None.
The first function enables sql error output (default), whereas the second function disables such output.
Useful when you do not want the script to die on error (example: no die on product installation if a table already exists).
Data Managers
Data Managers (DMs) are an interface to various data objects used within vBulletin. They enforce necessary constraints and administrator-set options on the data to ensure that the data is valid.
You can read more about Data Managers in vBulletin's online manual (http://www.vbulletin.com/docs/html/data_managers).
Also, you can read specifically about the User DM in this KirbyDE's How-To (https://vborg.vbsupport.ru/showthread.php?t=82836), and about Thread DM here (https://vborg.vbsupport.ru/showthread.php?t=97283).
Authentication Storage
The authentication data is stored in the following way (thank to Kirby for this info):
$_COOKIE:
{cookiepfx}userid - plain(userid)
{cookiepfx}password - md5(md5(md5('PlaintextPassword') . salt) . 'LicenseNo').
TABLE user:
password - md5(md5('PlaintextPassword') . salt)
Note that for cookie, {cookiepfx} is your board's cookie prefix. It is configurable via admincp and is accessible via the COOKIE_PREFIX constant.
Important Functions
construct_page_nav($pagenumber, $perpage, $results, $address, $address2 = '');
Returns the HTML for multi-page navigation.
Two latest arguments are not used yet, therefore they are not documented.
$pagenumber int Total number of items found
$perpage string Base address for links eg: showthread.php?t=99{&page=4}
$results string Ending portion of address for links
eval(standard_error(fetch_error('error_phrase')));
Outputs a standard error message with a phrase of your choice.
fetch_error looks up the phrase you specify in the "Front-End Error Messages" phrase category.
Error phrases must be prefixed with "error_".
.
print_standard_redirect($redir_phrase, $doquery = true, $forceredirect = false);
Returns eval()-able code to initiate a standard redirect
$vbulletin->url should contain the target url for the redirect.
$redir_phrase string Name of redirect phrase
$doquery boolean If true, it will fetch $redir_phrase from "Front-End Redirect Messages" phrase category. Must be prefixed with "redirect_".
If false, it will use the value of $redir_phrase as the phrase itself.
$forceredirect boolean Should generally be set to true.
is_valid_email($email);
Checks an email for validity and returns true or false.
.
can_moderate($forumid = 0, $do = '', $userid = -1, $usergroupids = '');
Checks whether a user can moderate a certain forum.
$forumid int Specific forum to check. If not set, will check whether the user is a moderator of any forum at all.
$do string Specific mod action to check. If not set, will check whether the user is a moderator of the forum specified in $forumid.
$userid int User ID to check. If not set, will use $vbulletin->userinfo.
$usergroupids string List of group IDs, separate by commas, to which the user belongs. Should be generally left blank.
can_administer();
Checks whether or not the visiting user has administrative permissions
This function can optionally take any number of parameters, each of which
should be a particular administrative permission you want to check. For example:
can_administer('canadminsettings', 'canadminstyles', 'canadminlanguages')
If any one of these permissions is met, the function will return true.
If no parameters are specified, the function will simply check that the user is an administrator.
.
convert_bits_to_array(&$bitfield, $_FIELDNAMES);
Converts a bitfield into an array of 1 / 0 values based on the array describing the resulting fields. Returns an array.
&$bitfield int (ref) Bitfield
$_FIELDNAMES array Array containing field definitions - array('canx' => 1, 'cany' => 2, 'canz' => 4) etc.
function convert_array_to_bits(&$arry, $_FIELDNAMES, $unset = 0);
Takes an array and returns the bitwise value.
&arry array Array for input.
$_FIELDNAMES array Array containing field definitions - array('canx' => 1, 'cany' => 2, 'canz' => 4) etc.
$unset int Defines whether to unset the array data once it has been converted to bits
fetch_template($templatename, $escape = 0, $gethtmlcomments = true);
Returns a single template from the templatecache or the database.
$templatename string Name of template to be fetched
$escape int Escape quotes in template? 1: escape; -1: unescape; 0: do nothing
$gethtmlcomments boolean Wrap template in HTML comments showing the template name?
Two most common uses are:
eval('$mycustomvar .= "' . fetch_template('mycustomtemplate') . '";');
eval('print_output("' . fetch_template('mycustomtemplate') . '");');
vbsetcookie($name, $value = '', $permanent = true);
Sets a cookie based on vBulletin environmental settings.
$name string Cookie name
$value mixed Value to store in the cookie
$permanent boolean If true, do not set an expiry date for the cookie
vb_number_format($number, $decimals = 0, $bytesize = false, $decimalsep = null, $thousandsep = null);
Formats a number with user's own decimal and thousands chars and returns the formatted number.
$number mixed Number to be formatted: integer / 8MB / 16 GB / 6.0 KB / 3M / 5K / ETC
$decimals integer Number of decimal places to display
$bytesize boolean Special case for byte-based numbers
$decimalsep string Custom decimal separator (to override user's preference)
$thousandsep string Custom thousands separator (to override user's preference)
vbmail($toemail, $subject, $message, $notsubscription = false, $from = '', $uheaders = '', $username = '');
Starts the process of sending an email - either immediately or by adding it to the mail queue.
$toemail string Destination email address
$subject string Email message subject
$message string Email message body
$notsubscription boolean If true, do not use the mail queue and send immediately
$from string Optional name/email to use in 'From' header
$uheaders string Additional headers
$username string Username of person sending the email
Sources Used
vBulletin's source code
vBulletin Online Manual (http://www.vbulletin.com/docs/html/)
Kier's message for developers, released here by Wayne Luke (https://vborg.vbsupport.ru/showpost.php?p=663572&postcount=5)
Scotsmist's contribution post (nice one!) (https://vborg.vbsupport.ru/showpost.php?p=725943&postcount=46)
>> EOD