AccessControl::NO_ACCESS_RESTRICTION, ]; /** @var Clicks */ private $clicks; /** @var Opens */ private $opens; /** @var LinkTokens */ private $link_tokens; public function __construct(Clicks $clicks, Opens $opens, LinkTokens $link_tokens) { $this->clicks = $clicks; $this->opens = $opens; $this->link_tokens = $link_tokens; } function click($data) { return $this->clicks->track($this->_processTrackData($data)); } function open($data) { return $this->opens->track($this->_processTrackData($data)); } function _processTrackData($data) { $data = (object)Links::transformUrlDataObject($data); if (empty($data->queue_id) || empty($data->subscriber_id) || empty($data->subscriber_token) ) { return false; } $data->queue = SendingQueue::findOne($data->queue_id); if ($data->queue) { $data->queue = SendingTask::createFromQueue($data->queue); } $data->subscriber = Subscriber::findOne($data->subscriber_id) ?: null; $data->newsletter = (!empty($data->queue->newsletter_id)) ? Newsletter::findOne($data->queue->newsletter_id) : false; if (!empty($data->link_hash)) { $data->link = NewsletterLink::where('hash', $data->link_hash) ->where('queue_id', $data->queue_id) ->findOne(); } return $this->_validateTrackData($data); } function _validateTrackData($data) { if (!$data->subscriber || !$data->queue || !$data->newsletter) return false; $subscriber_token_match = $this->link_tokens->verifyToken($data->subscriber, $data->subscriber_token); if (!$subscriber_token_match) { $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; } function terminate($code) { WPFunctions::get()->statusHeader($code); WPFunctions::get()->getTemplatePart((string)$code); exit; } }