From d2086d1fd1428688e8ef554263adf7d84f4b9c95 Mon Sep 17 00:00:00 2001 From: mychidarko Date: Sun, 25 Dec 2022 16:03:48 +0000 Subject: [PATCH 1/6] fix: call reset on csrf error --- src/App.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/App.php b/src/App.php index 516e50f..5274ada 100755 --- a/src/App.php +++ b/src/App.php @@ -53,7 +53,7 @@ public function __construct(array $userSettings = []) if (!Anchor\CSRF::verify()) { $csrfError = Anchor\CSRF::errors()['token']; - Http\Response::status(400); + Http\Headers::resetStatus(400); echo Exception\General::csrf($csrfError); exit(); } From 59be4a9e6cec2a385366599e5d07dcdfc03a530a Mon Sep 17 00:00:00 2001 From: mychidarko Date: Sun, 25 Dec 2022 16:08:34 +0000 Subject: [PATCH 2/6] chore: remove unused code --- src/App.php | 16 ++-------------- 1 file changed, 2 insertions(+), 14 deletions(-) diff --git a/src/App.php b/src/App.php index 5274ada..87a20c6 100755 --- a/src/App.php +++ b/src/App.php @@ -189,16 +189,6 @@ private function setupDefaultContainer() $mode = _env('LEAF_MODE'); } - if (isset($_ENV['LEAF_MODE'])) { - $mode = $_ENV['LEAF_MODE']; - } else { - $envMode = getenv('LEAF_MODE'); - - if ($envMode !== false) { - $mode = $envMode; - } - } - Config::set([ 'mode' => $mode, 'app' => [ @@ -393,10 +383,8 @@ public static function halt($status, $message = '') ob_clean(); } - Http\Headers::status($status); - Http\Response::markup($message); - - exit(); + Http\Headers::resetStatus($status); + response()->exit($message, $status); } /** From f61799772febc935c488d3b7c6faaad8e0ee7b0c Mon Sep 17 00:00:00 2001 From: mychidarko Date: Sun, 25 Dec 2022 16:12:26 +0000 Subject: [PATCH 3/6] chore: remove unused code --- src/App.php | 30 ++++++++++++++---------------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/src/App.php b/src/App.php index 87a20c6..b0dd023 100755 --- a/src/App.php +++ b/src/App.php @@ -156,26 +156,24 @@ private function setupDefaultContainer() return new \Leaf\Http\Headers(); }); - if ($this->config('log.enabled')) { - if (class_exists('Leaf\Log')) { - // Default log writer - $this->container->singleton('logWriter', function ($c) { - $logWriter = Config::get('log.writer'); + if ($this->config('log.enabled') && class_exists('Leaf\Log')) { + // Default log writer + $this->container->singleton('logWriter', function ($c) { + $logWriter = Config::get('log.writer'); - $file = $this->config('log.dir') . $this->config('log.file'); + $file = $this->config('log.dir') . $this->config('log.file'); - return is_object($logWriter) ? $logWriter : new \Leaf\LogWriter($file, $this->config('log.open') ?? true); - }); + return is_object($logWriter) ? $logWriter : new \Leaf\LogWriter($file, $this->config('log.open') ?? true); + }); - // Default log - $this->container->singleton('log', function ($c) { - $log = new \Leaf\Log($c->logWriter); - $log->enabled($this->config('log.enabled')); - $log->level($this->config('log.level')); + // Default log + $this->container->singleton('log', function ($c) { + $log = new \Leaf\Log($c->logWriter); + $log->enabled($this->config('log.enabled')); + $log->level($this->config('log.level')); - return $log; - }); - } + return $log; + }); } // Default mode From 012a83b1cc4e5149dfca2811cba4e13d2f9322ba Mon Sep 17 00:00:00 2001 From: mychidarko Date: Sun, 25 Dec 2022 16:23:08 +0000 Subject: [PATCH 4/6] feat: add support for websockets via eien --- src/App.php | 46 ++++++++++++++++++++++++++++++---------------- 1 file changed, 30 insertions(+), 16 deletions(-) diff --git a/src/App.php b/src/App.php index b0dd023..f895af8 100755 --- a/src/App.php +++ b/src/App.php @@ -270,6 +270,36 @@ public function setResponseClass($class) }); } + /** + * Evade CORS errors + * + * @param $options Config for cors + */ + public function cors($options = []) + { + if (class_exists('Leaf\Http\Cors')) { + Http\Cors::config($options); + } else { + trigger_error('Cors module not found! Run `leaf install cors` or `composer require leafs/cors` to install the CORS module. This is required to configure CORS.'); + } + } + + /** + * Create a route handled by websocket (requires Eien module) + * + * @param string $name The url of the route + * @param callable $callback The callback function + * @uses package Eien module + * @see https://leafphp.dev/modules/eien/ + */ + public function ws(string $name, callable $callback) + { + Config::set('eien.events', array_merge( + Config::get('eien.events') ?? [], + [$name = $callback] + )); + } + /******************************************************************************** * Logging *******************************************************************************/ @@ -385,22 +415,6 @@ public static function halt($status, $message = '') response()->exit($message, $status); } - /** - * Evade CORS errors - * - * Cors handler - * - * @param $options Config for cors - */ - public function cors($options = []) - { - if (class_exists('Leaf\Http\Cors')) { - Http\Cors::config($options); - } else { - trigger_error('Cors module not found! Run `composer require leafs/cors` to install the CORS module. This is required to configure CORS.'); - } - } - /** * @inheritdoc */ From 444f48ad8840db607e8d2bc6c79a306a2f4a96ab Mon Sep 17 00:00:00 2001 From: mychidarko Date: Sun, 25 Dec 2022 16:24:58 +0000 Subject: [PATCH 5/6] chore: fix styling --- src/App.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/App.php b/src/App.php index f895af8..37b868e 100755 --- a/src/App.php +++ b/src/App.php @@ -286,7 +286,7 @@ public function cors($options = []) /** * Create a route handled by websocket (requires Eien module) - * + * * @param string $name The url of the route * @param callable $callback The callback function * @uses package Eien module From 9454288acd3b9f9a893396959c7b0cc7a32a64a6 Mon Sep 17 00:00:00 2001 From: mychidarko Date: Sun, 25 Dec 2022 17:00:10 +0000 Subject: [PATCH 6/6] fix: patch up websocket function --- src/App.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/App.php b/src/App.php index 37b868e..8c0aa9f 100755 --- a/src/App.php +++ b/src/App.php @@ -296,7 +296,7 @@ public function ws(string $name, callable $callback) { Config::set('eien.events', array_merge( Config::get('eien.events') ?? [], - [$name = $callback] + [$name => $callback] )); }