Admin
5 years ago
Commands
6 years ago
Db
6 years ago
Ecommerce
6 years ago
Report
6 years ago
Site
5 years ago
TrackingCode
5 years ago
User
5 years ago
views
6 years ago
API.php
5 years ago
Access.php
6 years ago
AjaxTracker.php
5 years ago
Annotations.php
6 years ago
Bootstrap.php
6 years ago
Capabilities.php
6 years ago
Compatibility.php
6 years ago
Email.php
5 years ago
Installer.php
6 years ago
Logger.php
5 years ago
OptOut.php
5 years ago
Paths.php
6 years ago
PrivacyBadge.php
6 years ago
Referral.php
6 years ago
Roles.php
6 years ago
ScheduledTasks.php
6 years ago
Settings.php
5 years ago
Site.php
6 years ago
TrackingCode.php
5 years ago
Uninstaller.php
6 years ago
Updater.php
6 years ago
User.php
6 years ago
Referral.php
123 lines
| 1 | <?php |
| 2 | /** |
| 3 | * Matomo - free/libre analytics platform |
| 4 | * |
| 5 | * @link https://matomo.org |
| 6 | * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later |
| 7 | * @package matomo |
| 8 | */ |
| 9 | |
| 10 | namespace WpMatomo; |
| 11 | |
| 12 | if ( ! defined( 'ABSPATH' ) ) { |
| 13 | exit; // if accessed directly |
| 14 | } |
| 15 | |
| 16 | /** |
| 17 | * Every 90 days we show a please review notice until the user dismisses this notice or clicks on rate us. |
| 18 | * We only show this notice on Matomo screens. |
| 19 | * |
| 20 | * @package WpMatomo |
| 21 | */ |
| 22 | class Referral { |
| 23 | |
| 24 | const OPTION_NAME_REFERRAL_DISMISSED = 'matomo-referral-dismissed'; |
| 25 | |
| 26 | /** |
| 27 | * @var int |
| 28 | */ |
| 29 | private $time; |
| 30 | |
| 31 | public function __construct() { |
| 32 | $this->time = time(); |
| 33 | } |
| 34 | |
| 35 | /** |
| 36 | * @internal for tests only |
| 37 | * @param int $time |
| 38 | */ |
| 39 | public function set_time( $time ) { |
| 40 | $this->time = $time; |
| 41 | } |
| 42 | |
| 43 | public function register_hooks() { |
| 44 | $self = $this; |
| 45 | |
| 46 | add_action( |
| 47 | 'wp_ajax_matomo_referral_dismiss_admin_notice', |
| 48 | function () use ( $self ) { |
| 49 | if ( is_admin() && $self->should_show() && $self->can_refer() ) { |
| 50 | // no need for an nonce check here as it's nothing critical |
| 51 | if ( ! empty( $_POST['forever'] ) ) { |
| 52 | $self->dismiss_forever(); |
| 53 | } else { |
| 54 | $self->dismiss(); |
| 55 | } |
| 56 | } |
| 57 | } |
| 58 | ); |
| 59 | add_action( |
| 60 | 'admin_notices', |
| 61 | function () use ( $self ) { |
| 62 | if ( $self->can_refer() && $self->should_show_on_screen() ) { |
| 63 | $self->render(); |
| 64 | } |
| 65 | } |
| 66 | ); |
| 67 | } |
| 68 | |
| 69 | public function render() { |
| 70 | include 'views/referral.php'; |
| 71 | } |
| 72 | |
| 73 | public function should_show_on_screen() { |
| 74 | if ( ! is_admin() ) { |
| 75 | return false; |
| 76 | } |
| 77 | $screen = get_current_screen(); |
| 78 | return $screen && $screen->id && strpos( $screen->id, 'matomo-' ) === 0; |
| 79 | } |
| 80 | |
| 81 | public function can_refer() { |
| 82 | return current_user_can( Capabilities::KEY_VIEW ); |
| 83 | } |
| 84 | |
| 85 | public function dismiss_forever() { |
| 86 | $tenYears = 60 * 60 * 24 * 365 * 10; |
| 87 | update_option( self::OPTION_NAME_REFERRAL_DISMISSED, $this->time + $tenYears ); |
| 88 | } |
| 89 | |
| 90 | public function dismiss() { |
| 91 | update_option( self::OPTION_NAME_REFERRAL_DISMISSED, $this->time, true ); |
| 92 | } |
| 93 | |
| 94 | public function get_last_dismissed() { |
| 95 | return get_option( self::OPTION_NAME_REFERRAL_DISMISSED ); |
| 96 | } |
| 97 | |
| 98 | private function get_days_in_seconds( $num_days ) { |
| 99 | return 60 * 60 * 24 * $num_days; |
| 100 | } |
| 101 | |
| 102 | public function should_show() { |
| 103 | $dismissed = $this->get_last_dismissed(); |
| 104 | |
| 105 | if ( ! $dismissed ) { |
| 106 | // the first time we check... we set it back 30 days cause we want to see first rating after 60 days |
| 107 | $this->time = $this->time - $this->get_days_in_seconds( 30 ); |
| 108 | $this->dismiss(); |
| 109 | return false; |
| 110 | } |
| 111 | |
| 112 | $ninetyDaysInSeconds = $this->get_days_in_seconds( 90 ); |
| 113 | |
| 114 | if ( $this->time > ( $dismissed + $ninetyDaysInSeconds ) ) { |
| 115 | return true; |
| 116 | } |
| 117 | |
| 118 | return false; |
| 119 | } |
| 120 | |
| 121 | |
| 122 | } |
| 123 |