| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 | 
							- <?php
 
- /**
 
-  * Copyright © Magento, Inc. All rights reserved.
 
-  * See COPYING.txt for license details.
 
-  */
 
- namespace Magento\Sniffs\Security;
 
- use PHP_CodeSniffer\Sniffs\Sniff;
 
- use PHP_CodeSniffer\Files\File;
 
- use PHP_CodeSniffer\Util\Tokens;
 
- /**
 
-  * Detects executable regular expressions.
 
-  *
 
-  * Example: echo preg_replace('|^(.*)$|ei', '"\1"', 'get_input');
 
-  */
 
- class ExecutableRegExSniff implements Sniff
 
- {
 
-     /**
 
-      * String representation of error.
 
-      *
 
-      * @var string
 
-      */
 
-     // @codingStandardsIgnoreLine
 
-     protected $errorMessage = "Possible executable regular expression in %s. Make sure that the pattern doesn't contain 'e' modifier";
 
-     /**
 
-      * Error violation code.
 
-      *
 
-      * @var string
 
-      */
 
-     protected $errorCode = 'PossibleExecutableRegEx';
 
-     /**
 
-      * Observed function.
 
-      *
 
-      * @var array
 
-      */
 
-     protected $function = 'preg_replace';
 
-     /**
 
-      * List of ignored tokens.
 
-      *
 
-      * @var array
 
-      */
 
-     protected $ignoreTokens = [
 
-         T_DOUBLE_COLON,
 
-         T_OBJECT_OPERATOR,
 
-         T_FUNCTION,
 
-         T_CONST,
 
-         T_CLASS,
 
-     ];
 
-     /**
 
-      * @inheritdoc
 
-      */
 
-     public function register()
 
-     {
 
-         return [T_STRING];
 
-     }
 
-     /**
 
-      * @inheritdoc
 
-      */
 
-     public function process(File $phpcsFile, $stackPtr)
 
-     {
 
-         $tokens = $phpcsFile->getTokens();
 
-         if ($tokens[$stackPtr]['content'] !== $this->function) {
 
-             return;
 
-         }
 
-         $prevToken = $phpcsFile->findPrevious(T_WHITESPACE, $stackPtr - 1, null, true);
 
-         if (in_array($tokens[$prevToken]['code'], $this->ignoreTokens)) {
 
-             return;
 
-         }
 
-         $nextToken = $phpcsFile->findNext([T_WHITESPACE, T_OPEN_PARENTHESIS], $stackPtr + 1, null, true);
 
-         if (in_array($tokens[$nextToken]['code'], Tokens::$stringTokens)
 
-             && preg_match('/[#\/|~\}\)][imsxADSUXJu]*e[imsxADSUXJu]*.$/', $tokens[$nextToken]['content'])
 
-         ) {
 
-             $phpcsFile->addError(
 
-                 $this->errorMessage,
 
-                 $stackPtr,
 
-                 $this->errorCode,
 
-                 [$tokens[$stackPtr]['content']]
 
-             );
 
-         }
 
-     }
 
- }
 
 
  |