} catch (Exception $e) {
trigger_error($e->getMessage(), E_USER_WARNING);
Cake\Error\ErrorTrap->handleError() [internal], line ?? /home/site/wwwroot/vendor/cakephp/cakephp/src/Cache/Engine/FileEngine.php /home/site/wwwroot/vendor/cakephp/cakephp/src/Cache/Engine/FileEngine.php, line 387 Cake\Cache\Engine\FileEngine->_setKey() /home/site/wwwroot/vendor/cakephp/cakephp/src/Cache/Engine/FileEngine.php, line 214 Cake\Cache\Engine\FileEngine->delete() /home/site/wwwroot/vendor/cakephp/cakephp/src/Cache/Cache.php, line 406 Cake\Cache\Cache::delete() /home/site/wwwroot/vendor/dereuromark/cakephp-tinyauth/src/Utility/Cache.php, line 50 TinyAuth\Utility\Cache::clear() /home/site/wwwroot/vendor/dereuromark/cakephp-tinyauth/src/Auth/AllowTrait.php, line 125 TinyAuth\Controller\Component\AuthComponent->_getAllow() /home/site/wwwroot/vendor/dereuromark/cakephp-tinyauth/src/Auth/AllowTrait.php, line 28 TinyAuth\Controller\Component\AuthComponent->_getAllowRule() /home/site/wwwroot/vendor/dereuromark/cakephp-tinyauth/src/Controller/Component/AuthComponent.php, line 57 TinyAuth\Controller\Component\AuthComponent->_prepareAuthentication() /home/site/wwwroot/vendor/dereuromark/cakephp-tinyauth/src/Controller/Component/AuthComponent.php, line 49 TinyAuth\Controller\Component\AuthComponent->initialize() /home/site/wwwroot/vendor/cakephp/cakephp/src/Controller/Component.php, line 112 Cake\Controller\Component->__construct() /home/site/wwwroot/vendor/dereuromark/cakephp-tinyauth/src/Controller/Component/AuthComponent.php, line 32 TinyAuth\Controller\Component\AuthComponent->__construct() /home/site/wwwroot/vendor/cakephp/cakephp/src/Controller/ComponentRegistry.php, line 151 Cake\Controller\ComponentRegistry->_create() /home/site/wwwroot/vendor/cakephp/cakephp/src/Core/ObjectRegistry.php, line 115 Cake\Core\ObjectRegistry->load() /home/site/wwwroot/vendor/cakephp/cakephp/src/Controller/Controller.php, line 283 Cake\Controller\Controller->loadComponent() /home/site/wwwroot/src/Controller/AppController.php, line 45 App\Controller\AppController->initialize() /home/site/wwwroot/vendor/cakephp/cakephp/src/Controller/Controller.php, line 237 Cake\Controller\Controller->__construct() [internal], line ?? ReflectionClass->newInstance() /home/site/wwwroot/vendor/cakephp/cakephp/src/Controller/ControllerFactory.php, line 111 Cake\Controller\ControllerFactory->create() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/BaseApplication.php, line 360 Cake\Http\BaseApplication->handle() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Runner.php, line 86 Cake\Http\Runner->handle() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Middleware/BodyParserMiddleware.php, line 157 Cake\Http\Middleware\BodyParserMiddleware->process() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Runner.php, line 82 Cake\Http\Runner->handle() /home/site/wwwroot/vendor/cakephp/cakephp/src/Routing/Middleware/RoutingMiddleware.php, line 118 Cake\Routing\Middleware\RoutingMiddleware->process() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Runner.php, line 82 Cake\Http\Runner->handle() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Middleware/CsrfProtectionMiddleware.php, line 169 Cake\Http\Middleware\CsrfProtectionMiddleware->process() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Runner.php, line 82 Cake\Http\Runner->handle() /home/site/wwwroot/vendor/cakephp/cakephp/src/Routing/Middleware/AssetMiddleware.php, line 69 Cake\Routing\Middleware\AssetMiddleware->process() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Runner.php, line 82 Cake\Http\Runner->handle() /home/site/wwwroot/vendor/cakephp/cakephp/src/Error/Middleware/ErrorHandlerMiddleware.php, line 115 Cake\Error\Middleware\ErrorHandlerMiddleware->process() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Runner.php, line 82 Cake\Http\Runner->handle() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Runner.php, line 60 Cake\Http\Runner->run() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Server.php, line 104 Cake\Http\Server->run() /home/site/wwwroot/webroot/index.php, line 42 [main]
$message = "Unable to emit headers. Headers sent in file={$file} line={$line}";
trigger_error($message, E_USER_WARNING);
}
Cake\Error\ErrorTrap->handleError() [internal], line ?? /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php, line 65 Cake\Http\ResponseEmitter->emit() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Server.php, line 148 Cake\Http\Server->emit() /home/site/wwwroot/webroot/index.php, line 42 [main]
$reasonPhrase = $response->getReasonPhrase();
header(sprintf(
'HTTP/%s %d%s',
Cake\Error\ErrorTrap->handleError() [internal], line ?? /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php, line 159 Cake\Http\ResponseEmitter->emitStatusLine() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php, line 68 Cake\Http\ResponseEmitter->emit() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Server.php, line 148 Cake\Http\Server->emit() /home/site/wwwroot/webroot/index.php, line 42 [main]
foreach ($values as $value) {
header(sprintf(
'%s: %s',
Cake\Error\ErrorTrap->handleError() [internal], line ?? /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php, line 192 Cake\Http\ResponseEmitter->emitHeaders() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/ResponseEmitter.php, line 69 Cake\Http\ResponseEmitter->emit() /home/site/wwwroot/vendor/cakephp/cakephp/src/Http/Server.php, line 148 Cake\Http\Server->emit() /home/site/wwwroot/webroot/index.php, line 42 [main]
|
|
$backend = static::pool($config); |
|
$success = $backend->set($key, $value); |
|
if ($success === false && $value !== '') { |
|
throw new CacheWriteException(sprintf( |
|
"%s cache was unable to write '%s' to %s cache", |
|
$config, |
|
$key, |
|
$backend::class, |
*/ |
|
public static function write(string $type, array $data): void { |
|
$config = static::prepareConfig(); |
|
|
|
CoreCache::write(static::key($type), $data, $config['cache']); |
|
} |
|
|
|
/** |
|
* @param string $type |
unset($config['allowFile']); |
|
|
|
$auth = $this->_loadAllowAdapter($config['allowAdapter'])->getAllow($config); |
|
|
|
Cache::write(Cache::KEY_ALLOW, $auth); |
|
|
|
return $auth; |
|
} |
|
|
* @param array $params |
|
* @return array |
|
*/ |
|
protected function _getAllowRule(array $params) { |
|
$rules = $this->_getAllow($this->getConfig('allowFilePath')); |
|
|
|
$allowDefaults = $this->_getAllowDefaultsForCurrentParams($params); |
|
|
|
foreach ($rules as $rule) { |
* @param array $params |
|
* @return void |
|
*/ |
|
protected function _prepareAuthentication(array $params) { |
|
$rule = $this->_getAllowRule($params); |
|
if (!$rule) { |
|
return; |
|
} |
|
|
public function initialize(array $config): void { |
|
parent::initialize($config); |
|
|
|
$params = $this->_registry->getController()->getRequest()->getAttribute('params'); |
|
$this->_prepareAuthentication($params); |
|
} |
|
|
|
/** |
|
* @param array $params |
|
|
if ($this->components) { |
|
$this->components = $registry->normalizeArray($this->components); |
|
} |
|
$this->initialize($config); |
|
} |
|
|
|
/** |
|
* Get the controller this component is bound to. |
if ($config && empty($config['className'])) { |
|
$config['className'] = 'TinyAuth.Auth'; |
|
} |
|
|
|
parent::__construct($registry, $config); |
|
if ($registry->has('Authentication') && get_class($registry->get('Authentication')) === AuthenticationComponent::class) { |
|
throw new RuntimeException('You cannot use new TinyAuth.Authentication component and this TinyAuth.Auth component together.'); |
|
} |
|
if ($registry->has('Authorization') && get_class($registry->get('Authorization')) === AuthorizationComponent::class) { |
/** @var \Cake\Controller\Component $instance */ |
|
$instance = $this->container->get($class); |
|
$instance->setConfig($config); |
|
} else { |
|
$instance = new $class($this, $config); |
|
} |
|
|
|
if ($config['enabled'] ?? true) { |
|
$this->getEventManager()->on($instance); |
$this->_throwMissingClassError($name, $plugin); |
|
} |
|
} |
|
|
|
$instance = $this->_create($className, $objName, $config); |
|
$this->_loaded[$objName] = $instance; |
|
|
|
return $instance; |
|
} |
* @throws \Exception |
|
*/ |
|
public function loadComponent(string $name, array $config = []): Component |
|
{ |
|
return $this->components()->load($name, $config); |
|
} |
|
|
|
/** |
|
* Magic accessor for the default table. |
|
|
public function initialize(): void |
|
{ |
|
parent::initialize(); |
|
$this->loadComponent('TinyAuth.Auth'); |
|
$this->loadComponent('Flash'); |
|
$this->loadComponent('Excel'); // Load the ExcelComponent |
|
$this->loadComponent('PhpSpreadsheet'); |
|
|
$tableAlias = ($plugin ? $plugin . '.' : '') . $this->name; |
|
$this->defaultTable = $tableAlias; |
|
} |
|
|
|
$this->initialize(); |
|
|
|
$this->getEventManager()->on($this); |
|
} |
|
|
break; |
|
} |
|
} |
|
if ($hasComponents) { |
|
$controller = $reflection->newInstance(request: $request, components: $components); |
|
} else { |
|
$controller = $reflection->newInstance($request); |
|
} |
|
} |
assert($request instanceof ServerRequest); |
|
Router::setRequest($request); |
|
} |
|
|
|
$controller = $this->controllerFactory->create($request); |
|
|
|
return $this->controllerFactory->invoke($controller); |
|
} |
|
} |
return $middleware->process($request, $this); |
|
} |
|
|
|
if ($this->fallbackHandler) { |
|
return $this->fallbackHandler->handle($request); |
|
} |
|
|
|
return new Response([ |
|
'body' => 'Middleware queue was exhausted without returning a response ' |
*/ |
|
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface |
|
{ |
|
if (!in_array($request->getMethod(), $this->methods, true)) { |
|
return $handler->handle($request); |
|
} |
|
[$type] = explode(';', $request->getHeaderLine('Content-Type')); |
|
$type = strtolower($type); |
|
if (!isset($this->parsers[$type])) { |
if ($this->queue->valid()) { |
|
$middleware = $this->queue->current(); |
|
$this->queue->next(); |
|
|
|
return $middleware->process($request, $this); |
|
} |
|
|
|
if ($this->fallbackHandler) { |
|
return $this->fallbackHandler->handle($request); |
); |
|
} |
|
$matching = Router::getRouteCollection()->getMiddleware($middleware); |
|
if (!$matching) { |
|
return $handler->handle($request); |
|
} |
|
|
|
$container = $this->app instanceof ContainerApplicationInterface |
|
? $this->app->getContainer() |
if ($this->queue->valid()) { |
|
$middleware = $this->queue->current(); |
|
$this->queue->next(); |
|
|
|
return $middleware->process($request, $this); |
|
} |
|
|
|
if ($this->fallbackHandler) { |
|
return $this->fallbackHandler->handle($request); |
$this->_validateToken($request); |
|
$request = $this->_unsetTokenField($request); |
|
} |
|
|
|
return $handler->handle($request); |
|
} |
|
|
|
/** |
|
* Set callback for allowing to skip token check for particular request. |
if ($this->queue->valid()) { |
|
$middleware = $this->queue->current(); |
|
$this->queue->next(); |
|
|
|
return $middleware->process($request, $this); |
|
} |
|
|
|
if ($this->fallbackHandler) { |
|
return $this->fallbackHandler->handle($request); |
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface |
|
{ |
|
$url = $request->getUri()->getPath(); |
|
if (str_contains($url, '..') || !str_contains($url, '.')) { |
|
return $handler->handle($request); |
|
} |
|
|
|
if (str_contains($url, '/.')) { |
|
return $handler->handle($request); |
if ($this->queue->valid()) { |
|
$middleware = $this->queue->current(); |
|
$this->queue->next(); |
|
|
|
return $middleware->process($request, $this); |
|
} |
|
|
|
if ($this->fallbackHandler) { |
|
return $this->fallbackHandler->handle($request); |
*/ |
|
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface |
|
{ |
|
try { |
|
return $handler->handle($request); |
|
} catch (RedirectException $exception) { |
|
return $this->handleRedirect($exception); |
|
} catch (Throwable $exception) { |
|
return $this->handleException($exception, Router::getRequest() ?? $request); |
if ($this->queue->valid()) { |
|
$middleware = $this->queue->current(); |
|
$this->queue->next(); |
|
|
|
return $middleware->process($request, $this); |
|
} |
|
|
|
if ($this->fallbackHandler) { |
|
return $this->fallbackHandler->handle($request); |
$this->queue = $queue; |
|
$this->queue->rewind(); |
|
$this->fallbackHandler = $fallbackHandler; |
|
|
|
return $this->handle($request); |
|
} |
|
|
|
/** |
|
* Handle incoming server request and return a response. |
} |
|
|
|
$this->dispatchEvent('Server.buildMiddleware', ['middleware' => $middleware]); |
|
|
|
$response = $this->runner->run($middleware, $request, $this->app); |
|
|
|
if ($request instanceof ServerRequest) { |
|
$request->getSession()->close(); |
|
} |
// Bind your application to the server. |
|
$server = new Server(new Application(dirname(__DIR__) . '/config')); |
|
|
|
// Run the request/response through the application and emit the response. |
|
$server->emit($server->run()); |
|
|
If you want to customize this error message, create templates/Error/error500.ctp