Implemented the RouteWebRequestEvent and sessions.
- Developers can now use the RouteWebRequestEvent to cancel the loading of web requests - FuzeWorks\Input now starts the PHP session, which is required for some dependencies
This commit is contained in:
parent
208d2783c7
commit
612ab3abca
|
@ -0,0 +1,53 @@
|
|||
<?php
|
||||
/**
|
||||
* FuzeWorks Component.
|
||||
*
|
||||
* The FuzeWorks PHP FrameWork
|
||||
*
|
||||
* Copyright (C) 2013-2019 TechFuze
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*
|
||||
* @author TechFuze
|
||||
* @copyright Copyright (c) 2013 - 2019, TechFuze. (http://techfuze.net)
|
||||
* @license https://opensource.org/licenses/MIT MIT License
|
||||
*
|
||||
* @link http://techfuze.net/fuzeworks
|
||||
* @since Version 1.2.0
|
||||
*
|
||||
* @version Version 1.2.0
|
||||
*/
|
||||
|
||||
namespace FuzeWorks\Event;
|
||||
use FuzeWorks\Event;
|
||||
|
||||
class RouteWebRequestEvent extends Event
|
||||
{
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
public $uriString;
|
||||
|
||||
public function init(string $uriString)
|
||||
{
|
||||
$this->uriString = $uriString;
|
||||
}
|
||||
|
||||
}
|
|
@ -75,6 +75,9 @@ class Input
|
|||
if (!WebComponent::$willHandleRequest)
|
||||
return;
|
||||
|
||||
// Start session
|
||||
session_start();
|
||||
|
||||
// Sanitize all global arrays
|
||||
$this->sanitizeGlobals();
|
||||
|
||||
|
|
|
@ -151,6 +151,7 @@ class WebComponent implements iComponent
|
|||
Logger::logInfo("Parsing output...");
|
||||
$output = Factory::getInstance()->output;
|
||||
$output->display();
|
||||
return $event;
|
||||
}, 'coreShutdownEvent', Priority::NORMAL);
|
||||
|
||||
// Create an error 500 page when a haltEvent is fired
|
||||
|
@ -179,6 +180,11 @@ class WebComponent implements iComponent
|
|||
if ($output->getCache($uriString))
|
||||
return true;
|
||||
|
||||
// Send webRequestEvent, if no cache is found
|
||||
$event = Events::fireEvent('routeWebRequestEvent', $uriString);
|
||||
if ($event->isCancelled())
|
||||
return true;
|
||||
|
||||
// First test for Cross Site Request Forgery
|
||||
try {
|
||||
$security->csrf_verify();
|
||||
|
@ -321,6 +327,7 @@ class WebComponent implements iComponent
|
|||
$event->assign('csrfHash', $security->get_csrf_hash());
|
||||
$event->assign('csrfTokenName', $security->get_csrf_token_name());
|
||||
$event->assign('siteURL', $config->getConfig('web')->get('base_url'));
|
||||
$event->assign('serverName', $config->getConfig('web')->get('serverName'));
|
||||
|
||||
Logger::logInfo("Assigned variables to TemplateEngine from WebComponent");
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue