This is an SDK for the starling SDK, you'll have to take care of getting tokens from users but once you have one this SDK will wrap the whole API to allow for ease of use in PHP.
Right now its only read functions, I'll some write functions when I get around to using them.
See the tests folder for all the requests, you can pass any request to the request function on Starling\Api\Client
if you want to write your own they'll need to implements RequestInterface
I didn't want to be too opinionated so responses are not formatted.
composer require rentwoo/starling-php-sdk
$ ./vendor/bin/phpunit
$identity = new Starling\Identity($client_token);
$client = new Starling\Api\Client($identity, ['env' => 'prod']);
$request = new Starling\Api\Request\Accounts\Balance();
try {
$result = $client->request($request);
$body = json_decode((string) $result->getBody(), true);
print "Your balance is " . $body['effectiveBalance'] . " as for right now.";
} catch (Exception $e) {
print $e->getMessage();
}
$identity = new Starling\Identity($client_token);
$client = new Starling\Api\Client($identity, ['env' => 'prod']);
$request = new Starling\Api\Request\Accounts();
try {
$result = $client->request($request);
$body = json_decode((string) $result->getBody(), true);
print $body;
} catch (Exception $e) {
print $e->getMessage();
}
$identity = new Starling\Identity($client_token);
$client = new Starling\Api\Client($identity, ['env' => 'prod']);
$request = new Starling\Api\Request\DirectDebits();
try {
$result = $client->request($request);
$body = json_decode((string) $result->getBody(), true);
print $body;
} catch (Exception $e) {
print $e->getMessage();
}
$identity = new Starling\Identity($client_token);
$client = new Starling\Api\Client($identity);
$request = new Starling\Api\Request\Transactions([
'from' => new DateTime("-7 Days"),
'to' => new DateTime(),
]);
try {
$result = $client->request($request);
$body = json_decode((string) $result->getBody(), true);
print $body;
} catch (Exception $e) {
print $e->getMessage();
}