Le client API mis à jour est actuellement en cours de développement dans la branche v2
Client PHP pour se connecter à l'API Teamleader.
Le package est disponible via composer :
$ composer require nascom/teamleader-api-client
Tout d’abord, vous devrez fournir un client capable d’effectuer des requêtes HTTP. Il doit implémenter HttpClientInterface
. Un client utilisant Guzzle est déjà disponible dans le package. Cela nécessite l'installation de guzzlehttp/guzzle.
<?php
use Nascom TeamleaderApiClient Http HttpClient GuzzleHttpClient ;
$ guzzle = new GuzzleHttp Client ([ ' base_uri ' => ' https://www.teamleader.be/api/ ' ]);
$ httpClient = new GuzzleHttpClient ( $ guzzle );
Vous pouvez utiliser ce HttpClient pour instancier le client API réel. Vous devrez également fournir vos identifiants Teamleader API.
<?php
use Nascom TeamleaderApiClient Http ApiClient ApiClient ;
$ teamleaderParameters = [
' api_group ' => ' 12345 ' ,
' api_secret ' => ' XXXXXXXXXXXXXXX '
];
$ client = new ApiClient (
$ httpClient , // A client implementing HttpClientInterface.
$ teamleaderParameters // An array containing the Teamleader credentials.
);
Chaque point de terminaison d’API possède une classe Request correspondante. Ces classes doivent être transmises à la méthode handle()
du client, qui renverra un objet Response. Toutes les demandes disponibles peuvent être trouvées ici.
Par exemple, voici comment récupérer les détails d’un projet :
<?php
use Nascom TeamleaderApiClient Request Project RetrieveProjectRequest ;
$ projectRequest = new RetrieveProjectRequest ( 23 );
$ response = $ client -> handle ( $ projectRequest );
echo $ response -> getData (); // Returns the Teamleader JSON response as a string.
Des options supplémentaires peuvent être transmises à ApiClient. Celles-ci seront fusionnées avec certaines options par défaut et transmises au HttpClient lors d'une demande.
<?php
$ client = new ApiClient (
$ httpClient ,
$ teamleaderParameters ,
[ ' connect_timeout ' => 5.0 ] // This will override the default timeout.
);
Vous pouvez créer un HttpClient personnalisé pour gérer les demandes. Tout ce qu'il a à faire est d'implémenter HttpClientInterface
. Vous pouvez, par exemple, implémenter un client en utilisant curl.
<?php
use Nascom TeamleaderApiClient Http HttpClient HttpClientInterface ;
class CurlHttpClient implements HttpClientInterface
{
public function request ( $ method , $ uri , array $ options = [])
{
$ curl = curl_init ();
curl_setopt_array ( $ curl , array (
CURLOPT_RETURNTRANSFER => 1 ,
CURLOPT_URL => ' https://www.teamleader.be/api/ ' . $ uri ,
CURLOPT_POST => 1 ,
CURLOPT_POSTFIELDS => $ options [ ' form_params ' ]
));
$ response = curl_exec ( $ curl );
curl_close ( $ curl );
return $ response ;
}
}
$ client = new ApiClient (
new CurlHttpCLient (),
$ teamleaderParameters
);