PHP interface for Sendy api (http://sendy.co/) with full support Sendy API (http://sendy.co/api)
Simply add new require jiririedl/php-sendy to your composer.json.
"require": {
"jiririedl/php-sendy" : ">=1.0.0"
}and update in console
composer updateIf 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');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
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().
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).
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, &$statusMessage = NULL)- $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
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
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;
}All exceptions are extended from \SendyPHP\Exception so you can easily catch just this parent class
\SendyPHP\Exception\InvalidEmailExceptionis thrown if email address is not valid\SendyPHP\Exception\DomainExceptionis thrown if $listID is empty\SendyPHP\Exception\CurlExceptionis thrown if cURL library could not handle your request
Returns TRUE on success or FALSE on failure.
This method unsubscribes a user from a list.
bool unsubscribe($listID, $email,&$statusMessage = NULL)- $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
- $statusMessage <string|null> - optional - here will be returned status message f.e. if you get FALSE again, and again, here you can find why
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;
}All exceptions are extended from \SendyPHP\Exception so you can easily catch just this parent class
\SendyPHP\Exception\InvalidEmailExceptionis thrown if email address is not valid\SendyPHP\Exception\DomainExceptionis thrown if $listID is empty\SendyPHP\Exception\CurlExceptionis thrown if cURL library could not handle your request
Returns TRUE on success or FALSE on failure.
This method gets the total active subscriber count.
number|false getActiveSubscriberCount($listID, &$statusMessage = NULL)- $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
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;
}All exceptions are extended from \SendyPHP\Exception so you can easily catch just this parent class
\SendyPHP\Exception\DomainExceptionis thrown if $listID is empty\SendyPHP\Exception\CurlExceptionis thrown if cURL library could not handle your request
Returns number of active subscribers or FALSE on failure.
This method gets the current status of a subscriber (eg. subscribed, unsubscribed, bounced, complained).
\SendyPHP\Response\SubscriptionStatus getSubscriptionStatus($listID, $email)- $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
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;
}All exceptions are extended from \SendyPHP\Exception so you can easily catch just this parent class
\SendyPHP\Exception\DomainExceptionis thrown if $listID is empty\SendyPHP\Exception\InvalidEmailExceptionis thrown if email address is not valid\SendyPHP\Exception\CurlExceptionis thrown if cURL library could not handle your request
\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.
Creates draft of campaign
bool createCampaign($brandID, Model\Campaign $campaign, &$statusMessage = NULL)- $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
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;
}All exceptions are extended from \SendyPHP\Exception so you can easily catch just this parent class
\SendyPHP\Exception\CurlExceptionis thrown if cURL library could not handle your request
Returns TRUE on success or FALSE on failure.
Creates draft and automatically sends campaign
bool sendCampaign(array $listIDs, Model\Campaign $campaign, &$statusMessage = NULL)- $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
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;
}All exceptions are extended from \SendyPHP\Exception so you can easily catch just this parent class
\SendyPHP\Exception\CurlExceptionis thrown if cURL library could not handle your request\SendyPHP\Exception\DomainExceptionis thrown if $listIDs array is empty
Returns TRUE on success or FALSE on failure.
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)- $option - use
\CURLOPT_* constant - $value mixed
\SendyPHP\Exception\UnexpectedValueException is thrown if you try to set one of predefined options (\CURLOPT_RETURNTRANSFER, \CURLOPT_POST and \CURLOPT_POSTFIELDS).
Sets cURL option Clears user defined cURL options
void clearCurlOptions()Sets sendy installation URL Clears user defined cURL options
void setURL($URL)\SendyPHP\Exception\InvalidURLException is thrown if URL is invalid.
Sets api key
void setApiKey($apiKey)- $apiKey - sendy API key - your API key is available in sendy Settings
\SendyPHP\Exception\DomainException is thrown if API key is not string.