67 lines
1.8 KiB
PHP
67 lines
1.8 KiB
PHP
<?php
|
|
/**
|
|
* WordPress Coding Standard.
|
|
*
|
|
* @package WPCS\WordPressCodingStandards
|
|
* @link https://github.com/WordPress/WordPress-Coding-Standards
|
|
* @license https://opensource.org/licenses/MIT MIT
|
|
*/
|
|
|
|
namespace WordPressCS\WordPress\Sniffs\DB;
|
|
|
|
use WordPressCS\WordPress\AbstractFunctionRestrictionsSniff;
|
|
|
|
/**
|
|
* Verifies that no database related PHP functions are used.
|
|
*
|
|
* "Avoid touching the database directly. If there is a defined function that can get
|
|
* the data you need, use it. Database abstraction (using functions instead of queries)
|
|
* helps keep your code forward-compatible and, in cases where results are cached in memory,
|
|
* it can be many times faster."
|
|
*
|
|
* @link https://make.wordpress.org/core/handbook/best-practices/coding-standards/php/#database-queries
|
|
*
|
|
* @package WPCS\WordPressCodingStandards
|
|
*
|
|
* @since 0.10.0
|
|
* @since 0.13.0 Class name changed: this class is now namespaced.
|
|
*/
|
|
class RestrictedFunctionsSniff extends AbstractFunctionRestrictionsSniff {
|
|
|
|
/**
|
|
* Groups of functions to restrict.
|
|
*
|
|
* Example: groups => array(
|
|
* 'lambda' => array(
|
|
* 'type' => 'error' | 'warning',
|
|
* 'message' => 'Use anonymous functions instead please!',
|
|
* 'functions' => array( 'file_get_contents', 'create_function' ),
|
|
* )
|
|
* )
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getGroups() {
|
|
return array(
|
|
|
|
'mysql' => array(
|
|
'type' => 'error',
|
|
'message' => 'Accessing the database directly should be avoided. Please use the $wpdb object and associated functions instead. Found: %s.',
|
|
'functions' => array(
|
|
'mysql_*',
|
|
'mysqli_*',
|
|
'mysqlnd_ms_*',
|
|
'mysqlnd_qc_*',
|
|
'mysqlnd_uh_*',
|
|
'mysqlnd_memcache_*',
|
|
'maxdb_*',
|
|
),
|
|
'whitelist' => array(
|
|
'mysql_to_rfc3339' => true,
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
}
|