summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/SendGridCompatibility/Email.php199
-rw-r--r--lib/SendGridCompatibility/SendGrid.php22
-rw-r--r--lib/SparkPost/SparkPost.php (renamed from lib/MessageSystems/SparkPost.php)13
-rw-r--r--lib/SparkPost/Transmission.php (renamed from lib/MessageSystems/Transmission.php)83
4 files changed, 276 insertions, 41 deletions
diff --git a/lib/SendGridCompatibility/Email.php b/lib/SendGridCompatibility/Email.php
new file mode 100644
index 0000000..5351324
--- /dev/null
+++ b/lib/SendGridCompatibility/Email.php
@@ -0,0 +1,199 @@
+<?php
+namespace SparkPost\SendGridCompatibility;
+
+class Email {
+ public $model;
+
+
+ /**
+ * @desc Sets up the model for saving the configuration
+ */
+ public function __construct() {
+ $this->model = array();
+ }
+
+ /**
+ * @desc adds addresses as recipients
+ * @param string $address
+ * @param string $name optional
+ * @return \SparkPost\SendGridCompatibility\Email
+ */
+ public function addTo($address, $name = null) {
+ if (!isset($this->model['recipients'])) {
+ $this->model['recipients'] = array();
+ }
+
+ if(isset($name)) {
+ $address = array('address'=>array('email'=>$address, 'name'=>$name));
+ } else {
+ $address = array('address'=>array('email'=>$address));
+ }
+
+ array_push($this->model['recipients'], $address);
+ return $this;
+ }
+
+ /**
+ * @desc explicitly sets a list of addresses
+ * @param array $addresses
+ * @return \SparkPost\SendGridCompatibility\Email
+ */
+ public function setTos(array $addresses) {
+ $this->model['recipients'] = $addresses;
+ return $this;
+ }
+
+ /**
+ * @desc sets the from address
+ * @param string $address
+ * @return \MessageSystems\SendGridCompatibility\Email
+ */
+ public function setFrom($address) {
+ $this->model['from'] = array('email' => $address);
+ return $this;
+ }
+
+ /**
+ * @desc sets the name for the from address
+ * @param string $name
+ */
+ public function setFromName($name) {
+ if(!isset($this->model['from'])){
+ throw new \Exception('Must set "From" prior to setting "From Name".');
+ }
+ $this->model['from']['name'] = $name;
+ return $this;
+ }
+
+ /**
+ * @desc sets the reply to field
+ * @param string $address
+ * @return \MessageSystems\SendGridCompatibility\Email
+ */
+ public function setReplyTo ($address) {
+ $this->model['replyTo'] = $address;
+ return $this;
+ }
+
+ /**
+ * @desc throws an error because bcc fields are not yet implemented.
+ * @throws \Exception
+ * @param string $address
+ * @return \MessageSystems\SendGridCompatibility\Email
+ */
+ public function addBcc($address) {
+ throw new \Exception('Adding bcc recipients is not yet supported, try adding them as a "to" address');
+ }
+
+ /**
+ * @desc sets the subject header
+ * @param string $subject
+ * @return \SparkPost\SendGridCompatibility\Email
+ */
+ public function setSubject($subject) {
+ $this->model['subject'] = $subject;
+ return $this;
+ }
+
+ /**
+ * @desc sets the text body
+ * @param string $text
+ * @return \SparkPost\SendGridCompatibility\Email
+ */
+ public function setText($text) {
+ $this->model['text'] = $text;
+ return $this;
+ }
+
+ /**
+ * @desc sets the html body
+ * @param string $html
+ * @return \SparkPost\SendGridCompatibility\Email
+ */
+ public function setHtml($html) {
+ $this->model['html'] = $html;
+ return $this;
+ }
+
+ /**
+ * @desc Throws an exception since adding categories is not yet supported
+ * @throws \Exception
+ * @param string $category
+ * @throws \Exception
+ */
+ public function addCategory($category) {
+ throw new \Exception('Adding categories is not yet supported');
+ }
+
+ /**
+ * @desc Throws an exception since adding attachments is not yet supported
+ * @throws Exception
+ * @param mixed $attachment
+ */
+ public function addAttachment($attachment) {
+ throw new \Exception('Adding attachments is not yet supported');
+ }
+
+ /**
+ * @desc Adds transmission level substitution data
+ * @param string $name
+ * @param mixed $values
+ * @return \SparkPost\SendGridCompatibility\Email
+ */
+ public function addSubstitution($name, $values) {
+ if (!isset($this->model['substitutionData'])) {
+ $this->model['substitutionData'] = array();
+ }
+ $this->model['substitutionData'][$name] = $values;
+
+ return $this;
+ }
+
+ /**
+ * @desc Adds transmission level substitution data
+ * @param string $name
+ * @param mixed $values
+ */
+ public function addSection($name, $values) {
+ $this->addSubstitution($name, $values);
+ }
+
+ /**
+ * @desc Throws an exception because arguments for third party systems is not supported
+ * @throws Exception
+ * @param mixed $value
+ */
+ public function addUniqueArg($key, $value) {
+ throw new \Exception('Adding Unique Arguments is not yet supported');
+ }
+
+ /**
+ * @desc Throws an exception because arguments for third party systems is not supported
+ * @throws Exception
+ * @param mixed $values
+ */
+ public function setUniqueArgs(array $values) {
+ throw new \Exception('Setting Unique Arguments is not yet supported');
+ }
+
+ /**
+ * @desc Adds custom headers to the email header
+ * @param string $name
+ * @param string $value
+ */
+ public function addHeader($name, $value) {
+ if (!isset($this->model['customHeaders'])) {
+ $this->model['customHeaders'] = array();
+ }
+ $this->model['customHeaders'][$name] = $value;
+ }
+
+ /**
+ * @desc converts this object to a configuration for a SparkPost transmission
+ * @return array
+ */
+ public function toSparkPostTransmission() {
+ return $this->model;
+ }
+}
+?> \ No newline at end of file
diff --git a/lib/SendGridCompatibility/SendGrid.php b/lib/SendGridCompatibility/SendGrid.php
new file mode 100644
index 0000000..a85337a
--- /dev/null
+++ b/lib/SendGridCompatibility/SendGrid.php
@@ -0,0 +1,22 @@
+<?php
+namespace SparkPost\SendGridCompatibility;
+
+use SparkPost\Transmission;
+use SparkPost\SendGridCompatibility\Email;
+use SparkPost\Configuration;
+
+class SendGrid{
+ public function __construct($username, $password, $options = null) {
+ //username isn't used in our system
+ $opts = array('key'=>$password);
+ if (!is_null($options)) {
+ $opts = array_merge($opts, $options);
+ }
+ Configuration::setConfig($opts);
+ }
+
+ public function send(Email $email) {
+ Trasmission::send($email->toSparkPostTransmission());
+ }
+}
+?> \ No newline at end of file
diff --git a/lib/MessageSystems/SparkPost.php b/lib/SparkPost/SparkPost.php
index b1ad20a..5c2a554 100644
--- a/lib/MessageSystems/SparkPost.php
+++ b/lib/SparkPost/SparkPost.php
@@ -1,17 +1,17 @@
<?php
-namespace MessageSystems;
+namespace SparkPost;
class SparkPost {
private static $config;
- private static $defaults = [
+ private static $defaults = array(
'host'=>'api.sparkpost.com',
'protocol'=>'https',
'port'=>443,
'strictSSL'=>true,
'key'=>'',
'version'=>'v1'
- ];
+ );
/**
* Enforce that this object can't be instansiated
@@ -25,7 +25,12 @@ class SparkPost {
*/
public static function setConfig(array $configMap) {
//check for API key because its required
- if (!isset($configMap['key']) || empty(trim($configMap['key']))){
+ if (isset($configMap['key'])){
+ $key = trim($configMap['key']);
+ if(empty($key)){
+ throw new \Exception('You must provide an API key');
+ }
+ } else {
throw new \Exception('You must provide an API key');
}
self::$config = self::$defaults;
diff --git a/lib/MessageSystems/Transmission.php b/lib/SparkPost/Transmission.php
index e820cff..c083825 100644
--- a/lib/MessageSystems/Transmission.php
+++ b/lib/SparkPost/Transmission.php
@@ -1,7 +1,7 @@
<?php
-namespace MessageSystems;
-use GuzzleHttp\Client;
-use GuzzleHttp\Exception\RequestException;
+namespace SparkPost;
+use Guzzle\Http\Client;
+use Guzzle\Http\Exception\ClientErrorResponseException;
/**
* @desc SDK interface for managing transmissions
@@ -17,7 +17,7 @@ class Transmission {
* @desc Mapping for values passed into the send method to the values needed for the Transmission API
* @var array
*/
- private static $parameterMappings = [
+ private static $parameterMappings = array(
'campaign'=>'campaign_id',
'metadata'=>'metadata',
'substitutionData'=>'substitution_data',
@@ -28,33 +28,33 @@ class Transmission {
'from'=>'content.from',
'html'=>'content.html',
'text'=>'content.text',
- 'rfc822Part'=>'content.email_rfc822',
- 'headers'=>'content.headers',
+ 'rfc822'=>'content.email_rfc822',
+ 'customHeaders'=>'content.headers',
'recipients'=>'recipients',
'recipientList'=>'recipients.list_id',
'template'=>'content.template_id',
- 'openTracking'=>'options.open_tracking',
- 'clickTracking'=>'options.click_tracking',
+ 'trackOpens'=>'options.open_tracking',
+ 'trackClicks'=>'options.click_tracking',
'useDraftTemplate'=>'use_draft_template'
- ];
+ );
/**
* @desc Sets up default structure and default values for the model that is acceptable by the API
* @var array
*/
- private static $structure = [
+ private static $structure = array(
'return_path'=>"default@sparkpostmail.com",
- 'content'=>[
+ 'content'=>array(
'html'=>null,
'text'=>null,
'email_rfc822'=>null
- ],
- 'options'=>[
+ ),
+ 'options'=>array(
'open_tracking'=>true,
'click_tracking'=>true
- ],
+ ),
'use_draft_template'=>false
- ];
+ );
/**
* @desc Ensure that this class cannot be instansiated
@@ -113,13 +113,13 @@ class Transmission {
* 'from': string,
* 'html': string,
* 'text': string,
- * 'rfc822Part': string,
- * 'headers': array,
+ * 'rfc822': string,
+ * 'customHeaders': array,
* 'recipients': array,
* 'recipientList': string,
* 'template': string,
- * 'openTracking': boolean,
- * 'clickTracking': boolean,
+ * 'trackOpens': boolean,
+ * 'trackClicks': boolean,
* 'useDraftTemplate': boolean
*
* @return array API repsonse represented as key-value pairs
@@ -136,19 +136,23 @@ class Transmission {
//send the request
try {
- $response = $request->post(self::getBaseUrl($hostConfig), [
- 'json'=>$model,
- "headers"=>['authorization' => $hostConfig['key']],
- "verify"=>$hostConfig['strictSSL']
- ]);
+ $response = $request->post(self::getBaseUrl($hostConfig), array('authorization' => $hostConfig['key']), json_encode($model), array("verify"=>$hostConfig['strictSSL']))->send();
return $response->json();
- } catch (RequestException $exception) {
+ }
+ /*
+ * Handles 4XX responses
+ */
+ catch (ClientErrorResponseException $exception) {
$response = $exception->getResponse();
- throw new \Exception(json_encode($response->json()['errors']));
- } catch (\Exception $exception) {
+ $responseArray = $response->json();
+ throw new \Exception(json_encode($responseArray['errors']));
+ }
+ /*
+ * Handles 5XX Errors, Configuration Errors, and a catch all for other errors
+ */
+ catch (\Exception $exception) {
throw new \Exception('Unable to contact Transmissions API: '. $exception->getMessage());
}
-
}
/**
@@ -174,19 +178,24 @@ class Transmission {
//make request
try {
- $response = $request->get($url, [
- "headers"=>['authorization' => $hostConfig['key']],
- "verify"=>$hostConfig['strictSSL']
- ]);
+ $response = $request->get($url, array('authorization' => $hostConfig['key']), array("verify"=>$hostConfig['strictSSL']))->send();
return $response->json();
- } catch (RequestException $exception) {
+ }
+ /*
+ * Handles 4XX responses
+ */
+ catch (ClientErrorResponseException $exception) {
$response = $exception->getResponse();
- if($response->getStatusCode() === '404') {
+ $statusCode = $response->getStatusCode();
+ if($statusCode === 404) {
throw new \Exception("The specified Transmission ID does not exist", 404);
- } else {
- throw new \Exception("Received bad response from Transmission API: ". $response->getStatusCode());
}
- } catch (\Exception $exception) {
+ throw new \Exception("Received bad response from Transmission API: ". $statusCode);
+ }
+ /*
+ * Handles 5XX Errors, Configuration Errors, and a catch all for other errors
+ */
+ catch (\Exception $exception) {
throw new \Exception('Unable to contact Transmissions API: '. $exception->getMessage());
}
}