coder_review_security_reviews()Implements hook_reviews().
sites/all/modules/coder/coder_review/includes/coder_review_security.inc, line 13
<?php
function coder_review_security_reviews() {
$table = '\{[A-Za-z_]+\}'; // table-regex
$rules = array(
array(
'#type' => 'regex',
'#value' => '[\s\(]l\(check_plain\(.*',
'#never' => '[\'"]html[\'"]\s*=>\s*(TRUE|1)',
'#source' => 'allphp',
'#warning_callback' => '_coder_review_security_l_check_plain_warning',
),
/* array(
'#type' => 'callback',
'#value' => _coder_review_security_callback,
), */
array(
'#type' => 'regex',
'#value' => '(?-i)\$REQUEST_URI',
'#warning_callback' => '_coder_review_security_request_uri_warning',
),
array(
'#type' => 'regex',
'#source' => 'allphp',
'#value' => '(?-i)\"REQUEST_URI\"|\'REQUEST_URI\'',
'#warning_callback' => '_coder_review_security_request_uri_warning',
),
array(
'#type' => 'regex',
'#value' => '^(select\s+.*\s+from\s+' . $table . '|insert\s+into\s+' . $table . '|update\s+' . $table . '\s+set|delete\s+from\s+' . $table . ')\s+.*\$[a-z0-9_]+',
'#not' => '\$placeholder',
'#never' => '[\s\(]update_sql\(',
'#source' => 'quote',
'#warning_callback' => '_coder_review_security_sql_var_warning',
),
array(
'#type' => 'regex',
'#value' => '^(select\s+.*\s+from\s+' . $table . '|insert\s+into\s+' . $table . '|update\s+' . $table . '\s+set|delete\s+from\s' . $table . ')\s+[^\']*?(\s+|\(|=|,)\%s',
'#source' => 'quote',
'#warning' => 'SQL query handling data in a potentially insecure way by using the %%s placeholder without wrapping it in single quotes. This is a potential source of SQL injection attacks when the value can come from user data.',
),
);
$review = array(
'#title' => 'Drupal Security Checks',
'#link' => 'http://drupal.org/node/28984',
'#rules' => $rules,
'#severity' => 'critical',
'#description' => t('very basic, needs work, but what it finds is good'),
);
return array('security' => $review);
}
?>