data = $this->_processBrowserPreviewData($data); } function view() { $view_in_browser = new NewsletterViewInBrowser(); return $this->_displayNewsletter($view_in_browser->view($this->data)); } function _processBrowserPreviewData($data) { $data = (object)$data; if(empty($data->subscriber_id) || empty($data->subscriber_token) || empty($data->newsletter_id) ) { $this->_abort(); } else { $data->newsletter = Newsletter::findOne($data->newsletter_id); $data->subscriber = Subscriber::findOne($data->subscriber_id); $data->queue = ($data->queue_id) ? SendingQueue::findOne($data->queue_id) : false; return ($this->_validateBrowserPreviewData($data)) ? $data : $this->_abort(); } } function _validateBrowserPreviewData($data) { if(!$data || !$data->subscriber || !$data->newsletter) return false; $subscriber_token_match = Subscriber::verifyToken($data->subscriber->email, $data->subscriber_token); if(!$subscriber_token_match) return false; // return if this is a WP user previewing the newsletter if($data->subscriber->isWPUser() && $data->preview) { return $data; } // if queue exists, check if the newsletter was sent to the subscriber if($data->queue && !$data->queue->isSubscriberProcessed($data->subscriber->id)) { $data = false; } return $data; } function _displayNewsletter($result) { header('Content-Type: text/html; charset=utf-8'); echo $result; exit; } function _abort() { status_header(404); exit; } }