Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. PregSecuritySniff.php

function PregSecuritySniff::processFunctionCall

Processes this function call.

Parameters

\PHP_CodeSniffer\Files\File $phpcsFile The file being scanned.:

int $stackPtr The position of the function call in: the stack.

int $openBracket The position of the opening: parenthesis in the stack.

int $closeBracket The position of the closing: parenthesis in the stack.

Return value

void

File

vendor/drupal/coder/coder_sniffer/Drupal/Sniffs/Semantics/PregSecuritySniff.php, line 59

Class

PregSecuritySniff
Check the usage of the preg functions to ensure the insecure /e flag isn't used: https://www.drupal.org/node/750148

Namespace

Drupal\Sniffs\Semantics

Code

public function processFunctionCall(File $phpcsFile, $stackPtr, $openBracket, $closeBracket) {
    $tokens = $phpcsFile->getTokens();
    $argument = $this->getArgument(1);
    if ($argument === false) {
        return;
    }
    if ($tokens[$argument['start']]['code'] !== T_CONSTANT_ENCAPSED_STRING) {
        // Not a string literal.
        // @TODO: Extend code to recognize patterns in variables.
        return;
    }
    $pattern = $tokens[$argument['start']]['content'];
    $quote = substr($pattern, 0, 1);
    // Check that the pattern is a string.
    if ($quote === '"' || $quote === "'") {
        // Get the delimiter - first char after the enclosing quotes.
        $delimiter = preg_quote(substr($pattern, 1, 1), '/');
        // Check if there is the evil e flag.
        if (preg_match('/' . $delimiter . '[\\w]{0,}e[\\w]{0,}$/', substr($pattern, 0, -1)) === 1) {
            $warn = 'Using the e flag in %s is a possible security risk. For details see https://www.drupal.org/node/750148';
            $phpcsFile->addError($warn, $argument['start'], 'PregEFlag', [
                $tokens[$stackPtr]['content'],
            ]);
            return;
        }
    }
}

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal