From 970db87cbc67cc8599f9eecbf4b8e7073b3060bb Mon Sep 17 00:00:00 2001 From: Dan Jones Date: Mon, 19 Jun 2023 21:54:57 -0500 Subject: [PATCH] =?UTF-8?q?=F0=9F=9B=A0=20Add=20trakt:debug=20command?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit I should really add a proper login command, and refresh --- app/Commands/TraktDebug.php | 58 +++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 app/Commands/TraktDebug.php diff --git a/app/Commands/TraktDebug.php b/app/Commands/TraktDebug.php new file mode 100644 index 0000000..f9a783e --- /dev/null +++ b/app/Commands/TraktDebug.php @@ -0,0 +1,58 @@ +getBody(); + $method = $this->argument('method'); + $url = $this->argument('endpoint'); + + $resp = $trakt->request()->asJson(); + if ($body) { + $body = json_encode($body); + $resp->withBody($body); + } + + $this->line("Request: $method $url $body"); + $resp = $resp->send($method, $url); + $this->line('Response (' . $resp->status() . '):' . PHP_EOL . json_encode($resp->json(), JSON_PRETTY_PRINT)); + + return static::SUCCESS; + } + + protected function getBody(): ?array + { + if ($this->argument('method') === 'GET') { + return null; + } + + $ret = []; + foreach ($this->option('data') as $kv) { + [$k, $v] = explode('=', $kv) + [null, null]; + if (empty($k) || empty($v)) { + continue; + } + if ($k[strlen($k) - 1] === ':') { + $k = substr($k, 0, strlen($k) - 1); + $v = json_decode($v, true); + if (json_last_error() !== JSON_ERROR_NONE) { + continue; + } + } + Arr::set($ret, $k, $v); + } + + return $ret; + } +}