Compare commits

...

3 Commits

Author SHA1 Message Date
Tony Air 7d0b766882 IMPR: Login forms 2024-03-26 04:58:54 +02:00
Tony Air f6b150b866 IMPR: Login forms 2024-03-26 04:53:12 +02:00
Tony Air 10d35e92fc IMPR: Login forms 2024-03-26 04:22:27 +02:00
4 changed files with 61 additions and 16 deletions

View File

@ -1,5 +1,8 @@
--- ---
Name: a2nt-cms-niceties-base-extensions Name: a2nt-cms-niceties-base-extensions
After:
- login-forms
- '#coresecurity'
--- ---
# Basic extensions # Basic extensions
SilverStripe\Admin\LeftAndMain: SilverStripe\Admin\LeftAndMain:
@ -51,6 +54,10 @@ SilverStripe\Core\Injector\Injector:
class: A2nt\CMSNiceties\Forms\GridField\GridFieldConfig_RelationEditor class: A2nt\CMSNiceties\Forms\GridField\GridFieldConfig_RelationEditor
SilverStripe\Forms\FormRequestHandler: SilverStripe\Forms\FormRequestHandler:
class: A2nt\CMSNiceties\Ajax\AjaxFormRequestHandler class: A2nt\CMSNiceties\Ajax\AjaxFormRequestHandler
SilverStripe\Security\Security:
properties:
Authenticators:
default: '%$A2nt\CMSNiceties\Forms\Authenticator'
SilverStripe\UserForms\Form\UserForm: SilverStripe\UserForms\Form\UserForm:
extensions: extensions:

View File

@ -10,6 +10,7 @@ use SilverStripe\Core\Config\Config;
use SilverStripe\Core\Extension; use SilverStripe\Core\Extension;
use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Injector\Injector;
use SilverStripe\Forms\Form; use SilverStripe\Forms\Form;
use SilverStripe\Forms\HiddenField;
use SilverStripe\ORM\FieldType\DBHTMLText; use SilverStripe\ORM\FieldType\DBHTMLText;
use SilverStripe\ORM\ValidationResult; use SilverStripe\ORM\ValidationResult;
use SilverStripe\Security\MemberAuthenticator\MemberAuthenticator; use SilverStripe\Security\MemberAuthenticator\MemberAuthenticator;
@ -70,23 +71,17 @@ class AjaxControllerEx extends Extension
public function LoginFormEx() public function LoginFormEx()
{ {
$ctrl = $this->owner; $ctrl = Security::singleton();
/* @var Form $form */ /* @var Form $form */
if (method_exists($ctrl, 'LoginForm')) { $form = $ctrl->getLoginForms()['default'][0];
$form = $ctrl->LoginForm();
} else {
$form = $ctrl->getLoginForms()['default'][0];
}
self::_processFields($form); self::_processFields($form);
//$form->addExtraClass('ajax-form'); //$form->addExtraClass('ajax-form');
$back = $this->owner->Link();
if (Director::isLive() && $form->get_protector()) { $form->setFormAction('/Security/login/default/LoginForm/?BackURL='.$back);
$form->enableSpamProtection(); $form->Fields()
} ->push(HiddenField::create('BackURL')->setValue($back));
$form->setLegend( $form->setLegend(
_t( _t(
@ -207,11 +202,9 @@ class AjaxControllerEx extends Extension
$url = $req->getURL(); $url = $req->getURL();
$url = $url === 'home' ? '/' : $url; $url = $url === 'home' ? '/' : $url;
$ajax_res = $ctrl->config()->get('ajax_resources');
$graphql_res = $ctrl->config()->get('graphql_resources');
$resources = array_merge( $resources = array_merge(
$ajax_res ? $ajax_res : [], $ctrl->config()->get('graphql_resources'),
$graphql_res ? $graphql_res : [] $ctrl->config()->get('ajax_resources')
); );
$body = $response->getBody(); $body = $response->getBody();

View File

@ -0,0 +1,13 @@
<?php
namespace A2nt\CMSNiceties\Forms;
use SilverStripe\Security\MemberAuthenticator\MemberAuthenticator;
class Authenticator extends MemberAuthenticator
{
public function getLoginHandler($link)
{
return LoginHandler::create($link, $this);
}
}

View File

@ -0,0 +1,32 @@
<?php
namespace A2nt\CMSNiceties\Forms;
use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Security\MemberAuthenticator\LoginHandler as MemberAuthenticatorLoginHandler;
use SilverStripe\Security\MemberAuthenticator\MemberLoginForm;
class LoginHandler extends MemberAuthenticatorLoginHandler
{
private static $allowed_actions = [
'LoginForm',
];
public function doLogin($data, MemberLoginForm $form, HTTPRequest $request)
{
return parent::doLogin($data, $form, $request);
}
public function loginForm()
{
$form = parent::loginForm();
if (self::config()->get('enable_captcha') && Director::isLive() && $form->get_protector()) {
$form->enableSpamProtection();
}
$form->addExtraClass('legacy');
return $form;
}
}