mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge pull request #10536 from creative-commoners/pulls/5/action-signature
API Strongly-type action method signatures
This commit is contained in:
commit
868f790dc5
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
@ -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
|
||||||
|
@ -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();
|
||||||
|
@ -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')
|
||||||
@ -36,7 +37,8 @@ use SilverStripe\ORM\DataObjectInterface;
|
|||||||
* 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
|
||||||
|
@ -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');
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
|
@ -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');
|
||||||
|
@ -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();
|
||||||
|
@ -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();
|
||||||
|
@ -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)
|
||||||
|
@ -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()
|
||||||
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user