silverstripe-framework/Control/RequestFilter.php

37 lines
1.2 KiB
PHP
Raw Normal View History

<?php
namespace SilverStripe\Control;
use SilverStripe\ORM\DataModel;
/**
* A request filter is an object that's executed before and after a
* request occurs. By returning 'false' from the preRequest method,
* request execution will be stopped from continuing
*
* @author marcus@silverstripe.com.au
* @license BSD License http://silverstripe.org/bsd-license/
*/
interface RequestFilter {
2014-08-15 18:53:05 +12:00
/**
* Filter executed before a request processes
2014-08-15 18:53:05 +12:00
*
2016-09-09 18:43:05 +12:00
* @param HTTPRequest $request Request container object
* @param Session $session Request session
* @param DataModel $model Current DataModel
* @return boolean Whether to continue processing other filters. Null or true will continue processing (optional)
*/
2016-09-09 18:43:05 +12:00
public function preRequest(HTTPRequest $request, Session $session, DataModel $model);
/**
* Filter executed AFTER a request
2014-08-15 18:53:05 +12:00
*
2016-09-09 18:43:05 +12:00
* @param HTTPRequest $request Request container object
* @param HTTPResponse $response Response output object
* @param DataModel $model Current DataModel
* @return boolean Whether to continue processing other filters. Null or true will continue processing (optional)
*/
2016-09-09 18:43:05 +12:00
public function postRequest(HTTPRequest $request, HTTPResponse $response, DataModel $model);
}