TeamleaderApiClient
Added LICENSE
更新后的 API 客户端目前正在 v2 分支开发中
用于连接到 Teamleader API 的 PHP 客户端。
该软件包可通过 Composer 获得:
$ composer require nascom/teamleader-api-client
首先,您需要提供一个可以发出 HTTP 请求的客户端。它必须实现HttpClientInterface
。软件包中已经提供了使用 Guzzle 的客户端。这需要安装 guzzlehttp/guzzle。
<?php
use Nascom TeamleaderApiClient Http HttpClient GuzzleHttpClient ;
$ guzzle = new GuzzleHttp Client ([ ' base_uri ' => ' https://www.teamleader.be/api/ ' ]);
$ httpClient = new GuzzleHttpClient ( $ guzzle );
您可以使用此 HttpClient 实例化实际的 API 客户端。您还必须提供您的 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.
);
每个 API 端点都有一个对应的 Request 类。这些类必须传递给客户端的handle()
方法,该方法将返回一个Response对象。所有可用的请求都可以在这里找到。
例如,以下是获取项目详细信息的方法:
<?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.
额外的选项可以传递给 ApiClient。这些将与一些默认选项合并,并在发出请求时传递给 HttpClient。
<?php
$ client = new ApiClient (
$ httpClient ,
$ teamleaderParameters ,
[ ' connect_timeout ' => 5.0 ] // This will override the default timeout.
);
您可以创建自定义 HttpClient 来处理请求。它所要做的就是实现HttpClientInterface
。例如,您可以使用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
);