webparking / laravel-visma
Laravel API helper for Visma eAccounting
This package's canonical repository appears to be gone and the package has been frozen as a result.
Requires
- php: ^7.3
- ext-json: *
- laravel/framework: ^5.5 || ^6.0 || ^7.0 || ^8.0
- league/oauth2-client: ^2.4
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.16
- phpstan/phpstan: ^0.12.18
This package is auto-updated.
Last update: 2023-10-10 12:00:14 UTC
README
Does nothing more than helping you setup the oAuth connection for the eAccounting API (https://eaccountingapi.vismaonline.com/swagger/ui/index) and giving you a few simple wrappers to make life a bit easier.
Installation
composer require webparking/laravel-visma
Usage
Preparations
- Register your app https://selfservice.developer.vismaonline.com/
- Set the .env variables (see config/visma.php)
1. Making redirect url for initial consent
/** @var Client $client */
$client = app()->make(Client::class)->connect();
return redirect()->away($client->getAuthorizationUrl());
2. Use the received token to generate an access & refresh token
$authorizationCode = ''; // Received through request
/** @var Client $client */
$client = app()->make(Client::class)->connect();
/** @var AccessTokenInterface $tokens */
$tokens = $client->getAccessToken($authorizationCode);
// Store those for future requests
$accessToken = $tokens->getToken();
$refeshToken = $tokens->getRefreshToken();
Basic requests preparation
/** @var VismaClient $client */
$client = app()->make(VismaClient::class)->connect();
/** @var AccessTokenInterface $tokens */
$tokens = $client->getNewRefreshToken($refeshToken);
// Store those for future requests
$accessToken = $tokens->getToken();
$refeshToken = $tokens->getRefreshToken();
$client->setToken($accessToken);
Example request
// Get all accounts
$accounts = (new Account($client)->index();
// Get accountBalances at certain date
$balances = (new AccountBalance($client)->index(Carbon::now());
// Get accountBalances at certain date for specific account
$balances = (new AccountBalance($client)->index(Carbon::now(), '4001');
Notes
This is a bare minimal helper for the Visma eAccounting API that just covers what we needed. Feel free to improve it.
Licence and Postcardware
This software is open source and licensed under the MIT license.
If you use this software in your daily development we would appreciate to receive a postcard of your hometown.
Please send it to: Webparking BV, Cypresbaan 31a, 2908 LT Capelle aan den IJssel, The Netherlands