Merge branch '4.11' into 4

This commit is contained in:
Guy Sartorelli 2022-09-29 09:41:06 +13:00
commit 421864d111
No known key found for this signature in database
GPG Key ID: F313E3B9504D496A
5 changed files with 73 additions and 1 deletions

View File

@ -63,6 +63,11 @@ class ExtensionMiddleware implements Middleware
$extensions = $extensionSourceConfig['extensions']; $extensions = $extensionSourceConfig['extensions'];
foreach ($extensions as $extension) { foreach ($extensions as $extension) {
// Allow removing extensions via yaml config by setting named extension config to null
if ($extension === null) {
continue;
}
list($extensionClass, $extensionArgs) = ClassInfo::parse_class_spec($extension); list($extensionClass, $extensionArgs) = ClassInfo::parse_class_spec($extension);
// Strip service name specifier // Strip service name specifier
$extensionClass = strtok($extensionClass ?? '', '.'); $extensionClass = strtok($extensionClass ?? '', '.');

View File

@ -553,6 +553,11 @@ trait Extensible
if ($extensions) { if ($extensions) {
foreach ($extensions as $extension) { foreach ($extensions as $extension) {
// Allow removing extensions via yaml config by setting named extension config to null
if ($extension === null) {
continue;
}
$name = $extension; $name = $extension;
// Allow service names of the form "%$ServiceName" // Allow service names of the form "%$ServiceName"
if (substr($name ?? '', 0, 2) == '%$') { if (substr($name ?? '', 0, 2) == '%$') {

View File

@ -47,7 +47,7 @@ class MemberAuthenticator implements Authenticator
// Optionally record every login attempt as a {@link LoginAttempt} object // Optionally record every login attempt as a {@link LoginAttempt} object
$this->recordLoginAttempt($data, $request, $member, $result->isValid()); $this->recordLoginAttempt($data, $request, $member, $result->isValid());
if ($member) { if ($member && $request->hasSession()) {
$request->getSession()->clear('BackURL'); $request->getSession()->clear('BackURL');
} }

View File

@ -0,0 +1,48 @@
<?php
namespace SilverStripe\Core\Tests;
use BadMethodCallException;
use ReflectionProperty;
use SilverStripe\Core\Config\Config;
use SilverStripe\Core\Tests\ExtensionTest\NamedExtension;
use SilverStripe\Dev\SapphireTest;
use SilverStripe\ORM\DataObject;
class ExtensionTest extends SapphireTest
{
protected function setUp(): void
{
parent::setUp();
// Reset extra_methods so that when we set NamedExtension to null it re-evaluates which methods are available
$reflectionProperty = new ReflectionProperty(DataObject::class, 'extra_methods');
$reflectionProperty->setAccessible(true);
$reflectionProperty->setValue([]);
// Add named extension config like we would in yaml
Config::modify()->merge(DataObject::class, 'extensions', ['NamedExtension' => NamedExtension::class]);
}
public function testHasNamedExtension()
{
$this->assertTrue(DataObject::has_extension(NamedExtension::class));
$instance = new DataObject();
$this->assertTrue($instance->hasMethod('getTestValue'));
$this->assertSame('test', $instance->getTestValue());
}
public function testRemoveNamedExtension()
{
Config::modify()->merge(DataObject::class, 'extensions', ['NamedExtension' => null]);
$this->assertFalse(DataObject::has_extension(NamedExtension::class));
$instance = new DataObject();
$this->assertFalse($instance->hasMethod('getTestValue'));
}
public function testRemoveNamedExtensionException()
{
Config::modify()->merge(DataObject::class, 'extensions', ['NamedExtension' => null]);
$instance = new DataObject();
$this->expectException(BadMethodCallException::class);
$instance->getTestValue();
}
}

View File

@ -0,0 +1,14 @@
<?php
namespace SilverStripe\Core\Tests\ExtensionTest;
use SilverStripe\Core\Extension;
use SilverStripe\Dev\TestOnly;
class NamedExtension extends Extension implements TestOnly
{
public function getTestValue()
{
return 'test';
}
}