Klien API yang diperbarui saat ini sedang dikembangkan di cabang v2
Klien PHP untuk terhubung ke Teamleader API.
Paket ini tersedia melalui komposer:
$ composer require nascom/teamleader-api-client
Pertama, Anda harus menyediakan klien yang dapat membuat permintaan HTTP. Itu harus mengimplementasikan HttpClientInterface
. Klien yang menggunakan Guzzle sudah tersedia dalam paket. Ini memerlukan instalasi guzzlehttp/guzzle.
<?php
use Nascom TeamleaderApiClient Http HttpClient GuzzleHttpClient ;
$ guzzle = new GuzzleHttp Client ([ ' base_uri ' => ' https://www.teamleader.be/api/ ' ]);
$ httpClient = new GuzzleHttpClient ( $ guzzle );
Anda dapat menggunakan HttpClient ini untuk membuat instance klien API yang sebenarnya. Anda juga harus memberikan kredensial Teamleader API Anda.
<?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.
);
Setiap titik akhir API memiliki kelas Permintaan yang sesuai. Kelas-kelas ini harus diteruskan ke metode handle()
klien, yang akan mengembalikan objek Response. Semua permintaan yang tersedia dapat ditemukan di sini.
Misalnya, berikut cara mengambil detail proyek:
<?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.
Opsi tambahan dapat diteruskan ke ApiClient. Ini akan digabungkan dengan beberapa opsi default, dan diteruskan ke HttpClient saat membuat permintaan.
<?php
$ client = new ApiClient (
$ httpClient ,
$ teamleaderParameters ,
[ ' connect_timeout ' => 5.0 ] // This will override the default timeout.
);
Anda dapat membuat HttpClient khusus untuk menangani permintaan. Yang harus dilakukan hanyalah mengimplementasikan HttpClientInterface
. Anda dapat, misalnya, mengimplementasikan klien menggunakan 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
);