mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge branch '4.1' into 4.2
This commit is contained in:
commit
b984959170
@ -45,6 +45,7 @@ class Backtrace
|
||||
array('SilverStripe\\Security\\PasswordEncryptor_MySQLOldPassword', 'salt'),
|
||||
array('SilverStripe\\Security\\PasswordEncryptor_Blowfish', 'encrypt'),
|
||||
array('SilverStripe\\Security\\PasswordEncryptor_Blowfish', 'salt'),
|
||||
array('*', 'updateValidatePassword'),
|
||||
);
|
||||
|
||||
/**
|
||||
@ -106,7 +107,10 @@ class Backtrace
|
||||
$match = false;
|
||||
if (!empty($bt[$i]['class'])) {
|
||||
foreach ($ignoredArgs as $fnSpec) {
|
||||
if (is_array($fnSpec) && $bt[$i]['class'] == $fnSpec[0] && $bt[$i]['function'] == $fnSpec[1]) {
|
||||
if (is_array($fnSpec) &&
|
||||
('*' == $fnSpec[0] || $bt[$i]['class'] == $fnSpec[0]) &&
|
||||
$bt[$i]['function'] == $fnSpec[1]
|
||||
) {
|
||||
$match = true;
|
||||
}
|
||||
}
|
||||
|
@ -424,6 +424,10 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
|
||||
// Get duplicates
|
||||
if ($relations === null) {
|
||||
$relations = $this->config()->get('cascade_duplicates');
|
||||
// Remove any duplicate entries before duplicating them
|
||||
if (is_array($relations)) {
|
||||
$relations = array_unique($relations);
|
||||
}
|
||||
}
|
||||
|
||||
// Create unsaved raw duplicate
|
||||
|
@ -68,4 +68,45 @@ class BacktraceTest extends SapphireTest
|
||||
$this->assertEquals('<filtered>', $filtered[1]['args']['password'], 'Filters class functions');
|
||||
$this->assertEquals('myval', $filtered[2]['args']['myarg'], 'Doesnt filter other functions');
|
||||
}
|
||||
|
||||
public function testFilteredWildCard()
|
||||
{
|
||||
$bt = array(
|
||||
array(
|
||||
'type' => '->',
|
||||
'file' => 'MyFile.php',
|
||||
'line' => 99,
|
||||
'function' => 'myIgnoredGlobalFunction',
|
||||
'args' => array('password' => 'secred',)
|
||||
),
|
||||
array(
|
||||
'class' => 'MyClass',
|
||||
'type' => '->',
|
||||
'file' => 'MyFile.php',
|
||||
'line' => 99,
|
||||
'function' => 'myIgnoredClassFunction',
|
||||
'args' => array('password' => 'secred',)
|
||||
),
|
||||
array(
|
||||
'class' => 'MyClass',
|
||||
'type' => '->',
|
||||
'file' => 'MyFile.php',
|
||||
'line' => 99,
|
||||
'function' => 'myFunction',
|
||||
'args' => array('myarg' => 'myval')
|
||||
)
|
||||
);
|
||||
Backtrace::config()->update(
|
||||
'ignore_function_args',
|
||||
array(
|
||||
array('*', 'myIgnoredClassFunction'),
|
||||
)
|
||||
);
|
||||
|
||||
$filtered = Backtrace::filter_backtrace($bt);
|
||||
|
||||
$this->assertEquals('secred', $filtered[0]['args']['password']);
|
||||
$this->assertEquals('<filtered>', $filtered[1]['args']['password']);
|
||||
$this->assertEquals('myval', $filtered[2]['args']['myarg']);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user