| Server IP : 68.183.124.220 / Your IP : 216.73.217.137 Web Server : Apache/2.4.18 (Ubuntu) System : Linux Sandbox-A 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : gavin ( 1000) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /var/www/html/wp-content/plugins/wordpress-seo/config/php-scoper/ |
Upload File : |
<?php
declare( strict_types=1 );
use Isolated\Symfony\Component\Finder\Finder;
return array(
/*
* By default when running php-scoper add-prefix, it will prefix all relevant code found in the current working
* directory. You can however define which files should be scoped by defining a collection of Finders in the
* following configuration key.
*
* For more see: https://github.com/humbug/php-scoper#finders-and-paths
*/
'finders' => array(
Finder::create()->files()->in( 'vendor/ruckusing/ruckusing-migrations' )
->exclude( [ 'config', 'tests', 'lib/Task/Hello' ] )
->name( [ '*.php', 'LICENSE', 'composer.json' ] ),
),
/*
* When scoping PHP files, there will be scenarios where some of the code being scoped indirectly references the
* original namespace. These will include, for example, strings or string manipulations. PHP-Scoper has limited
* support for prefixing such strings. To circumvent that, you can define patchers to manipulate the file to your
* heart contents.
*
* For more see: https://github.com/humbug/php-scoper#patchers
*/
'patchers' => array(
/**
* Replaces the Adapter string references with the prefixed versions.
*
* @param string $filePath The path of the current file.
* @param string $prefix The prefix to be used.
* @param string $content The content of the specific file.
*
* @return string The modified content.
*/
function( $file_path, $prefix, $content ) {
if ( substr( $file_path, -33 ) !== 'lib/Ruckusing/FrameworkRunner.php' ) {
return $content;
}
$replaced = preg_replace(
'/\$adapter_class = "Ruckusing_Adapter_(MySQL|PgSQL|Sqlite3)_Base"/',
sprintf( '$adapter_class = "\%s\Ruckusing_Adapter_\\1_Base"', $prefix ),
$content
);
$replaced = str_replace(
"\set_error_handler(array('Ruckusing_Exception', 'errorHandler'), \E_ALL);",
sprintf( '\set_error_handler(array(\'\%s\Ruckusing_Exception\', \'errorHandler\'), \E_ALL);', $prefix ),
$replaced
);
$replaced = str_replace(
"\set_exception_handler(array('Ruckusing_Exception', 'exceptionHandler'));",
sprintf( '\set_exception_handler(array(\'\%s\Ruckusing_Exception\', \'exceptionHandler\'));', $prefix ),
$replaced
);
return $replaced;
},
/**
* Replaces a string reference to a class with the prefixed version.
*
* @param string $file_path The path of the current file.
* @param string $prefix The prefix to be used.
* @param string $content The content of the specific file.
*
* @return string The modified content.
*/
function( $file_path, $prefix, $content ) {
if ( substr( $file_path, -27 ) !== 'Ruckusing/Util/Migrator.php' ) {
return $content;
}
$replaced = str_replace(
'"Ruckusing_Util_Migrator"',
sprintf( '"\%s\Ruckusing_Util_Migrator"', $prefix ),
$content
);
return $replaced;
},
/**
* Prefixes the Namespace prefix define.
*
* @param string $file_path The path of the current file.
* @param string $prefix The prefix to be used.
* @param string $content The content of the specific file.
*
* @return string The modified content.
*/
function( $file_path, $prefix, $content ) {
if ( substr( $file_path, -25 ) !== 'Ruckusing/Util/Naming.php' ) {
return $content;
}
$replaced = str_replace(
'const CLASS_NS_PREFIX = \'Task_\'',
sprintf( 'const CLASS_NS_PREFIX = \'\%s\Task_\'', $prefix ),
$content
);
return $replaced;
},
/**
* Escapes the namespace for use in a regex match.
*
* @param string $file_path The path of the current file.
* @param string $prefix The prefix to be used.
* @param string $content The content of the specific file.
*
* @return string The modified content.
*/
function( $file_path, $prefix, $content ) {
if ( substr( $file_path, -25 ) !== 'Ruckusing/Util/Naming.php' ) {
return $content;
}
$replaced = str_replace(
'preg_match(\'/\' . self::CLASS_NS_PREFIX . \'/\'',
'preg_match(\'/\' . preg_quote(self::CLASS_NS_PREFIX) . \'/\'',
$content
);
return $replaced;
},
),
/*
* By default, PHP-Scoper will not prefix the user defined constants, classes and functions belonging to the global
* namespace. You can however change that setting for them to be prefixed as usual unless explicitly whitelisted.
*
* https://github.com/humbug/php-scoper#whitelist
*/
'whitelist-global-constants' => false,
'whitelist-global-classes' => false,
'whitelist' => [ 'FALSE', 'NULL' ],
);