jiririedl / php-sendy
PHP class for using sendy API
Installs: 36 797
Dependents: 0
Suggesters: 0
Security: 0
Stars: 30
Watchers: 8
Forks: 8
Open Issues: 0
Requires
- php: >=5.3.0
- lib-curl: *
README
PHP interface for Sendy api (http://sendy.co/) with full support Sendy API (http://sendy.co/api)
Installation
Using composer
Simply add new require jiririedl/php-sendy
to your composer.json
.
"require": { "jiririedl/php-sendy" : ">=1.0.0" }
and update in console
composer update
Using autoload (alternative dirty way)
If you don't use Composer (for some reasons) you can download and include library bootstrap into your project manually. This wil add spl_autoload for SendyPHP namespace.
$phpSendyPath = ''; // here you can fill something like 'vendor/SendyPHP' require_once($phpSendyPath.'/bootstrap.php');
Using autoload method (alternative dirty dirty way)
If you have your own solution of class autoloading, there is prepared autload function in /src/autoload.php
.
Calling \SendyPHP\autoload($className)
includes requested class from SendyPHP
namespace or returns FALSE
Usage
Create instance of \SendyPHP\Sendy
with URL of your Sendy installation and API key.
Your API key is located in sendy - login as Admin and go to "Settings" (/settings) - your key is located in right side under topic "Your API key" beware of white spaces!
$sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey');
Some request doesn't need API key for work (f.e. subscribe() or unsubscribe()) so setting api key is optional. You can also set api key by using setApiKey() method or redefine sendy URL by setURL().
Methods
Sendy API Requests
All requests uses curl library for calling Sendy API. If you have installed library by using Composer, curl was checked automatically, otherwise you can check this in your phpinfo, or just try to call some method from curl (http://php.net/manual/en/ref.curl.php).
Subscribe
This method adds a new subscriber to a list. You can also use this method to update an existing subscriber.
bool subscribe($listID, $email, $name = NULL, array $customFields = array(), &$statusMessage = NULL)
Parameters
- $listID - the list id you want to subscribe a user to. This encrypted & hashed id can be found under View all lists section named ID
- $email - user's email
- $name <string|null> - optional -user's name is optional
- $customFields - optional - associative array of custom fields and their values f.e. array('salutation'=>'Mr.','userLevel'=>'VIP+')
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
Example
try{ $sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey'); $statusMessage = ''; $status = $sendy->subscribe('myHashedListID','newsubscribers@email.com','John Doe',$statusMessage); if($status) echo "Yeah! New subscriber successfully added"; else echo "Ops! Sendy API responds a problem with adding subscriber - Sendy PHP message :".$statusMessage; }catch (\SendyPHP\Exception $e) { echo "Ops! An exception raised: ".$e; }
Exceptions
All exceptions are extended from \SendyPHP\Exception
so you can easily catch just this parent class
\SendyPHP\Exception\InvalidEmailException
is thrown if email address is not valid\SendyPHP\Exception\DomainException
is thrown if $listID is empty\SendyPHP\Exception\CurlException
is thrown if cURL library could not handle your request
Return values
Returns TRUE on success or FALSE on failure.
UnSubscribe
This method unsubscribes a user from a list.
bool unsubscribe($listID, $email,&$statusMessage = NULL)
Parameters
- $listID - the list id you want to unsubscribe a user from. This encrypted & hashed id can be found under View all lists section named ID
- $email - user's email
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
Example
try{ $sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey'); $statusMessage = ''; $status = $sendy->unsubscribe('myHashedListID','newsubscribers@email.com',$statusMessage); if($status) echo "Subscriber successfully removed from list"; else echo "Ops! Sendy API responds a problem with unsubscribing - Sendy PHP message :".$statusMessage; }catch (\SendyPHP\Exception $e) { echo "Ops! An exception raised: ".$e; }
Exceptions
All exceptions are extended from \SendyPHP\Exception
so you can easily catch just this parent class
\SendyPHP\Exception\InvalidEmailException
is thrown if email address is not valid\SendyPHP\Exception\DomainException
is thrown if $listID is empty\SendyPHP\Exception\CurlException
is thrown if cURL library could not handle your request
Return values
Returns TRUE on success or FALSE on failure.
Delete
This method deletes a subscriber off a list (only supported in Sendy version 2.1.1.4 and above).
bool delete($listID, $email,&$statusMessage = NULL)
Parameters
- $listID - the list id you want to delete a user from. This encrypted & hashed id can be found under View all lists section named ID
- $email - user's email
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
Example
try{ $sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey'); $statusMessage = ''; $status = $sendy->delete('myHashedListID','newsubscribers@email.com',$statusMessage); if($status) echo "Subscriber successfully deleted from list"; else echo "Ops! Sendy API responds a problem with deleting - Sendy PHP message :".$statusMessage; }catch (\SendyPHP\Exception $e) { echo "Ops! An exception raised: ".$e; }
Exceptions
All exceptions are extended from \SendyPHP\Exception
so you can easily catch just this parent class
\SendyPHP\Exception\InvalidEmailException
is thrown if email address is not valid\SendyPHP\Exception\DomainException
is thrown if $listID is empty\SendyPHP\Exception\CurlException
is thrown if cURL library could not handle your request
Return values
Returns TRUE on success or FALSE on failure.
Get active subscriber count
This method gets the total active subscriber count.
number|false getActiveSubscriberCount($listID, &$statusMessage = NULL)
Parameters
- $listID - the list id you want to subscribe a user to. This encrypted & hashed id can be found under View all lists section named ID
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
Example
try{ $sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey'); $statusMessage = ''; $subscribersCount = $sendy->getActiveSubscriberCount('myHashedListID',$statusMessage); if($subscribersCount!==false) echo "In this list is $subscribersCount active subscribers"; else echo "Ops! Sendy API responds a problem with getting active subscribers count - Sendy PHP message :".$statusMessage; }catch (\SendyPHP\Exception $e) { echo "Ops! An exception raised: ".$e; }
Exceptions
All exceptions are extended from \SendyPHP\Exception
so you can easily catch just this parent class
\SendyPHP\Exception\DomainException
is thrown if $listID is empty\SendyPHP\Exception\CurlException
is thrown if cURL library could not handle your request
Return values
Returns number of active subscribers or FALSE on failure.
Get subscribtion status
This method gets the current status of a subscriber (eg. subscribed, unsubscribed, bounced, complained).
\SendyPHP\Response\SubscriptionStatus getSubscriptionStatus($listID, $email)
Parameters
- $listID - the list id you want to subscribe a user to. This encrypted & hashed id can be found under View all lists section named ID
- $email - user's email
Example
try{ $sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey'); $subscriptionStatus = $sendy->getSubscriptionStatus('myHashedListID','mysubscribers@email.com'); if($subscriptionStatus->success()) { switch(true) { case $subscriptionStatus->isSubscribed(): echo "Subscribed"; break; case $subscriptionStatus->isUnSubscribed(): echo "Unsubscribed"; break; case $subscriptionStatus->isComplained(): echo "Complained"; break; case $subscriptionStatus->isUnconfirmed(): echo "Unconfirmed"; break; case $subscriptionStatus->isHardBounced(): echo "Hard Bounced"; break; case $subscriptionStatus->isSoftBounced(): echo "Soft bounced"; break; } } else echo "Ops! Sendy API responds a problem with getting subscribtion status - Sendy PHP message :".$subscriptionStatus->getRawResponse(); }catch (\SendyPHP\Exception $e) { echo "Ops! An exception raised: ".$e; }
Exceptions
All exceptions are extended from \SendyPHP\Exception
so you can easily catch just this parent class
\SendyPHP\Exception\DomainException
is thrown if $listID is empty\SendyPHP\Exception\InvalidEmailException
is thrown if email address is not valid\SendyPHP\Exception\CurlException
is thrown if cURL library could not handle your request
Return values
\SendyPHP\Response\SubscriptionStatus
returned object has many of usable methods (see phpdoc) f.e. by calling success() are you able to check if API returns some subscribers status.
Create campaign
Creates draft of campaign
bool createCampaign($brandID, Model\Campaign $campaign, &$statusMessage = NULL)
Parameters
- $brandID - Brand IDs can be found under 'Brands' page named ID
- $campaign <\SendyPHP\Model\Campaign> - configured campaign
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
Example
try{ $sender = new \SendyPHP\Model\Sender('From name','from-adrress@mydomain.com','reply-address@mydomain.com'); $emailBody = new \SendyPHP\Model\EmailBody('<h1>HTML body of my newsletter</h1>', 'Plaintext body of my newsletter'); $campaign = new \SendyPHP\Model\Campaign($sender,'My first great newsletter!',$emailBody); $brandID = 1; // here fill your brand ID $sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey'); $statusMessage = ''; $status = $sendy->createCampaign($brandID,$campaign,$statusMessage); if($status) { echo "Campaign successfully created"; } else echo "Ops! Sendy API responds a problem with creating campaign - Sendy PHP message :".$statusMessage; }catch (\SendyPHP\Exception $e) { echo "Ops! An exception raised: ".$e; }
Exceptions
All exceptions are extended from \SendyPHP\Exception
so you can easily catch just this parent class
\SendyPHP\Exception\CurlException
is thrown if cURL library could not handle your request
Return values
Returns TRUE on success or FALSE on failure.
Send campaign
Creates draft and automatically sends campaign
bool sendCampaign(array $listIDs, Model\Campaign $campaign, &$statusMessage = NULL)
Parameters
- $listIDs <number[]> - The encrypted & hashed ids can be found under View all lists section named ID.
- $campaign <\SendyPHP\Model\Campaign> - configured campaign
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
Example
try{ $sender = new \SendyPHP\Model\Sender('From name','from-adrress@mydomain.com','reply-address@mydomain.com'); $emailBody = new \SendyPHP\Model\EmailBody('<h1>HTML body of my newsletter</h1>', 'Plaintext body of my newsletter'); $campaign = new \SendyPHP\Model\Campaign($sender,'My first great newsletter!',$emailBody); $listIDs = array(1); // here fill your list IDs $sendy = new \SendyPHP\Sendy('http://mysendyinstalation.mydomain','myAPIKey'); $statusMessage = ''; $status = $sendy->sendCampaign($listIDs,$campaign,$statusMessage); if($status) { echo "Campaign successfully created and now sending"; } else echo "Ops! Sendy API responds a problem with creating and sending campaign - Sendy PHP message :".$statusMessage; }catch (\SendyPHP\Exception $e) { echo "Ops! An exception raised: ".$e; }
Exceptions
All exceptions are extended from \SendyPHP\Exception
so you can easily catch just this parent class
\SendyPHP\Exception\CurlException
is thrown if cURL library could not handle your request\SendyPHP\Exception\DomainException
is thrown if $listIDs array is empty
Return values
Returns TRUE on success or FALSE on failure.
Other methods
Set cURL option
Sets cURL option
You can set cURL options f.e. CURLOPT_SSL_VERIFYPEER
or CURLOPT_SSL_VERIFYHOST
some parameters (\CURLOPT_RETURNTRANSFER
, \CURLOPT_POST
, \CURLOPT_POSTFIELDS
) are used, if you try to set one of these exception is thrown.
See http://php.net/manual/en/function.curl-setopt.php for more informations.
void setCurlOption($option, $value)
Parameters
- $option - use
\CURLOPT_
* constant - $value mixed
Exceptions
\SendyPHP\Exception\UnexpectedValueException
is thrown if you try to set one of predefined options (\CURLOPT_RETURNTRANSFER
, \CURLOPT_POST
and \CURLOPT_POSTFIELDS
).
Clear cURL option
Sets cURL option Clears user defined cURL options
void clearCurlOptions()
Set URL
Sets sendy installation URL Clears user defined cURL options
void setURL($URL)
Exceptions
\SendyPHP\Exception\InvalidURLException
is thrown if URL is invalid.
Set API key
Sets api key
void setApiKey($apiKey)
Parameters
- $apiKey - sendy API key - your API key is available in sendy Settings
Exceptions
\SendyPHP\Exception\DomainException
is thrown if API key is not string.