AccessControl::NO_ACCESS_RESTRICTION, ]; /** @var Clicks */ private $clicks; /** @var Opens */ private $opens; /** @var LinkTokens */ private $linkTokens; public function __construct(Clicks $clicks, Opens $opens, LinkTokens $linkTokens) { $this->clicks = $clicks; $this->opens = $opens; $this->linkTokens = $linkTokens; } public function click($data) { return $this->clicks->track($this->_processTrackData($data)); } public function open($data) { return $this->opens->track($this->_processTrackData($data)); } public function _processTrackData($data) { $data = (object)Links::transformUrlDataObject($data); if (empty($data->queueId) || empty($data->subscriberId) || empty($data->subscriberToken) ) { return false; } $data->queue = SendingQueue::findOne($data->queueId); if ($data->queue instanceof SendingQueue) { $data->queue = SendingTask::createFromQueue($data->queue); } $data->subscriber = Subscriber::findOne($data->subscriberId) ?: null; $data->newsletter = (!empty($data->queue->newsletterId)) ? Newsletter::findOne($data->queue->newsletterId) : false; if (!empty($data->linkHash)) { $data->link = NewsletterLink::where('hash', $data->linkHash) ->where('queue_id', $data->queueId) ->findOne(); } return $this->_validateTrackData($data); } public function _validateTrackData($data) { if (!$data->subscriber || !$data->queue || !$data->newsletter) return false; $subscriberTokenMatch = $this->linkTokens->verifyToken($data->subscriber, $data->subscriberToken); if (!$subscriberTokenMatch) { $this->terminate(403); } // return if this is a WP user previewing the newsletter if ($data->subscriber->isWPUser() && $data->preview) { return $data; } // check if the newsletter was sent to the subscriber return ($data->queue->isSubscriberProcessed($data->subscriber->id)) ? $data : false; } public function terminate($code) { WPFunctions::get()->statusHeader($code); WPFunctions::get()->getTemplatePart((string)$code); exit; } }