madeitbelgium / teamleader
Laravel TeamLeader SDK
Fund package maintenance!
madeitbelgium
Installs: 6 627
Dependents: 0
Suggesters: 0
Security: 0
Stars: 13
Watchers: 5
Forks: 14
Open Issues: 0
Requires
- php: >=7.2
- guzzlehttp/guzzle: ^6.5|7.*
- illuminate/container: *
- illuminate/support: *
- nesbot/carbon: ^1.35|^2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: 2.*
- mockery/mockery: 0.9
- php-coveralls/php-coveralls: ^2.0
- phpunit/phpunit: 7.*|6.*|8.*
README
With this Laravel package you can create a TeamLeader integration.
Installation
composer require madeitbelgium/teamleader
Or require this package in your composer.json
and update composer.
"madeitbelgium/teamleader": "^1.8"
Publish config file
php artisan vendor:publish --provider="MadeITBelgium\TeamLeader\ServiceProvider\TeamLeader"
Laravel <5.5
After updating composer, add the ServiceProvider to the providers array in config/app.php
MadeITBelgium\TeamLeader\ServiceProvider\TeamLeader::class,
You can use the facade for shorter code. Add this to your aliases:
'TeamLeader' => MadeITBelgium\TeamLeader\Facade\TeamLeader::class,
Documentation
Usage
use MadeITBelgium\TeamLeader\TeamLeader; $teamLeader = new TeamLeader($appUrl, $clientId, $clientSecret, $redirectUri, $client = null);
In laravel you can use the Facade
use MadeITBelgium\TeamLeader\Facade\TeamLeader; $teamLeaderContact = TeamLeader::crm()->contact()->add([ 'first_name' => 'Tjebbe', 'last_name' => 'Lievens', 'emails' => [ [ 'type' => 'primary', 'email' => 'info@madeit.be', ] ], 'telephones' => [ ['type' => 'mobile', 'number' => '0000000000'], ], 'addresses' => [ [ 'type' => 'primary', 'address' => [ 'line_1' => 'Adres 1', 'postal_code' => '1234', 'city' => 'Cityname', 'country' => 'BE', ] ] ], 'language' => "nl", ]); $contactId = $teamLeaderContact->data->id;
Authentication
Create a redirect URL and redirect the user to the teamleader URL.
TeamLeader::setRedirectUrl($redirect_url); $redirectTo = TeamLeader::getAuthorizationUrl();
When the user succesfully is authenticated. The user is redirect to the provided redirect URL. You can now request (and save) the access and refersh token.
$accessTokenResult = TeamLeader::requestAccessToken($request->get('code')); $access_token = TeamLeader::getAccessToken(); $refresh_token = TeamLeader::getRefreshToken(); $expired_at = TeamLeader::getExpiresAt();
The access token has a short expire time. Before each reqeust check if the access token is still valid.
TeamLeader::setAccessToken($access_token); TeamLeader::setRefreshToken($refresh_token); TeamLeader::setExpiresAt($expired_at); $refresh = TeamLeader::checkAndDoRefresh(); if (false !== $refresh) { $access_token = TeamLeader::getAccessToken(); $refresh_token = TeamLeader::getRefreshToken(); $expired_at = TeamLeader::getExpiresAt(); //Save data to database }
All available endpoints
Need more endpoints? Create an issue or contact us.
TeamLeader::setRedirectUrl($redirect_url); TeamLeader::getAuthorizationUrl(); TeamLeader::requestAccessToken($code); TeamLeader::getAccessToken(); TeamLeader::getRefreshToken(); TeamLeader::getExpiresAt(); TeamLeader::setAccessToken($access_token); TeamLeader::setRefreshToken($refresh_token); TeamLeader::setExpiresAt($expired_at); TeamLeader::checkAndDoRefresh(); TeamLeader::general()->department()->list() TeamLeader::general()->department()->info($id) TeamLeader::general()->user()->me() TeamLeader::general()->user()->list() TeamLeader::general()->user()->info($id) TeamLeader::general()->team()->list() TeamLeader::general()->customField()->list() TeamLeader::general()->customField()->info($id) TeamLeader::general()->workType()->list() TeamLeader::crm()->contact()->list(['filter' => ..., 'page' => ..., 'sort' => ...]); //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.list TeamLeader::crm()->contact()->info($id); //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.info TeamLeader::crm()->contact()->add(['first_name' => ..., ...]); //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.add TeamLeader::crm()->contact()->update($id, ['first_name' => ...]) //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.update TeamLeader::crm()->contact()->delete($id); //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.delete TeamLeader::crm()->contact()->tag($id, $tags); //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.tag TeamLeader::crm()->contact()->untag($id, $tags); //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.untag TeamLeader::crm()->contact()->linkToCompany($id, $companyId, $position, $decisionMaker) //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.linktocompany TeamLeader::crm()->contact()->unlinkToCompany($id, $companyId); //https://developer.focus.teamleader.eu/#/reference/crm/contacts/contacts.unlinkfromcompany TeamLeader::crm()->company()->list(['filter' => ..., 'page' => ..., 'sort' => ...]); //https://developer.focus.teamleader.eu/#/reference/crm/companies/companies.list TeamLeader::crm()->company()->info($id); //https://developer.focus.teamleader.eu/#/reference/crm/companies/companies.info TeamLeader::crm()->company()->add(['first_name' => ..., ...]); //https://developer.focus.teamleader.eu/#/reference/crm/companies/companies.add TeamLeader::crm()->company()->update($id, ['first_name' => ...]) //https://developer.focus.teamleader.eu/#/reference/crm/companies/companies.update TeamLeader::crm()->company()->delete($id); //https://developer.focus.teamleader.eu/#/reference/crm/companies/companies.delete TeamLeader::crm()->company()->tag($id, $tags); //https://developer.focus.teamleader.eu/#/reference/crm/companies/companies.tag TeamLeader::crm()->company()->untag($id, $tags); //https://developer.focus.teamleader.eu/#/reference/crm/companies/companies.untag TeamLeader::deals()->list($data = []); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.list TeamLeader::deals()->info($id); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.info TeamLeader::deals()->create($data); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.create TeamLeader::deals()->update($id, $data); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.update TeamLeader::deals()->move($id, $phaseId); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.move TeamLeader::deals()->win($id); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.win TeamLeader::deals()->lose($id, $reason_id = null, $extra_info = null); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.lose TeamLeader::deals()->delete($id); //https://developer.focus.teamleader.eu/#/reference/deals/deals/deals.delete TeamLeader::deals()->lostReasons($data = []); //https://developer.focus.teamleader.eu/#/reference/deals/deals/lostreasons.list TeamLeader::invoicing()->invoices()->list($data = []) TeamLeader::invoicing()->invoices()->info($id) TeamLeader::invoicing()->invoices()->draft($data) TeamLeader::invoicing()->invoices()->update($id, $data) TeamLeader::invoicing()->invoices()->delete($id) TeamLeader::invoicing()->invoices()->download($id, $format = 'pdf') TeamLeader::invoicing()->invoices()->copy($id) TeamLeader::invoicing()->invoices()->book($id, $on) TeamLeader::invoicing()->invoices()->registerPayment($id, $paid_at, $amount, $currency = 'EUR') TeamLeader::invoicing()->invoices()->credit($id, $creditNoteDate) TeamLeader::invoicing()->taxRates()->list() TeamLeader::invoicing()->subscriptions()->list($data = []) TeamLeader::invoicing()->subscriptions()->info($id) TeamLeader::invoicing()->subscriptions()->create($data) TeamLeader::invoicing()->subscriptions()->update($id, $data) TeamLeader::invoicing()->subscriptions()->deactivate($id) TeamLeader::products()->product()->categoriesList($data = []) TeamLeader::products()->product()->list($data = []) TeamLeader::products()->product()->info($id) TeamLeader::products()->product()->add($data) TeamLeader::timeTracking()->list($data = []) TeamLeader::timeTracking()->info($id) TeamLeader::timeTracking()->add($data) TeamLeader::timeTracking()->update($id, $data) TeamLeader::timeTracking()->resume($id, $data) TeamLeader::timeTracking()->delete($id) TeamLeader::milestones()->list($data = []) TeamLeader::milestones()->info($id) TeamLeader::milestones()->add($data) TeamLeader::milestones()->update($id, $data) TeamLeader::milestones()->delete($id) TeamLeader::milestones()->close($id) TeamLeader::milestones()->open($id) TeamLeader::tasks()->list($data = []) TeamLeader::tasks()->info($id) TeamLeader::tasks()->add($data) TeamLeader::tasks()->update($id, $data) TeamLeader::tasks()->delete($id) TeamLeader::tasks()->complete($id) TeamLeader::tasks()->reopen($id) TeamLeader::tasks()->schedule($id) TeamLeader::webhooks()->list(); //https://developer.focus.teamleader.eu/#/reference/other/webhooks/webhooks.list TeamLeader::webhooks()->register($data); //https://developer.focus.teamleader.eu/#/reference/other/webhooks/webhooks.register TeamLeader::webhooks()->unregister($url, $types); //https://developer.focus.teamleader.eu/#/reference/other/webhooks/webhooks.unregister
The complete documentation can be found at: http://www.madeit.be/
Support
Support github or mail: tjebbe.lievens@madeit.be
Contributing
Please try to follow the psr-2 coding style guide. http://www.php-fig.org/psr/psr-2/
License
This package is licensed under LGPL. You are free to use it in personal and commercial projects. The code can be forked and modified, but the original copyright author should always be included!