From b44e1a02ca3755028215ebf1352b89c68039ff60 Mon Sep 17 00:00:00 2001 From: David Bomba Date: Thu, 28 Jul 2022 16:29:42 +1000 Subject: [PATCH] Auth tokens --- app/Helpers/Bank/Yodlee/Yodlee.php | 74 +++++++++++++++++-- .../Controllers/Bank/YodleeController.php | 6 +- resources/views/bank/yodlee/auth.blade.php | 4 +- tests/Feature/Bank/YodleeApiTest.php | 10 +++ 4 files changed, 83 insertions(+), 11 deletions(-) diff --git a/app/Helpers/Bank/Yodlee/Yodlee.php b/app/Helpers/Bank/Yodlee/Yodlee.php index 1a4b47692629..1f09fd1052ef 100644 --- a/app/Helpers/Bank/Yodlee/Yodlee.php +++ b/app/Helpers/Bank/Yodlee/Yodlee.php @@ -22,7 +22,7 @@ class Yodlee private string $test_api_endpoint = 'https://sandbox.api.yodlee.com/ysl'; - protected string $fast_track_url = 'https://fl4.sandbox.yodlee.com/authenticate/restserver/fastlink'; + public string $fast_track_url = 'https://fl4.sandbox.yodlee.com/authenticate/restserver/fastlink'; protected string $client_id; @@ -47,16 +47,68 @@ class Yodlee public function getAccessToken() { - return $this->bankRequest('/auth/token', 'post'); + $response = $this->bankFormRequest('/auth/token', 'post'); + + return $response->token->accessToken; + } + + + public function createUser() + { + // { + // "user": { + // "preferences": { + // "dateFormat": "string", + // "timeZone": "string", + // "currency": "USD", + // "locale": "en_US" + // }, + // "address": { + // "zip": "string", + // "country": "string", + // "address3": "string", + // "address2": "string", + // "city": "string", + // "address1": "string", + // "state": "string" + // }, + // "loginName": "string", + // "name": { + // "middle": "string", + // "last": "string", + // "fullName": "string", + // "first": "string" + // }, + // "email": "string", + // "segmentName": "string" + // } + // } + + $user['user'] = [ + 'loginName' => 'test123', + ]; + + return $this->bankRequest('/user/register', 'post', $user); + } private function bankRequest(string $uri, string $verb, array $data = []) { - nlog($this->getHeaders()); - nlog($this->buildBody()); - nlog($this->api_endpoint . $uri); - $response = Http::withHeaders($this->getHeaders())->asForm()->{$verb}($this->api_endpoint . $uri, $this->buildBody()); + $response = Http::withHeaders($this->getHeaders(['loginName' => $this->admin_name]))->{$verb}($this->api_endpoint . $uri, $this->buildBody()); + + if($response->successful()) + return $response->object(); + + if($response->failed()) + return $response->body(); + + } + + private function bankFormRequest(string $uri, string $verb, array $data = []) + { + + $response = Http::withHeaders($this->getFormHeaders(['loginName' => $this->admin_name]))->asForm()->{$verb}($this->api_endpoint . $uri, $this->buildBody()); if($response->successful()) return $response->object(); @@ -70,7 +122,15 @@ class Yodlee { return array_merge($data, [ 'Api-Version' => '1.1', - 'loginName' => $this->admin_name + 'ContentType' => 'application/json' + ]); + } + + + private function getFormHeaders($data = []) + { + return array_merge($data, [ + 'Api-Version' => '1.1', ]); } diff --git a/app/Http/Controllers/Bank/YodleeController.php b/app/Http/Controllers/Bank/YodleeController.php index ea898994686c..26cd5f7c994e 100644 --- a/app/Http/Controllers/Bank/YodleeController.php +++ b/app/Http/Controllers/Bank/YodleeController.php @@ -11,6 +11,7 @@ namespace App\Http\Controllers\Bank; +use App\Helpers\Bank\Yodlee\Yodlee; use App\Http\Controllers\BaseController; use Illuminate\Http\Request; @@ -20,10 +21,11 @@ class YodleeController extends BaseController public function auth(Request $request) { - $yodlee = new Yodlee(); + $yodlee = new Yodlee(true); $data = [ - 'access_token' => $yodlee->getAccessToken() + 'access_token' => $yodlee->getAccessToken(), + 'fasttrack_url' => $yodlee->fast_track_url ]; return view('bank.yodlee.auth', $data); diff --git a/resources/views/bank/yodlee/auth.blade.php b/resources/views/bank/yodlee/auth.blade.php index 1abc1ea503f7..3cda43d55b0b 100644 --- a/resources/views/bank/yodlee/auth.blade.php +++ b/resources/views/bank/yodlee/auth.blade.php @@ -27,10 +27,10 @@ 'click', function() { window.fastlink.open({ - fastLinkURL: 'https://fl4.sandbox.yodlee.com/authenticate/restserver/fastlink', + fastLinkURL: '{{ $fasttrack_url }}', accessToken: 'Bearer {{ $access_token }}', params: { - configName : '' + configName : 'Example2' }, onSuccess: function (data) { // will be called on success. For list of possible message, refer to onSuccess(data) Method. diff --git a/tests/Feature/Bank/YodleeApiTest.php b/tests/Feature/Bank/YodleeApiTest.php index 12b7289df5db..dd3f9446223d 100644 --- a/tests/Feature/Bank/YodleeApiTest.php +++ b/tests/Feature/Bank/YodleeApiTest.php @@ -37,4 +37,14 @@ class YodleeApiTest extends TestCase $this->assertNotNull($access_token); } + public function testCreateUser() + { + $yodlee = new Yodlee(true); + + $create_user = $yodlee->createUser(); + + nlog($create_user); + + } + }