2016-10-14 14:30:05 +13:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\Forms\Tests\FormTest;
|
|
|
|
|
|
|
|
use SilverStripe\Control\Controller;
|
2022-10-17 17:58:20 +13:00
|
|
|
use SilverStripe\Control\HTTPResponse;
|
2016-10-14 14:30:05 +13:00
|
|
|
use SilverStripe\Dev\TestOnly;
|
|
|
|
use SilverStripe\Forms\EmailField;
|
|
|
|
use SilverStripe\Forms\FieldList;
|
|
|
|
use SilverStripe\Forms\Form;
|
|
|
|
use SilverStripe\Forms\FormAction;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @skipUpgrade
|
|
|
|
*/
|
|
|
|
class ControllerWithSecurityToken extends Controller implements TestOnly
|
|
|
|
{
|
|
|
|
|
2020-04-20 18:58:09 +01:00
|
|
|
private static $allowed_actions = ['Form'];
|
2016-12-16 17:34:21 +13:00
|
|
|
|
2020-04-20 18:58:09 +01:00
|
|
|
private static $url_handlers = [
|
2016-12-16 17:34:21 +13:00
|
|
|
'$Action//$ID/$OtherID' => "handleAction",
|
2020-04-20 18:58:09 +01:00
|
|
|
];
|
2016-12-16 17:34:21 +13:00
|
|
|
|
|
|
|
protected $template = 'BlankPage';
|
|
|
|
|
|
|
|
public function Link($action = null)
|
|
|
|
{
|
|
|
|
return Controller::join_links(
|
|
|
|
'FormTest_ControllerWithSecurityToken',
|
|
|
|
$this->getRequest()->latestParam('Action'),
|
|
|
|
$this->getRequest()->latestParam('ID'),
|
|
|
|
$action
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function Form()
|
|
|
|
{
|
|
|
|
$form = new Form(
|
|
|
|
$this,
|
|
|
|
'Form',
|
|
|
|
new FieldList(
|
|
|
|
new EmailField('Email')
|
|
|
|
),
|
|
|
|
new FieldList(
|
|
|
|
new FormAction('doSubmit')
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
return $form;
|
|
|
|
}
|
|
|
|
|
2022-10-17 17:58:20 +13:00
|
|
|
public function doSubmit(array $data, Form $form): HTTPResponse
|
2016-12-16 17:34:21 +13:00
|
|
|
{
|
|
|
|
$form->sessionMessage('Test save was successful', 'good');
|
|
|
|
return $this->redirectBack();
|
|
|
|
}
|
2016-10-14 14:30:05 +13:00
|
|
|
}
|