leadpush / sdk-php
Official PHP SDK for Leadpush
Requires
- php: ^8.2
- symfony/http-client: ^7.4
Requires (Dev)
- pestphp/pest: ^3.0|^4.0
README
Official PHP SDK for the Leadpush API.
Create a Leadpush account at leadpush.io.
Installation
composer require leadpush/sdk-php
Requirements
- PHP 8.2 or newer
- A Leadpush API key
Quick Start
<?php use Leadpush\SDK\Leadpush; $client = new Leadpush($_ENV['LEADPUSH_API_KEY']); $contacts = $client->contacts()->list([ 'page' => 1, 'per_page' => 10, ]); print_r($contacts->data());
Configuration
<?php use Leadpush\SDK\Leadpush; $client = new Leadpush('leadpush_api_key', [ 'baseUrl' => 'https://api.leadpush.io/v1', 'timeout' => 30000, 'headers' => [ 'X-App-Name' => 'my-app', ], ]);
Defaults:
baseUrl:https://api.leadpush.io/v1timeout:30000
You can pass a Symfony HttpClientInterface as the third constructor argument for custom transports or tests.
Contacts
Get A Contact
$contact = $client->contacts()->get('contact_uuid'); echo $contact->uuid(); echo $contact->attributes()['email'];
Create A Contact
$contact = $client->contacts()->create([ 'subscribed' => true, 'attributes' => [ 'email' => 'person@example.com', 'first_name' => 'Person', ], ]);
Update By Id
$contact = $client->contacts()->update('contact_uuid', [ 'subscribed' => false, 'attributes' => [ 'first_name' => 'Updated', ], ]);
Update From A Model
$contact = $client->contacts()->get('contact_uuid'); $contact->setSubscribed(false); $contact->setAttribute('first_name', 'Updated'); $contact->update();
Subscribe Or Unsubscribe
$contact->subscribe(); $contact->unsubscribe();
Contact Events
$events = $client->contacts()->events('contact_uuid')->list([ 'search' => 'purchase', ]);
You can also access events from an attached contact model:
$contact = $client->contacts()->get('contact_uuid'); $events = $contact->events()->list();
Create A Contact Event
$client->contacts()->events('contact_uuid')->create([ 'event_name' => 'purchase', 'attributes' => [ 'plan' => 'enterprise', ], ]);
Contact event creation returns null when the API accepts the event. The create endpoint does not return the created event.
Pagination
List One Page
$page = $client->contacts()->list([ 'page' => 1, 'per_page' => 25, ]); print_r($page->data()); echo $page->meta()->hasNext() ? 'more' : 'done';
Iterate Every Model
foreach ($client->contacts()->listAll(['per_page' => 100]) as $contact) { echo $contact->uuid(); }
Iterate Page By Page
foreach ($client->contacts()->cursor(['per_page' => 100]) as $page) { echo $page->meta()->currentPage(); echo count($page->data()); }
Fields
List Fields
$fields = $client->fields()->list([ 'search' => 'company', 'filters' => [ [ 'id' => 'type', 'value' => ['text'], ], ], ]);
Create A Field
$field = $client->fields()->create([ 'name' => 'company_name', 'type' => 'text', 'format' => [ 'text' => 'url', ], ]);
Suppressions
List Suppressions
$suppressions = $client->suppressions()->list([ 'search' => 'blocked@example.com', 'filters' => [ [ 'id' => 'type', 'value' => ['manual'], ], ], ]);
Create A Suppression
$suppression = $client->suppressions()->create([ 'email' => 'blocked@example.com', 'type' => 'manual', ]);
Suppressions do not support updates. Calling $client->suppressions()->update(...) throws UnsupportedEndpointError.
Low-Level Requests
Use get, post, or delete for endpoints that do not have a typed resource yet.
GET
$response = $client->get('contacts/contact_uuid/events');
POST
$response = $client->post('contacts/contact_uuid/subscribe');
DELETE
$client->delete('contacts/contact_uuid');
Paths can also be passed as arrays:
$client->get(['contacts', 'contact_uuid', 'events']);
Errors
The SDK throws typed errors for common API failures:
<?php use Leadpush\SDK\Exceptions\UnauthorizedError; use Leadpush\SDK\Exceptions\ValidationError; try { $client->contacts()->list(); } catch (UnauthorizedError) { echo 'Invalid API key'; } catch (ValidationError $error) { print_r($error->response()); }
Available errors:
ApiErrorUnauthorizedErrorForbiddenErrorNotFoundErrorValidationErrorTimeoutErrorUnsupportedEndpointError
Development
composer install
composer test
Releasing
Releases are created from Git tags. Packagist reads the GitHub repository and publishes Composer versions from tags like v1.0.0.
Before the first release, submit this repository to Packagist as leadpush/sdk-php and enable the Packagist GitHub integration so new tags update automatically.
To publish a release:
- Open the
Releaseworkflow in GitHub Actions. - Run it manually with a SemVer tag like
v1.0.0. - Wait for the matrix tests to pass.
The workflow creates and pushes the Git tag, then creates a GitHub Release. Packagist will expose the tag as the matching Composer version.
License
MIT