- Converts static classes to dynamic

This commit is contained in:
Vlad
2016-08-22 16:22:33 -04:00
parent ed352bb1d3
commit ec09fbcb78
6 changed files with 197 additions and 27 deletions

View File

@ -7,8 +7,10 @@ use MailPoet\Newsletter\Shortcodes\Categories\Link;
if(!defined('ABSPATH')) exit;
class Clicks {
static function track($data) {
if(!$data || empty($data->link)) self::abort();
function track($data) {
if(!$data || empty($data->link)) {
return $this->abort();
}
$subscriber = $data->subscriber;
$queue = $data->queue;
$newsletter = $data->newsletter;
@ -17,22 +19,23 @@ class Clicks {
// log statistics only if the action did not come from
// a WP user previewing the newsletter
if(!$wp_user_preview) {
$statistics = StatisticsClicks::createOrUpdateClickCount(
StatisticsClicks::createOrUpdateClickCount(
$link->id,
$subscriber->id,
$newsletter->id,
$queue->id
);
// track open event
Opens::track($data, $display_image = false);
$open_event = new Opens();
$open_event->track($data, $display_image = false);
}
$url = self::processUrl($link->url, $newsletter, $subscriber, $queue, $wp_user_preview);
self::redirectToUrl($url);
$url = $this->processUrl($link->url, $newsletter, $subscriber, $queue, $wp_user_preview);
$this->redirectToUrl($url);
}
static function processUrl($url, $newsletter, $subscriber, $queue, $wp_user_preview) {
function processUrl($url, $newsletter, $subscriber, $queue, $wp_user_preview) {
if(preg_match('/\[link:(?P<action>.*?)\]/', $url, $shortcode)) {
if(!$shortcode['action']) self::abort();
if(!$shortcode['action']) $this->abort();
$url = Link::processShortcodeAction(
$shortcode['action'],
$newsletter,
@ -44,12 +47,12 @@ class Clicks {
return $url;
}
static function abort() {
function abort() {
status_header(404);
exit;
}
static function redirectToUrl($url) {
function redirectToUrl($url) {
header('Location: ' . $url, true, 302);
exit;
}

View File

@ -6,8 +6,10 @@ use MailPoet\Models\StatisticsOpens;
if(!defined('ABSPATH')) exit;
class Opens {
static function track($data, $display_image = true) {
if(!$data) return self::returnResponse($display_image);
function track($data, $display_image = true) {
if(!$data) {
return $this->returnResponse($display_image);
}
$subscriber = $data->subscriber;
$queue = $data->queue;
$newsletter = $data->newsletter;
@ -21,10 +23,10 @@ class Opens {
$queue->id
);
}
return self::returnResponse($display_image);
return $this->returnResponse($display_image);
}
static function returnResponse($display_image) {
function returnResponse($display_image) {
if(!$display_image) return;
// return 1x1 pixel transparent gif image
header('Content-Type: image/gif');

View File

@ -6,12 +6,17 @@ use MailPoet\Models\StatisticsUnsubscribes;
if(!defined('ABSPATH')) exit;
class Unsubscribes {
static function track($newsletter, $subscriber, $queue, $wp_user_preview) {
if($wp_user_preview) return;
StatisticsUnsubscribes::getOrCreate(
$subscriber->id,
$newsletter->id,
$queue->id
);
function track($newsletter_id, $subscriber_id, $queue_id) {
$statistics = StatisticsUnsubscribes::where('subscriber_id', $subscriber_id)
->where('newsletter_id', $newsletter_id)
->where('queue_id', $queue_id)
->findOne();
if(!$statistics) {
$statistics = StatisticsUnsubscribes::create();
$statistics->newsletter_id = $newsletter_id;
$statistics->subscriber_id = $subscriber_id;
$statistics->queue_id = $queue_id;
$statistics->save();
}
}
}