From ffce65adf7bffb89d6885d339e2bae40bb3de988 Mon Sep 17 00:00:00 2001 From: Richard Leland Date: Tue, 26 Apr 2016 17:06:02 -0400 Subject: [PATCH] Update get_request_body to address reply to, from overrides * Update get_request_body to address reply to, from overrides * Fixes #33 * Modifies payload to only include releveant bits depending on whether user has a template vs. inline content * Adds from and reply_to sub data when using a template * Add from_localpart to sub data for stored templates * Update template help to link to WordPress article --- admin.widget.class.php | 4 +- mailer.http.class.php | 101 +++++++++++++++++++++++++++-------------- 2 files changed, 67 insertions(+), 38 deletions(-) diff --git a/admin.widget.class.php b/admin.widget.class.php index 2b88e7a0..f8466b39 100644 --- a/admin.widget.class.php +++ b/admin.widget.class.php @@ -234,11 +234,9 @@ public function render_template_field() value="options['template']; ?>"/>
options = SparkPost::get_options(); @@ -18,7 +22,16 @@ function __construct($exceptions = false) parent::__construct($exceptions); } - function mailSend($header, $body) { /** TODO check if need to use $header, $body */ + /** + * Send mail using SparkPost + * @param string $header The message headers + * @param string $body The message body + * @throws SparkPostException + * @access protected + * @return boolean + */ + protected function mailSend($header, $body) + { return $this->sparkpostSend(); } @@ -43,50 +56,68 @@ function sparkpostSend() $this->edebug('Response received'); return $this->handle_response($result); - - } + /** + * Build the request body to be sent to the SparkPost API. + */ protected function get_request_body() { $tracking_enabled = !!$this->options['enable_tracking']; $sender = $this->get_sender(); - $body = array( - 'recipients' => $this->get_recipients(), - 'content' => array( - 'from' => $sender, - 'subject' => $this->Subject, - 'headers' => $this->get_headers() - ), - 'options' => array( - 'open_tracking' => $tracking_enabled, - 'click_tracking' => $tracking_enabled - ) + $replyTo = $this->get_reply_to(); + $body = array(); + + // add recipients + $body['recipients'] = $this->get_recipients(); + + // enable engagement tracking + $body['options'] = array( + 'open_tracking' => $tracking_enabled, + 'click_tracking' => $tracking_enabled ); + // pass through either stored template or inline content if (!empty($this->options['template'])) { - $body['content']['template_id'] = $this->options['template']; - $body['substitution_data']['content'] = $this->Body; - $body['substitution_data']['subject'] = $this->Subject; - $body['substitution_data']['from_name'] = $sender['name']; + // stored template + $body['content']['template_id'] = $this->options['template']; + + // supply substitution data so users can add variables to templates + $body['substitution_data']['content'] = $this->Body; + $body['substitution_data']['subject'] = $this->Subject; + $body['substitution_data']['from_name'] = $sender['name']; + $body['substitution_data']['from'] = $sender['name'] . ' <' . $sender['email'] . '>'; + if ($replyTo) { + $body['substitution_data']['reply_to'] = $replyTo; + } + $localpart = explode('@', $sender['email']); + if (!empty($localpart)) { + $body['substitution_data']['from_localpart'] = $localpart[0]; + } } else { - switch($this->ContentType) { - case 'multipart/alternative': - $body['content']['html'] = $this->Body; - $body['content']['text'] = $this->AltBody; - break; - case 'text/plain': - $body['content']['text'] = $this->Body; - break; - default: - $body['content']['html'] = $this->Body; - break; - } - } + // inline content + $body['content'] = array( + 'from' => $sender, + 'subject' => $this->Subject, + 'headers' => $this->get_headers() + ); - $replyTo = $this->get_reply_to(); - if ($replyTo) { - $body['content']['reply_to'] = $replyTo; + if ($replyTo) { + $body['content']['reply_to'] = $replyTo; + } + + switch($this->ContentType) { + case 'multipart/alternative': + $body['content']['html'] = $this->Body; + $body['content']['text'] = $this->AltBody; + break; + case 'text/plain': + $body['content']['text'] = $this->Body; + break; + default: + $body['content']['html'] = $this->Body; + break; + } } $attachments = $this->get_attachments(); @@ -150,7 +181,7 @@ protected function handle_response($response) $this->edebug($response->get_error_messages()); return false; } - + $this->edebug('Response headers: ' . print_r($response['headers'], true)); $this->edebug('Response body: ' . print_r($response['body'], true));