nullform / zerobounce-client
ZeroBounce API client
Requires
- php: >=7.2
- ext-curl: *
- ext-fileinfo: *
- ext-json: *
- psr/cache: ^1.0.1
- psr/simple-cache: ^1.0.1
This package is auto-updated.
Last update: 2024-12-27 16:30:16 UTC
README
Non official PHP client for ZeroBounce API.
Installation
composer require nullform/zerobounce-client
Usage
Basic
use Nullform\ZeroBounce; $client = new ZeroBounce\Client($api_key); try { $result = $client->validate($email); } catch (ZeroBounce\Exceptions\AbstractException $exception) { echo $exception->getMessage(); }
Caching
You can cache API responses if you use PSR-6 or PSR-16 caching in your project.
Just pass to Client::caching()
your cache repository instance, TTL and prefix.
If the cache instance is passed, each successful response will be stored to the cache for the $ttl
seconds.
With repeated requests with the same parameters, the response will be taken from the cache.
// Set PSR-6 or PSR-16 cache instance, TTL (60) and cache keys prefix (zerobounce_) $client->caching($cache, 60, 'zerobounce_');
Logging
You can log your API calls by passing your own function to Client::logFunction()
. Passed function will be called on every API call.
The function takes an instance of \Nullform\ZeroBounce\Client
as a parameter.
For example:
$log_func = function (ZeroBounce\Client $client) { file_put_contents('zerobounce-client.log', print_r($client->lastResponse(), true)); }; $client = new ZeroBounce\Client($api_key); $client->logFunction($log_func); $usage = $client->getUsage('2019-01-01');
Or you can just override the Client::log()
method that is called on every API call.
Methods
Client::timeout()
Client::timeout( [ int $timeout = null ] ) : int
Timeout (maximum time the request is allowed to take). Get or set value.
Client::caching()
Client::caching( $cache, int $ttl [, string $prefix = '' ] ) : bool
Caching of API responses.
You can pass null
to disable caching (default).
Client::logFunction()
Client::logFunction( ?callable $func ) : bool
The function for logging that will be called after every ZeroBounce API call.
The function takes a client instance as a parameter.
Client::lastRequest()
Client::lastRequest( void ) : Http\Request
Get last request.
Client::lastResponse()
Client::lastResponse( void ) : Http\Response
Get last response.
Client::getCredits()
Client::getCredits( void ) : int
Get credit balance. If a -1 is returned, that means your API Key is invalid.
Validation API: Credit Balance
Client::validate()
Client::validate( string $email [, ?string $ip_address = null ] ) : Models\Email
Validate email.
Validation API: Validate Emails
Client::getUsage()
Client::getUsage( mixed $start_date [, mixed $end_date = 'now' ] ) : Models\Usage
Get API usage.
$start_date
and $end_date
- timestamp or string that the strtotime(), DateTime and date_create() parser understands.
Client::bulkSendFile()
Client::bulkSendFile( string $filename, string $type, Params\BulkSendFileParams $params ) : Models\BulkFile
Send a csv or txt file for bulk email validation/scoring.
$client = new Client($api_key); $client->timeout(60); $params = new Params\BulkSendFileParams(); $params->email_address_column = 2; $file = $client->bulkSendFile($filename, Models\BulkFile::TYPE_VALIDATION, $params);
Validation API: Send File | AI Scoring API: Send File
Client::bulkFileStatus()
Client::bulkFileStatus( string $file_id, string $type ) : Models\BulkFile
Uploaded file status.
Validation API: File Status | AI Scoring API: File Status
Client::bulkGetFile()
Client::bulkGetFile( string $file_id, string $type [, ?string $output_filename = null ] ) : string
Get the validation/scoring results csv (or zip) file for the file been submitted using sendfile API.
Validation API: Get File | AI Scoring API: Get File
Client::bulkDeleteFile()
Client::bulkDeleteFile( string $file_id, string $type ) : bool
Delete the file that was submitted using sendfile API. File can be deleted only when its status is Complete.
Validation API: Delete File | AI Scoring API: Delete File
Facade
You can use facade for quick email validation and balance check.
use Nullform\ZeroBounce\Facade as ZeroBounce; try { $result = ZeroBounce::validate($api_key, $email); $credits = ZeroBounce::getCredits($api_key); } catch (\Exception $exception) { $error = $exception->getMessage(); }