- Updates front router and endpoints to use dynamic methods

This commit is contained in:
Vlad
2016-08-24 10:19:49 -04:00
parent 05c128d12d
commit 133d123919
5 changed files with 35 additions and 18 deletions

View File

@@ -12,28 +12,33 @@ class ViewInBrowser {
const ENDPOINT = 'view_in_browser';
const ACTION_VIEW = 'view';
static function view($data) {
function view($data) {
$data = $this->_processBrowserPreviewData($data);
$view_in_browser = new NewsletterViewInBrowser();
$view_in_browser->view(self::_processBrowserPreviewData($data));
return $this->_displayNewsletter($view_in_browser->view($data));
}
static function _processBrowserPreviewData($data) {
function _processBrowserPreviewData($data) {
$data = (object)$data;
if(empty($data->subscriber_id) ||
empty($data->subscriber_token) ||
empty($data->newsletter_id)
) {
return false;
$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();
}
$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 self::_validateBrowserPreviewData($data);
}
static function _validateBrowserPreviewData($data) {
function _validateBrowserPreviewData($data) {
if(!$data || !$data->subscriber || !$data->newsletter) return false;
$subscriber_token_match =
Subscriber::verifyToken($data->subscriber->email, $data->subscriber_token);
@@ -48,4 +53,15 @@ class ViewInBrowser {
}
return $data;
}
function _displayNewsletter($rendered_newsletter) {
header('Content-Type: text/html; charset=utf-8');
echo $rendered_newsletter;
exit;
}
function _abort() {
status_header(404);
exit;
}
}