From 237728af488acbb7e1a04fdcb98b43408bfa3abf Mon Sep 17 00:00:00 2001 From: javier-villatoro Date: Mon, 5 Aug 2024 20:44:40 -0600 Subject: [PATCH] Improve use of ApiResponse to return data --- src/Http/Client/LeverClient.php | 38 ++++++++++++++++----------------- 1 file changed, 18 insertions(+), 20 deletions(-) diff --git a/src/Http/Client/LeverClient.php b/src/Http/Client/LeverClient.php index 4d2a516..c8bb0c6 100644 --- a/src/Http/Client/LeverClient.php +++ b/src/Http/Client/LeverClient.php @@ -80,40 +80,40 @@ private function sendRequest($method, $endpoint, array $options = []): ResponseI } } - public function get(): ResponseInterface + public function get(): array { - return $this->sendRequest('GET', $this->endpoint, $this->options); + $response = $this->sendRequest('GET', $this->endpoint, $this->options); + + return ApiResponse::using($response)->toArray(); } - public function post(array $body = []): ResponseInterface + public function post(array $body = []): array { - return $this->sendRequest('POST', $this->endpoint, $this->prepareOptions($body)); + $response = $this->sendRequest('POST', $this->endpoint, $this->prepareOptions($body)); + + return ApiResponse::using($response)->toArray(); } - public function put(array $body = []): ResponseInterface + public function put(array $body = []): array { - return $this->sendRequest('PUT', $this->endpoint, $this->prepareOptions($body)); + $response = $this->sendRequest('PUT', $this->endpoint, $this->prepareOptions($body)); + + return ApiResponse::using($response)->toArray(); } public function create(array $body, string $method = 'post'): array { - $response = ApiResponse::using($this->$method($body))->toArray(); - - return $response; + return $this->$method($body); } public function update(array $body): array { - $response = ApiResponse::using($this->post($body))->toArray(); - - return $response; + return $this->post($body); } public function putUpdate(array $body): array { - $response = ApiResponse::using($this->put($body))->toArray(); - - return $response; + return $this->put($body); } public function fetch(): LazyCollection|array @@ -121,7 +121,7 @@ public function fetch(): LazyCollection|array $endpoint = $this->endpoint; $options = $this->options; - $response = ApiResponse::using($this->get())->toArray(); + $response = $this->get(); if (! array_key_exists('hasNext', $response)) { return $response['data']; @@ -140,7 +140,7 @@ public function fetch(): LazyCollection|array if (! empty($response['next'])) { $this->options['query']['offset'] = json_decode(urldecode($response['next'])); - $response = ApiResponse::using($this->get())->toArray(); + $response = $this->get(); } else { return; } @@ -292,9 +292,7 @@ public function apply(array $body = []): array { $this->endpoint .= '/apply'; - $application = ApiResponse::using($this->post($body))->toArray(); - - return $application; + return $this->post($body); } public function notes(?string $noteId = null): self