PluginProbe ʕ •ᴥ•ʔ
Matomo Analytics – Powerful, Privacy-First Insights for WordPress / 4.14.2
Matomo Analytics – Powerful, Privacy-First Insights for WordPress v4.14.2
5.11.1 5.11.0 5.10.2 5.10.1 trunk 1.0.2 1.0.3 1.0.4 1.0.5 1.0.6 1.1.0 1.1.1 1.1.2 1.1.3 1.2.0 1.3.0 1.3.1 1.3.2 4.0.0 4.0.1 4.0.2 4.0.3 4.0.4 4.1.0 4.1.1 4.1.2 4.1.3 4.10.0 4.11.0 4.12.0 4.13.0 4.13.2 4.13.3 4.13.4 4.13.5 4.14.0 4.14.1 4.14.2 4.15.0 4.15.1 4.15.2 4.15.3 4.2.0 4.3.0 4.3.1 4.4.1 4.4.2 4.5.0 4.6.0 5.0.1 5.0.2 5.0.3 5.0.4 5.0.5 5.0.6 5.0.7 5.0.8 5.1.0 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.10.0 5.2.0 5.2.1 5.2.2 5.3.0 5.3.1 5.3.2 5.3.3 5.6.0 5.6.1 5.7.0 5.7.1 5.8.0 5.8.1 5.8.2
matomo / classes / WpMatomo / Logger.php
matomo / classes / WpMatomo Last commit date
Admin 3 years ago Commands 4 years ago Db 4 years ago Ecommerce 3 years ago Report 4 years ago Site 3 years ago TrackingCode 4 years ago Updater 4 years ago User 3 years ago WpStatistics 4 years ago views 4 years ago API.php 4 years ago Access.php 4 years ago AjaxTracker.php 5 years ago Annotations.php 4 years ago Bootstrap.php 4 years ago Capabilities.php 4 years ago Compatibility.php 4 years ago Email.php 4 years ago Installer.php 4 years ago Logger.php 4 years ago OptOut.php 4 years ago Paths.php 4 years ago PrivacyBadge.php 4 years ago RedirectOnActivation.php 4 years ago Referral.php 4 years ago Roles.php 4 years ago ScheduledTasks.php 4 years ago Settings.php 4 years ago Site.php 3 years ago TrackingCode.php 4 years ago Uninstaller.php 4 years ago Updater.php 4 years ago User.php 4 years ago
Logger.php
115 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 use Exception;
13
14 if ( ! defined( 'ABSPATH' ) ) {
15 exit; // if accessed directly
16 }
17
18 class Logger {
19 const LEVEL_NONE = 99;
20 const LEVEL_DEBUG = 1;
21 const LEVEL_INFO = 3;
22
23 private function get_log_level() {
24 if ( defined( 'MATOMO_DEBUG' ) ) {
25 if ( MATOMO_DEBUG ) {
26 return self::LEVEL_DEBUG;
27 }
28
29 return self::LEVEL_NONE;
30 }
31
32 return self::LEVEL_INFO;
33 }
34
35 public function log( $message, $mode = 3 ) {
36 $log_level = $this->get_log_level();
37
38 if ( $log_level > $mode ) {
39 return;
40 }
41
42 if ( defined( 'WP_DEBUG' ) && WP_DEBUG === true ) {
43 if ( is_array( $message ) || is_object( $message ) ) {
44 error_log( 'Matomo: ' . print_r( $message, true ) );
45 } else {
46 error_log( 'Matomo: ' . $message );
47 }
48 }
49 }
50
51 public function clear_logged_exceptions() {
52 delete_option( $this->make_id() );
53 }
54
55 private function persist( $key, $message ) {
56 $id = $this->make_id();
57 $logs = $this->get_last_logged_entries();
58 $logs[] = [
59 'name' => $key,
60 'value' => time(),
61 'comment' => $message,
62 ];
63 $logs = array_slice( $logs, - 6 );
64 update_option( $id, $logs );
65 }
66
67 private function make_id() {
68 return Settings::OPTION_PREFIX . 'errorlogs';
69 }
70
71 public function get_last_logged_entries() {
72 $id = $this->make_id();
73 $logs = get_option( $id );
74 if ( empty( $logs ) ) {
75 $logs = [];
76 }
77
78 // remove any entry older than 1 week
79 $logs = array_filter(
80 $logs,
81 function ( $log ) {
82 $one_week_seconds = 604800;
83
84 return ! empty( $log['value'] ) && is_numeric( $log['value'] ) && ( time() - $log['value'] ) <= $one_week_seconds;
85 }
86 );
87
88 return $logs;
89 }
90
91 public function get_readable_trace( Exception $e ) {
92 $trace = '';
93 if ( $e->getFile() ) {
94 $trace = basename( $e->getFile() ) . ':' . $e->getLine() . '; ';
95 }
96 foreach ( $e->getTrace() as $index => $item ) {
97 if ( ! empty( $item['file'] ) ) {
98 $trace .= basename( $item['file'] ) . ':' . $item['line'] . '; ';
99 }
100 if ( $index > 8 ) {
101 continue;
102 }
103 }
104
105 return trim( $trace );
106 }
107
108 public function log_exception( $key, Exception $e ) {
109 $trace = $this->get_readable_trace( $e );
110 $message = $e->getMessage() . ' => ' . $trace;
111 $this->log( 'Matomo error: ' . $message );
112 $this->persist( $key, $message );
113 }
114 }
115