Skip to content

Commit

Permalink
Allow Harvest API Credentials be added later
Browse files Browse the repository at this point in the history
- Update Gateway to allow Harvest API Credentials to be set after initialisation:
- Get credentials from config in __construct method
- remove exception thrown by $this->hasCredentials in __construct, as they may not be set at this point
- modify get() method to explicitly set headers with credentials from config
  • Loading branch information
RandomWeasel authored Oct 31, 2018
1 parent 70d33b1 commit 8f5ba1d
Showing 1 changed file with 14 additions and 5 deletions.
19 changes: 14 additions & 5 deletions src/Api/Gateway.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,9 @@ public function __construct()
$this->token = config('harvest.personal_access_token');
$this->account_id = config('harvest.account_id');

if (! $this->hasCredentials()) {
throw new Exception('Credentials not found, please ensure you published the package config file with artisan vendor:publish');
}
// if (! $this->hasCredentials()) {
// throw new Exception('Credentials not found, please ensure you published the package config file with artisan vendor:publish');
// }

$apiClient = new Client([
'headers' => [
Expand All @@ -44,8 +44,17 @@ public function getWithoutBase($uri, $data = null)

public function get($uri, $data = null)
{
//explicitly pass the headers here
//this accounts for a case where the harvest credentials weren't set when __construct was run
//or where they have since been updated

$response = $this->apiClient->request('GET', $this->uri . $uri, [
'json' => $data
'json' => $data,
'headers' => [
'Authorization' => 'Bearer ' . config('harvest.personal_access_token'),
'Harvest-Account-Id' => config('harvest.account_id'),
'User-Agent' => 'Harvest API App'
]
]);

return $this->transformResponse($response);
Expand Down Expand Up @@ -87,4 +96,4 @@ public function transformResponse($response)
{
return (new Response($response))->toObject();
}
}
}

0 comments on commit 8f5ba1d

Please sign in to comment.