Use array instead of \stdClass, fix coding style
[MAILPOET-2430]
This commit is contained in:
committed by
Jack Kitterhing
parent
923dc0d1dd
commit
ddfc9647dd
@ -45,70 +45,73 @@ class ViewInBrowser {
|
||||
return $this->_displayNewsletter($viewInBrowser->view($data));
|
||||
}
|
||||
|
||||
public function _processBrowserPreviewData($data) {
|
||||
$data = (object)NewsletterUrl::transformUrlDataObject($data);
|
||||
return ($this->_validateBrowserPreviewData($data)) ?
|
||||
$data :
|
||||
$this->_abort();
|
||||
public function _processBrowserPreviewData(array $data) {
|
||||
$data = NewsletterUrl::transformUrlDataObject($data);
|
||||
return $this->_validateBrowserPreviewData($data) ?: $this->_abort();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param \stdClass $data
|
||||
* @return bool|\stdClass
|
||||
* @param array $data
|
||||
* @return array|false
|
||||
*/
|
||||
public function _validateBrowserPreviewData($data) {
|
||||
public function _validateBrowserPreviewData(array $data) {
|
||||
// either newsletter ID or hash must be defined, and newsletter must exist
|
||||
if (empty($data->newsletter_id) && empty($data->newsletter_hash)) return false; // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
$data->newsletter = (!empty($data->newsletter_hash)) ? // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
Newsletter::getByHash($data->newsletter_hash) : // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
Newsletter::findOne($data->newsletter_id); // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
if (!$data->newsletter) return false;
|
||||
if (empty($data['newsletter_id']) && empty($data['newsletter_hash'])) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$data['newsletter'] = (!empty($data['newsletter_hash']))
|
||||
? Newsletter::getByHash($data['newsletter_hash'])
|
||||
: Newsletter::findOne($data['newsletter_id']);
|
||||
if (!$data['newsletter']) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// subscriber is optional; if exists, token must validate
|
||||
$data->subscriber = (!empty($data->subscriber_id)) ? // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
Subscriber::findOne($data->subscriber_id) : // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
false;
|
||||
if ($data->subscriber) {
|
||||
if (empty($data->subscriber_token) || // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
!$this->linkTokens->verifyToken($data->subscriber, $data->subscriber_token) // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
) return false;
|
||||
} else if (!$data->subscriber && !empty($data->preview)) {
|
||||
$data['subscriber'] = !empty($data['subscriber_id']) ? Subscriber::findOne($data['subscriber_id']) : false;
|
||||
if ($data['subscriber']) {
|
||||
if (empty($data['subscriber_token']) || !$this->linkTokens->verifyToken($data['subscriber'], $data['subscriber_token'])) {
|
||||
return false;
|
||||
}
|
||||
} else if (!$data['subscriber'] && !empty($data['preview'])) {
|
||||
// if this is a preview and subscriber does not exist,
|
||||
// attempt to set subscriber to the current logged-in WP user
|
||||
$data->subscriber = Subscriber::getCurrentWPUser();
|
||||
$data['subscriber'] = Subscriber::getCurrentWPUser();
|
||||
}
|
||||
|
||||
// if newsletter hash is not provided but newsletter ID is defined then subscriber must exist
|
||||
if (empty($data->newsletter_hash) && $data->newsletter_id && !$data->subscriber) return false; // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
if (empty($data['newsletter_hash']) && $data['newsletter_id'] && !$data['subscriber']) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// queue is optional; try to find it if it's not defined and this is not a welcome email
|
||||
if ($data->newsletter->type !== Newsletter::TYPE_WELCOME) {
|
||||
$data->queue = (!empty($data->queue_id)) ? // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
SendingQueue::findOne($data->queue_id) : // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
SendingQueue::where('newsletter_id', $data->newsletter->id)
|
||||
->findOne();
|
||||
if ($data['newsletter']->type !== Newsletter::TYPE_WELCOME) {
|
||||
$data['queue'] = (!empty($data['queue_id']))
|
||||
? SendingQueue::findOne($data['queue_id'])
|
||||
: SendingQueue::where('newsletter_id', $data['newsletter']->id)->findOne();
|
||||
} else {
|
||||
$data->queue = false;
|
||||
$data['queue'] = false;
|
||||
}
|
||||
|
||||
// reset queue when automatic email is being previewed
|
||||
if ($data->newsletter->type === Newsletter::TYPE_AUTOMATIC && !empty($data->preview)) {
|
||||
$data->queue = false;
|
||||
if ($data['newsletter']->type === Newsletter::TYPE_AUTOMATIC && !empty($data['preview'])) {
|
||||
$data['queue'] = false;
|
||||
}
|
||||
|
||||
// allow users with permission to manage emails to preview any newsletter
|
||||
if (!empty($data->preview) && $this->accessControl->validatePermission(AccessControl::PERMISSION_MANAGE_EMAILS)
|
||||
) return $data;
|
||||
if (!empty($data['preview']) && $this->accessControl->validatePermission(AccessControl::PERMISSION_MANAGE_EMAILS)) {
|
||||
return $data;
|
||||
}
|
||||
|
||||
// allow others to preview newsletters only when newsletter hash is defined
|
||||
if (!empty($data->preview) && empty($data->newsletter_hash) // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
) return false;
|
||||
if (!empty($data['preview']) && empty($data['newsletter_hash'])) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// if queue and subscriber exist, subscriber must have received the newsletter
|
||||
if ($data->queue instanceof SendingQueue &&
|
||||
$data->subscriber &&
|
||||
!$data->queue->isSubscriberProcessed($data->subscriber->id)
|
||||
) return false;
|
||||
if ($data['queue'] instanceof SendingQueue && $data['subscriber'] && !$data['queue']->isSubscriberProcessed($data['subscriber']->id)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
Reference in New Issue
Block a user