API Strongly-type action method signatures

This commit is contained in:
Steve Boyd 2022-10-17 17:58:20 +13:00
parent 83a09daa3a
commit a57c7315a2
20 changed files with 83 additions and 108 deletions

View File

@ -73,10 +73,8 @@ class Controller extends RequestHandler implements TemplateGlobalProvider
* The response object that the controller returns. * The response object that the controller returns.
* *
* Set in {@link handleRequest()}. * Set in {@link handleRequest()}.
*
* @var HTTPResponse
*/ */
protected $response; protected HTTPResponse $response;
/** /**
* Default URL handlers. * Default URL handlers.
@ -95,6 +93,12 @@ class Controller extends RequestHandler implements TemplateGlobalProvider
'handleIndex', 'handleIndex',
]; ];
public function __construct()
{
parent::__construct();
$this->setResponse(HTTPResponse::create());
}
/** /**
* Initialisation function that is run before any action on the controller is called. * Initialisation function that is run before any action on the controller is called.
* *
@ -142,12 +146,11 @@ class Controller extends RequestHandler implements TemplateGlobalProvider
* *
* Also set the URLParams * Also set the URLParams
*/ */
public function setRequest($request) public function setRequest(HTTPRequest $request): static
{ {
$return = parent::setRequest($request); parent::setRequest($request);
$this->setURLParams($this->getRequest()->allParams()); $this->setURLParams($this->getRequest()->allParams());
return $this;
return $return;
} }
/** /**
@ -192,11 +195,8 @@ class Controller extends RequestHandler implements TemplateGlobalProvider
* Important: If you are going to overload handleRequest, * Important: If you are going to overload handleRequest,
* make sure that you start the method with $this->beforeHandleRequest() * make sure that you start the method with $this->beforeHandleRequest()
* and end the method with $this->afterHandleRequest() * and end the method with $this->afterHandleRequest()
*
* @param HTTPRequest $request
* @return HTTPResponse
*/ */
public function handleRequest(HTTPRequest $request) public function handleRequest(HTTPRequest $request): HTTPResponse
{ {
if (!$request) { if (!$request) {
throw new \RuntimeException('Controller::handleRequest() not passed a request!'); throw new \RuntimeException('Controller::handleRequest() not passed a request!');
@ -332,14 +332,9 @@ class Controller extends RequestHandler implements TemplateGlobalProvider
/** /**
* Returns the HTTPResponse object that this controller is building up. Can be used to set the * Returns the HTTPResponse object that this controller is building up. Can be used to set the
* status code and headers. * status code and headers.
*
* @return HTTPResponse
*/ */
public function getResponse() public function getResponse(): HTTPResponse
{ {
if (!$this->response) {
$this->setResponse(new HTTPResponse());
}
return $this->response; return $this->response;
} }
@ -628,17 +623,14 @@ class Controller extends RequestHandler implements TemplateGlobalProvider
/** /**
* Redirect to the given URL. * Redirect to the given URL.
*
* @param string $url
* @param int $code
* @return HTTPResponse
*/ */
public function redirect($url, $code = 302) public function redirect(string $url, int $code = 302): HTTPResponse
{ {
if ($this->getResponse()->getHeader('Location') && $this->getResponse()->getHeader('Location') != $url) { $response = $this->getResponse();
if ($response->getHeader('Location') && $response->getHeader('Location') != $url) {
user_error("Already directed to " . $this->getResponse()->getHeader('Location') user_error("Already directed to " . $this->getResponse()->getHeader('Location')
. "; now trying to direct to $url", E_USER_WARNING); . "; now trying to direct to $url", E_USER_WARNING);
return null; return $response;
} }
$response = parent::redirect($url, $code); $response = parent::redirect($url, $code);
$this->setResponse($response); $this->setResponse($response);

View File

@ -310,13 +310,7 @@ class HTTPResponse
return $this; return $this;
} }
/** public function redirect(string $dest, int $code = 302): static
* @param string $dest
* @param int $code
*
* @return $this
*/
public function redirect($dest, $code = 302)
{ {
if (!in_array($code, self::$redirect_codes)) { if (!in_array($code, self::$redirect_codes)) {
trigger_error("Invalid HTTP redirect code {$code}", E_USER_WARNING); trigger_error("Invalid HTTP redirect code {$code}", E_USER_WARNING);

View File

@ -17,7 +17,7 @@ use Exception;
class HTTPResponse_Exception extends Exception class HTTPResponse_Exception extends Exception
{ {
protected $response; protected HTTPResponse $response;
/** /**
* @param HTTPResponse|string $body Either the plaintext content of the error * @param HTTPResponse|string $body Either the plaintext content of the error
@ -52,17 +52,11 @@ class HTTPResponse_Exception extends Exception
parent::__construct((string) $this->getResponse()->getBody(), $this->getResponse()->getStatusCode()); parent::__construct((string) $this->getResponse()->getBody(), $this->getResponse()->getStatusCode());
} }
/** public function getResponse(): HTTPResponse
* @return HTTPResponse
*/
public function getResponse()
{ {
return $this->response; return $this->response;
} }
/**
* @param HTTPResponse $response
*/
public function setResponse(HTTPResponse $response) public function setResponse(HTTPResponse $response)
{ {
$this->response = $response; $this->response = $response;

View File

@ -30,7 +30,7 @@ class PjaxResponseNegotiator
*/ */
protected $callbacks = []; protected $callbacks = [];
protected $response = null; protected HTTPResponse $response;
/** /**
* Overridden fragments (if any). Otherwise uses fragments from the request. * Overridden fragments (if any). Otherwise uses fragments from the request.
@ -41,21 +41,18 @@ class PjaxResponseNegotiator
* @param array $callbacks * @param array $callbacks
* @param HTTPResponse $response An existing response to reuse (optional) * @param HTTPResponse $response An existing response to reuse (optional)
*/ */
public function __construct($callbacks = [], $response = null) public function __construct($callbacks = [], HTTPResponse $response = null)
{ {
$this->callbacks = $callbacks; $this->callbacks = $callbacks;
$this->response = $response; $this->response = $response ?: HTTPResponse::create();
} }
public function getResponse() public function getResponse(): HTTPResponse
{ {
if (!$this->response) {
$this->response = new HTTPResponse();
}
return $this->response; return $this->response;
} }
public function setResponse($response) public function setResponse(HTTPResponse $response)
{ {
$this->response = $response; $this->response = $response;
} }
@ -68,10 +65,9 @@ class PjaxResponseNegotiator
* @param array $extraCallbacks List of anonymous functions or callables returning either a string * @param array $extraCallbacks List of anonymous functions or callables returning either a string
* or HTTPResponse, keyed by their fragment identifier. The 'default' key can * or HTTPResponse, keyed by their fragment identifier. The 'default' key can
* be used as a fallback for non-ajax responses. * be used as a fallback for non-ajax responses.
* @return HTTPResponse
* @throws HTTPResponse_Exception * @throws HTTPResponse_Exception
*/ */
public function respond(HTTPRequest $request, $extraCallbacks = []) public function respond(HTTPRequest $request, $extraCallbacks = []): HTTPResponse
{ {
// Prepare the default options and combine with the others // Prepare the default options and combine with the others
$callbacks = array_merge($this->callbacks, $extraCallbacks); $callbacks = array_merge($this->callbacks, $extraCallbacks);

View File

@ -60,7 +60,7 @@ class RequestHandler extends ViewableData
* @var HTTPRequest $request The request object that the controller was called with. * @var HTTPRequest $request The request object that the controller was called with.
* Set in {@link handleRequest()}. Useful to generate the {} * Set in {@link handleRequest()}. Useful to generate the {}
*/ */
protected $request = null; protected HTTPRequest $request;
/** /**
* The DataModel for this request * The DataModel for this request
@ -543,11 +543,8 @@ class RequestHandler extends ViewableData
/** /**
* Typically the request is set through {@link handleAction()} * Typically the request is set through {@link handleAction()}
* or {@link handleRequest()}, but in some based we want to set it manually. * or {@link handleRequest()}, but in some based we want to set it manually.
*
* @param HTTPRequest $request
* @return $this
*/ */
public function setRequest($request) public function setRequest(HTTPRequest $request): static
{ {
$this->request = $request; $this->request = $request;
return $this; return $this;
@ -581,12 +578,8 @@ class RequestHandler extends ViewableData
/** /**
* Redirect to the given URL. * Redirect to the given URL.
*
* @param string $url
* @param int $code
* @return HTTPResponse
*/ */
public function redirect($url, $code = 302) public function redirect(string $url, int $code = 302): HTTPResponse
{ {
$url = Director::absoluteURL($url); $url = Director::absoluteURL($url);
$response = new HTTPResponse(); $response = new HTTPResponse();
@ -655,10 +648,8 @@ class RequestHandler extends ViewableData
* URL (see {@link Director::baseURL()}). * URL (see {@link Director::baseURL()}).
* *
* @uses redirect() * @uses redirect()
*
* @return HTTPResponse
*/ */
public function redirectBack() public function redirectBack(): HTTPResponse
{ {
// Prefer to redirect to ?BackURL, but fall back to Referer header // Prefer to redirect to ?BackURL, but fall back to Referer header
// As a last resort redirect to base url // As a last resort redirect to base url

View File

@ -4,6 +4,8 @@ namespace SilverStripe\Dev;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\Director; use SilverStripe\Control\Director;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\ORM\DatabaseAdmin; use SilverStripe\ORM\DatabaseAdmin;
class DevBuildController extends Controller class DevBuildController extends Controller
@ -17,7 +19,7 @@ class DevBuildController extends Controller
'build' 'build'
]; ];
public function build($request) public function build(HTTPRequest $request): HTTPResponse
{ {
if (Director::is_cli()) { if (Director::is_cli()) {
$da = DatabaseAdmin::create(); $da = DatabaseAdmin::create();

View File

@ -23,7 +23,8 @@ use SilverStripe\ORM\DataObjectInterface;
* <code> * <code>
* class ExampleFormController extends PageController { * class ExampleFormController extends PageController {
* *
* function Form() { * public function Form(): Form
* {
* $fields = new FieldList( * $fields = new FieldList(
* new TextField('MyName'), * new TextField('MyName'),
* new FileField('MyFile') * new FileField('MyFile')
@ -31,12 +32,13 @@ use SilverStripe\ORM\DataObjectInterface;
* $actions = new FieldList( * $actions = new FieldList(
* new FormAction('doUpload', 'Upload file') * new FormAction('doUpload', 'Upload file')
* ); * );
* $validator = new RequiredFields(['MyName', 'MyFile']); * $validator = new RequiredFields(['MyName', 'MyFile']);
* *
* return new Form($this, 'Form', $fields, $actions, $validator); * return new Form($this, 'Form', $fields, $actions, $validator);
* } * }
* *
* function doUpload($data, $form) { * public function doUpload((array $data, Form $form): HTTPResponse
* {
* $file = $data['MyFile']; * $file = $data['MyFile'];
* $content = file_get_contents($file['tmp_name']); * $content = file_get_contents($file['tmp_name']);
* // ... process content * // ... process content

View File

@ -103,7 +103,7 @@ class FormRequestHandler extends RequestHandler
* if the form is valid. * if the form is valid.
* *
* @param HTTPRequest $request * @param HTTPRequest $request
* @return HTTPResponse * @return mixed
* @throws HTTPResponse_Exception * @throws HTTPResponse_Exception
*/ */
public function httpSubmission($request) public function httpSubmission($request)
@ -200,7 +200,7 @@ class FormRequestHandler extends RequestHandler
// buttonClicked() validates that the action set above is valid // buttonClicked() validates that the action set above is valid
&& !$this->buttonClicked() && !$this->buttonClicked()
) { ) {
return $this->httpError( $this->httpError(
403, 403,
sprintf('Action "%s" not allowed on controller (Class: %s)', $funcName, get_class($controller)) sprintf('Action "%s" not allowed on controller (Class: %s)', $funcName, get_class($controller))
); );
@ -209,7 +209,7 @@ class FormRequestHandler extends RequestHandler
$this->hasMethod($funcName) $this->hasMethod($funcName)
&& !$this->checkAccessAction($funcName) && !$this->checkAccessAction($funcName)
) { ) {
return $this->httpError( $this->httpError(
403, 403,
sprintf('Action "%s" not allowed on form request handler (Class: "%s")', $funcName, static::class) sprintf('Action "%s" not allowed on form request handler (Class: "%s")', $funcName, static::class)
); );
@ -261,7 +261,7 @@ class FormRequestHandler extends RequestHandler
); );
} }
return $this->httpError(404, "Could not find a suitable form-action callback function"); $this->httpError(404, "Could not find a suitable form-action callback function");
} }
/** /**
@ -299,11 +299,8 @@ class FormRequestHandler extends RequestHandler
* handles 'application/json' requests with a JSON object containing the error messages. * handles 'application/json' requests with a JSON object containing the error messages.
* Behaviour can be influenced by setting {@link $redirectToFormOnValidationError}, * Behaviour can be influenced by setting {@link $redirectToFormOnValidationError},
* and can be overruled by setting {@link $validationResponseCallback}. * and can be overruled by setting {@link $validationResponseCallback}.
*
* @param ValidationResult $result
* @return HTTPResponse
*/ */
protected function getValidationErrorResponse(ValidationResult $result) protected function getValidationErrorResponse(ValidationResult $result): HTTPResponse
{ {
// Check for custom handling mechanism // Check for custom handling mechanism
$callback = $this->form->getValidationResponseCallback(); $callback = $this->form->getValidationResponseCallback();
@ -329,10 +326,8 @@ class FormRequestHandler extends RequestHandler
/** /**
* Redirect back to this form with an added #anchor link * Redirect back to this form with an added #anchor link
*
* @return HTTPResponse
*/ */
public function redirectBackToForm() public function redirectBackToForm(): HTTPResponse
{ {
$pageURL = $this->getReturnReferer(); $pageURL = $this->getReturnReferer();
if (!$pageURL) { if (!$pageURL) {
@ -369,9 +364,8 @@ class FormRequestHandler extends RequestHandler
* *
* @internal called from {@see Form::getValidationErrorResponse} * @internal called from {@see Form::getValidationErrorResponse}
* @param ValidationResult $result * @param ValidationResult $result
* @return HTTPResponse
*/ */
protected function getAjaxErrorResponse(ValidationResult $result) protected function getAjaxErrorResponse(ValidationResult $result): HTTPResponse
{ {
// Ajax form submissions accept json encoded errors by default // Ajax form submissions accept json encoded errors by default
$acceptType = $this->getRequest()->getHeader('Accept'); $acceptType = $this->getRequest()->getHeader('Accept');

View File

@ -153,13 +153,8 @@ class LostPasswordHandler extends RequestHandler
* the logic, by returning FALSE. In this case, the user will be redirected back * the logic, by returning FALSE. In this case, the user will be redirected back
* to the form without further action. It is recommended to set a message * to the form without further action. It is recommended to set a message
* in the form detailing why the action was denied. * in the form detailing why the action was denied.
*
* @skipUpgrade
* @param array $data Submitted data
* @param LostPasswordForm $form
* @return HTTPResponse
*/ */
public function forgotPassword($data, $form) public function forgotPassword(array $data, Form $form): HTTPResponse
{ {
// Run a first pass validation check on the data // Run a first pass validation check on the data
$dataValidation = $this->validateForgotPasswordData($data, $form); $dataValidation = $this->validateForgotPasswordData($data, $form);

View File

@ -314,9 +314,8 @@ class Security extends Controller implements TemplateGlobalProvider
* *
* The alreadyLoggedIn value can contain a '%s' placeholder that will be replaced with a link * The alreadyLoggedIn value can contain a '%s' placeholder that will be replaced with a link
* to log in. * to log in.
* @return HTTPResponse
*/ */
public static function permissionFailure($controller = null, $messageSet = null) public static function permissionFailure($controller = null, $messageSet = null): HTTPResponse
{ {
self::set_ignore_disallowed_actions(true); self::set_ignore_disallowed_actions(true);

View File

@ -3,12 +3,14 @@
namespace SilverStripe\Control\Tests\Middleware\Control; namespace SilverStripe\Control\Tests\Middleware\Control;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse;
class TestController extends Controller class TestController extends Controller
{ {
public function index($request) public function index(HTTPRequest $request): HTTPResponse
{ {
return "Success"; return HTTPResponse::create()->setBody("Success");
} }
public function Link($action = null) public function Link($action = null)

View File

@ -3,6 +3,8 @@
namespace SilverStripe\Control\Tests\RequestHandlingTest; namespace SilverStripe\Control\Tests\RequestHandlingTest;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Forms\FormRequestHandler; use SilverStripe\Forms\FormRequestHandler;
/** /**
@ -29,13 +31,13 @@ class TestFormHandler extends FormRequestHandler
return $this->form->Fields()->dataFieldByName($request->param('FieldName')); return $this->form->Fields()->dataFieldByName($request->param('FieldName'));
} }
public function handleSubmission($request) public function handleSubmission(HTTPRequest $request): HTTPResponse
{ {
return "Form posted"; return HTTPResponse::create()->setBody("Form posted");
} }
public function handleGet($request) public function handleGet(HTTPRequest $request): HTTPResponse
{ {
return "Get request on form"; return HTTPResponse::create()->setBody("Get request on form");
} }
} }

View File

@ -3,9 +3,12 @@
namespace SilverStripe\Forms\Tests\FormFactoryTest; namespace SilverStripe\Forms\Tests\FormFactoryTest;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Core\Convert; use SilverStripe\Core\Convert;
use SilverStripe\Core\Extension; use SilverStripe\Core\Extension;
use SilverStripe\Forms\FieldList; use SilverStripe\Forms\FieldList;
use SilverStripe\Forms\Form;
use SilverStripe\Forms\FormAction; use SilverStripe\Forms\FormAction;
use SilverStripe\Forms\LiteralField; use SilverStripe\Forms\LiteralField;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
@ -75,13 +78,15 @@ class ControllerExtension extends Extension
} }
} }
public function publish($data, $form) public function publish(array $data, Form $form): HTTPResponse
{ {
// noop // noop
return HTTPResponse::create();
} }
public function preview() public function preview(HTTPRequest $request): HTTPResponse
{ {
// noop // noop
return HTTPResponse::create();
} }
} }

View File

@ -3,6 +3,7 @@
namespace SilverStripe\Forms\Tests\FormTest; namespace SilverStripe\Forms\Tests\FormTest;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\Forms\EmailField; use SilverStripe\Forms\EmailField;
use SilverStripe\Forms\FieldList; use SilverStripe\Forms\FieldList;
@ -49,7 +50,7 @@ class ControllerWithSecurityToken extends Controller implements TestOnly
return $form; return $form;
} }
public function doSubmit($data, $form, $request) public function doSubmit(array $data, Form $form): HTTPResponse
{ {
$form->sessionMessage('Test save was successful', 'good'); $form->sessionMessage('Test save was successful', 'good');
return $this->redirectBack(); return $this->redirectBack();

View File

@ -82,13 +82,13 @@ class ControllerWithSpecialSubmittedValueFields extends Controller implements Te
return $form; return $form;
} }
public function doSubmit($data, $form, $request) public function doSubmit(array $data, Form $form): HTTPResponse
{ {
$form->sessionMessage('Test save was successful', 'good'); $form->sessionMessage('Test save was successful', 'good');
return $this->redirectBack(); return $this->redirectBack();
} }
public function doTriggerException($data, $form, $request) public function doTriggerException(array $data, Form $form): HTTPResponse
{ {
$result = new ValidationResult(); $result = new ValidationResult();
$result->addFieldError('Email', 'Error on Email field'); $result->addFieldError('Email', 'Error on Email field');

View File

@ -3,6 +3,7 @@
namespace SilverStripe\Forms\Tests\FormTest; namespace SilverStripe\Forms\Tests\FormTest;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\Forms\EmailField; use SilverStripe\Forms\EmailField;
use SilverStripe\Forms\FieldList; use SilverStripe\Forms\FieldList;
@ -48,7 +49,7 @@ class ControllerWithStrictPostCheck extends Controller implements TestOnly
return $form; return $form;
} }
public function doSubmit($data, $form, $request) public function doSubmit(array $data, Form $form): HTTPResponse
{ {
$form->sessionMessage('Test save was successful', 'good'); $form->sessionMessage('Test save was successful', 'good');
return $this->redirectBack(); return $this->redirectBack();

View File

@ -3,6 +3,7 @@
namespace SilverStripe\Forms\Tests\FormTest; namespace SilverStripe\Forms\Tests\FormTest;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
use SilverStripe\Forms\CheckboxSetField; use SilverStripe\Forms\CheckboxSetField;
use SilverStripe\Forms\EmailField; use SilverStripe\Forms\EmailField;
@ -79,13 +80,13 @@ class TestController extends Controller implements TestOnly
return $form; return $form;
} }
public function doSubmit($data, $form, $request) public function doSubmit(array $data, Form $form): HTTPResponse
{ {
$form->sessionMessage('Test save was successful', 'good'); $form->sessionMessage('Test save was successful', 'good');
return $this->redirectBack(); return $this->redirectBack();
} }
public function doTriggerException($data, $form, $request) public function doTriggerException(array $data, Form $form): HTTPResponse
{ {
$result = new ValidationResult(); $result = new ValidationResult();
$result->addFieldError('Email', 'Error on Email field'); $result->addFieldError('Email', 'Error on Email field');
@ -93,13 +94,13 @@ class TestController extends Controller implements TestOnly
throw new ValidationException($result); throw new ValidationException($result);
} }
public function doSubmitValidationExempt($data, $form, $request) public function doSubmitValidationExempt(array $data, Form $form): HTTPResponse
{ {
$form->sessionMessage('Validation skipped', 'good'); $form->sessionMessage('Validation skipped', 'good');
return $this->redirectBack(); return $this->redirectBack();
} }
public function doSubmitActionExempt($data, $form, $request) public function doSubmitActionExempt(array $data, Form $form): HTTPResponse
{ {
$form->sessionMessage('Validation bypassed!', 'good'); $form->sessionMessage('Validation bypassed!', 'good');
return $this->redirectBack(); return $this->redirectBack();

View File

@ -4,6 +4,7 @@ namespace SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPRequest; use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Control\RequestHandler; use SilverStripe\Control\RequestHandler;
use SilverStripe\Forms\FieldList; use SilverStripe\Forms\FieldList;
use SilverStripe\Forms\Form; use SilverStripe\Forms\Form;
@ -83,9 +84,9 @@ class TestComponent extends RequestHandler implements GridField_URLHandler
); );
} }
public function doAction($data, $form) public function doAction(array $data, Form $form): HTTPResponse
{ {
return "Submitted " . $data['Test'] . " to component"; return HTTPResponse::create()->setBody("Submitted " . $data['Test'] . " to component");
} }
public function testpage(GridField $gridField, HTTPRequest $request) public function testpage(GridField $gridField, HTTPRequest $request)

View File

@ -2,6 +2,7 @@
namespace SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest; namespace SilverStripe\Forms\Tests\GridField\GridField_URLHandlerTest;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Control\RequestHandler; use SilverStripe\Control\RequestHandler;
use SilverStripe\Forms\FieldList; use SilverStripe\Forms\FieldList;
use SilverStripe\Forms\Form; use SilverStripe\Forms\Form;
@ -53,9 +54,9 @@ class TestComponent_ItemRequest extends RequestHandler
); );
} }
public function doAction($data, $form) public function doAction(array $data, Form $form): HTTPResponse
{ {
return "Submitted " . $data['Test'] . " to item #" . $this->id; return HTTPResponse::create()->setBody("Submitted " . $data['Test'] . " to item #" . $this->id);
} }
public function testpage() public function testpage()

View File

@ -3,6 +3,7 @@
namespace SilverStripe\Security\Tests\SecurityTest; namespace SilverStripe\Security\Tests\SecurityTest;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Dev\TestOnly; use SilverStripe\Dev\TestOnly;
/** /**
@ -11,9 +12,10 @@ use SilverStripe\Dev\TestOnly;
class NullController extends Controller implements TestOnly class NullController extends Controller implements TestOnly
{ {
public function redirect($url, $code = 302) public function redirect(string $url, int $code = 302): HTTPResponse
{ {
// NOOP // NOOP
return HTTPResponse::create();
} }
public function Link($action = null) public function Link($action = null)